dgs-js 1.0.6 → 1.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (2) hide show
  1. package/dist/index.js +116 -67
  2. package/package.json +1 -1
package/dist/index.js CHANGED
@@ -1,23 +1,23 @@
1
- var di=(async function(U={}){var t,i=U,o=!0,C=!1,h=[],f="./this.program",d=(A,e)=>{throw e},w=import.meta.url,F="",l,v;if(o||C){try{F=new URL(".",w).href}catch{}l=async A=>{var e=await fetch(A,{credentials:"same-origin"});if(e.ok)return e.arrayBuffer();throw new Error(e.status+" : "+e.url)}}var J=console.log.bind(console),P=console.error.bind(console),L,O=!1,S,X,V,z,M,R,m,p,QA,N,Qe,ae,Ie,oe,Ce=!1;function Ee(){var A=z.buffer;M=new Int8Array(A),m=new Int16Array(A),R=new Uint8Array(A),p=new Uint16Array(A),QA=new Int32Array(A),N=new Uint32Array(A),Qe=new Float32Array(A),ae=new Float64Array(A),Ie=new BigInt64Array(A),oe=new BigUint64Array(A)}function at(){if(i.preRun)for(typeof i.preRun=="function"&&(i.preRun=[i.preRun]);i.preRun.length;)wt(i.preRun.shift());he(le)}function It(){Ce=!0,hA.ca()}function ot(){if(i.postRun)for(typeof i.postRun=="function"&&(i.postRun=[i.postRun]);i.postRun.length;)Dt(i.postRun.shift());he(ce)}var aA=0,lA=null;function Ct(A){aA++,i.monitorRunDependencies?.(aA)}function Et(A){if(aA--,i.monitorRunDependencies?.(aA),aA==0&&lA){var e=lA;lA=null,e()}}function LA(A){i.onAbort?.(A),A="Aborted("+A+")",P(A),O=!0,A+=". Build with -sASSERTIONS for more info.";var e=new WebAssembly.RuntimeError(A);throw V?.(e),e}var WA;function nt(){return yt("AGFzbQEAAAAB8AEeYAF/AGABfwF/YAJ/fwF/YAN/f38Bf2ACf38AYAN/f38AYAAAYAR/f39/AGAGf39/f39/AGAFf39/f38AYAABf2AEf39/fwF/YAp/f39/f39/f39/AGAEf39/fwF8YAV/f39/fwF8YAd/f39/f39/AGAFf39/fn4AYAh/f39/f39/fwBgBn9/f39/fwF8YAt/f39/f39/f39/fwBgAn98AX9gA39/fwF8YAx/f39/f39/f39/f38AYA1/f39/f39/f39/f39/AGADf39+AX9gBX9/f39/AX9gA39/fQBgAn9/AX1gA39+fwF+YAJ/fAACzAI3AWEBYQAKAWEBYgAEAWEBYwAFAWEBZAADAWEBZQABAWEBZgACAWEBZwAMAWEBaAAAAWEBaQAJAWEBagACAWEBawAAAWEBbAAHAWEBbQABAWEBbgAFAWEBbwAFAWEBcAADAWEBcQANAWEBcgALAWEBcwAFAWEBdAAQAWEBdQARAWEBdgAAAWEBdwAGAWEBeAABAWEBeQASAWEBegANAWEBQQAOAWEBQgAGAWEBQwAFAWEBRAATAWEBRQAAAWEBRgAGAWEBRwAUAWEBSAAGAWEBSQABAWEBSgALAWEBSwAAAWEBTAAAAWEBTQAEAWEBTgAHAWEBTwAEAWEBUAAFAWEBUQAKAWEBUgAOAWEBUwAVAWEBVAABAWEBVQACAWEBVgABAWEBVwAAAWEBWAAMAWEBWQAIAWEBWgAIAWEBXwAAAWEBJAAWAWECYWEAFwN7egQAAQMAAwAYAAEJAQUAAAEAAAgHBgYBAQMPBQAPBAIFAQQZBgEABgELBhoBGwAGAQAAAgkHCQgDAwAAAhwBAwECAAABAgAAAQICAgICBgAFAwQCCgQEBAQEAgQFAgUCAAEAAgoBAQAEAAAdCgABAQEDCAgJCQMHBwAGBAUBcAFubgUHAQGCAoCAAgYIAX8BQYDJBAsHVA8CYmECAAJjYQCwAQJkYQB2AmVhAEACZmEAOAJnYQEAAmhhAKEBAmlhAJ4BAmphAJ0BAmthAK8BAmxhAKIBAm1hAHECbmEAcAJvYQCnAQJwYQCmAQmcAQEAQQELbWWcAWSbAZoBmQGYAZcBlgGVAZQBkwGSAWNhkQGQAY8BjgGNAYwBiwGKAWQ5MWNhMIkBiAGHAYYBJAmFARsWNA8QFS0u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cWoiBigCECIEDQALIAYgAzYCEEEYIQEgAiEEQQgLIQAgAyICDAELIAIoAggiBCADNgIMIAIgAzYCCEEYIQBBCCEBQQALIQYgASADaiAENgIAIAMgAjYCDCAAIANqIAY2AgBBlDZBlDYoAgBBAWsiAEF/IAAbNgIACwtiAQF/An9BASAAIABBAU0bIQADQAJAIAAQQCIBBH8gAQVB6MMAKAIAIgENAUEACwwCCyABEQYADAALAAsiAEUEQEEEEEYiAEGoMjYCACAAQeAvNgIAIABB/C9BOxAOAAsgAAt0AQF/IAJFBEAgACgCBCABKAIERg8LIAAgAUYEQEEBDwsgASgCBCICLQAAIQECQCAAKAIEIgMtAAAiAEUNACAAIAFHDQADQCACLQABIQEgAy0AASIARQ0BIAJBAWohAiADQQFqIQMgACABRg0ACwsgACABRgtEAQF/AkAgACgCBCIBQQlPBEBB5DlBADYCAEEnIAEQAUHkOSgCAEHkOUEANgIAQQFGDQEgAEEANgIECw8LQQAQBBA/AAutAwEFfyMAQRBrIgQkACAEIAAoAgAiBUEIaygCACIDNgIMIAQgACADajYCBCAEIAVBBGsoAgA2AgggBCgCBCEGAkAgBCgCCCIFIAJBABA6BEBBACAGIAQoAgwbIQMMAQsjAEFAaiIDJAAgACAGTgRAIAMgAjYCDCADIAU2AgQgAyAANgIIIANBEGpBAEEk/AsAIANBADYCPCADQoGAgICAgICAATcCNCAFIANBBGogBiAGQQFBACAFKAIAKAIUEQgAIABBACADKAIcGyEHCyADQUBrJAAgByIDDQAjAEFAaiIDJAAgAyABNgIMIAMgADYCCCADIAI2AgRBACEAIANBEGpBAEEr/AsAIANBADYCPCADQQE6ADsgBSADQQRqIAZBAUEAIAUoAgAoAhgRCQACQAJAAkAgAygCKA4CAAECCyADKAIYQQAgAygCJEEBRhtBACADKAIgQQFGG0EAIAMoAixBAUYbIQAMAQsgAygCHEEBRwRAIAMoAiwNASADKAIgQQFHDQEgAygCJEEBRw0BCyADKAIUIQALIANBQGskACAAIQMLIARBEGokACADCwYAIAAQOAvOAwIFfwF+IwBBIGsiBCQAAn8gAC0AAARAQQACfyACpyEGIAAoAggiAygCTBogAyADKAJIIgBB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IABBCGoiACAESQ0ACwsLGAAgACABKAIIQQAQOgRAIAEgAiADEFELCwYAIAAkAAt/AEHsOUEBNgIAQfA5QQA2AgAQZUHwOUGMOigCADYCAEGMOkHsOTYCAEGQOkE6NgIAQZQ6QQA2AgAQWkGUOkGMOigCADYCAEGMOkGQOjYCAEHUOkGAwAA2AgBBzDpBgMkENgIAQbA6QSo2AgBB+DpBvDs2AgBB0DpBgIAENgIACwvAKhUAQYAIC/EdZmFpbGVkIHRvIGFsbG9jYXRlIG1lbW9yeQBVaW50OEFycmF5AGNvbG9yTWF4AHNoTWF4AC0rICAgMFgweABtaXNtYXRjaGVkIHZlcnNpb24hIGV4cGVjdGVkIDEuMC54AHVuc2lnbmVkIHNob3J0AHVuc2lnbmVkIGludABzZXQAZmxvYXQAaW52YWxpZCBjb2xvciBub3JtYWxpemF0aW9uIGNvZWZmaWNpZW50cwBpbnZhbGlkIHNoIG5vcm1hbGl6YXRpb24gY29lZmZpY2llbnRzAHN1Y2Nlc3MAY29sb3JzAGZpbGUgY29udGFpbnMgMCBnYXVzc2lhbnMAR2F1c3NpYW5zAG1lYW5zAHNocwB2ZWxvY2l0aWVzAG9wYWNpdGllcwBjb3ZhcmlhbmNlcwB2ZWN0b3IAYXR0ZW1wdGluZyB0byByZWFkIHBhc3QgZW5kIG9mIGJ1ZmZlcgB1bnNpZ25lZCBjaGFyAHN0ZDo6ZXhjZXB0aW9uAGR1cmF0aW9uAGNvbG9yTWluAHNoTWluAGJvb2wAbGVuZ3RoAHVuc2lnbmVkIGxvbmcgbG9uZwB1bnNpZ25lZCBsb25nAHN0ZDo6d3N0cmluZwBiYXNpY19zdHJpbmcAc3RkOjpzdHJpbmcAc3RkOjp1MTZzdHJpbmcAc3RkOjp1MzJzdHJpbmcAZ2F1c3NpYW4gY291bnQgbXVzdCBiZSBwb3NpdGl2ZQBjb21iaW5lAGZhaWxlZCB0byByZWFkIGZyb20gZmlsZQBkb3VibGUAb3V0IG9mIGJvdW5kcyBzaCBkZWdyZWUAY2Fubm90IGNvbWJpbmUgZ2F1c3NpYW5zIHdpdGggZGlmZmVyZW50IHNoRGVncmVlAGRlY29kZQBtaXNtYXRjaGVkIG1hZ2ljIHdvcmQAdm9pZABzdGQ6OmJhZF9hbGxvYwBkeW5hbWljAGRnc19lcnJvci5jAGRnc19kZWNvZGUuYwBuZWdhdGl2ZSBkdXJhdGlvbiBlbmNvdW50ZXJlZCBpbiBtZXRhZGF0YQBNZXRhZGF0YQBnYXVzc2lhbiBzcGhlcmljYWwgaGFybW9taWMgZGVncmVlIG11c3QgYmUgbGVzcyB0aGFuIERHU19HQVVTU0lBTlNfTUFYX1NIX0RFR1JFRQBlbXNjcmlwdGVuOjptZW1vcnlfdmlldzxzaG9ydD4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8dW5zaWduZWQgc2hvcnQ+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PGludD4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8dW5zaWduZWQgaW50PgBlbXNjcmlwdGVuOjptZW1vcnlfdmlldzxmbG9hdD4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8dWludDhfdD4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8aW50OF90PgBlbXNjcmlwdGVuOjptZW1vcnlfdmlldzx1aW50MTZfdD4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8aW50MTZfdD4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8dWludDY0X3Q+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PGludDY0X3Q+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PHVpbnQzMl90PgBlbXNjcmlwdGVuOjptZW1vcnlfdmlldzxpbnQzMl90PgBlbXNjcmlwdGVuOjptZW1vcnlfdmlldzxjaGFyPgBlbXNjcmlwdGVuOjptZW1vcnlfdmlldzx1bnNpZ25lZCBjaGFyPgBlbXNjcmlwdGVuOjptZW1vcnlfdmlldzxzaWduZWQgY2hhcj4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8bG9uZz4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8dW5zaWduZWQgbG9uZz4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8ZG91YmxlPgBpbnZhbGlkIGlucHV0IChwcm92aWRlZCBtZW1vcnkvZmlsZSBpbnB1dCB3YXMgaW4gYW4gaW52YWxpZCBmb3JtYXQpAChudWxsKQBpbnZhbGlkIGFyZ3VtZW50cyAoYmFkIGZ1bmN0aW9uIGNhbGwpAGZhaWxlZCB0byB3cml0ZSB0byBhIGZpbGUgKGZ3cml0ZSB3cm90ZSBmZXdlciBieXRlcyB0aGFuIHJlcXVlc3RlZCkAZmFpbGVkIHRvIHJlYWQgZnJvbSBhIGZpbGUgKGZyZWFkIHJlYWQgZmV3ZXIgYnl0ZXMgdGhhbiByZXF1ZXN0ZWQpAGZhaWxlZCB0byBvcGVuIGEgZmlsZSAoZm9wZW4gcmV0dXJuZWQgTlVMTCkAb3V0IG9mIG1lbW9yeSAoREdTX01BTExPQy9ER1NfUkVBTExPQyByZXR1cm5lZCBOVUxMKQBmYWlsZWQgdG8gY2xvc2UgYSBmaWxlIChmY2xvc2UgcmV0dXJuZWQgRU9GKQBER1MgaW50ZXJuYWwgZXJyb3I6ICIAREdTIEVSUk9SOiAiJXMiIGluICVzIGF0IGxpbmUgJWkKAERHUyBXQVJOSU5HOiAiJXMiIGluICVzIGF0IGxpbmUgJWkKAAlpbiAlcyBhdCBsaW5lICVpCgAAAADAGAAA8AsAADEyREdTZ2F1c3NpYW5zAADEFwAAEAwAAAAAAADoCwAAUDEyREdTZ2F1c3NpYW5zAMQXAAAwDAAAAQAAAOgLAABQSzEyREdTZ2F1c3NpYW5zAHBwAHYAdnAAAAAAAAAAAGgMAAA8AAAAPQAAAD4AAAA/AAAAQAAAAPgYAAB0DAAAtBQAAE5TdDNfXzIyMF9fc2hhcmVkX3B0cl9wb2ludGVySVAxMkRHU2dhdXNzaWFuc04xMGVtc2NyaXB0ZW4xNXNtYXJ0X3B0cl90cmFpdElOU18xMHNoYXJlZF9wdHJJUzFfRUVFMTF2YWxfZGVsZXRlckVOU185YWxsb2NhdG9ySVMxX0VFRUUATjEwZW1zY3JpcHRlbjE1c21hcnRfcHRyX3RyYWl0SU5TdDNfXzIxMHNoYXJlZF9wdHJJMTJER1NnYXVzc2lhbnNFRUUxMXZhbF9kZWxldGVyRQAAAABADwAAwBgAAFwNAABOU3QzX18yMTBzaGFyZWRfcHRySTEyREdTZ2F1c3NpYW5zRUUAcABwcHAAAFQNAAAAAAAAqA0AAEEAAABCAAAAQwAAAEQAAABFAAAA+BgAALQNAAC0FAAATlN0M19fMjIwX19zaGFyZWRfcHRyX2VtcGxhY2VJMTJER1NnYXVzc2lhbnNOU185YWxsb2NhdG9ySVMxX0VFRUUAaXBwAHZwcGkAZnBwAHZwcGYAwBgAABAOAAAxMURHU21ldGFkYXRhAAAAQA8AAEAPAABsFgAAQA8AAAAAAABMDgAARgAAAEcAAABIAAAASQAAAEoAAAD4GAAAWA4AALQUAABOU3QzX18yMjBfX3NoYXJlZF9wdHJfcG9pbnRlcklQMTJER1NnYXVzc2lhbnNaWkwyMWVtYmluZF9pbml0X2xpYmRnc19qc3ZFTkszJF83Y2xFUktOMTBlbXNjcmlwdGVuM3ZhbEVFVWxTMl9FX05TXzlhbGxvY2F0b3JJUzFfRUVFRQBaWkwyMWVtYmluZF9pbml0X2xpYmRnc19qc3ZFTkszJF83Y2xFUktOMTBlbXNjcmlwdGVuM3ZhbEVFVWxQMTJER1NnYXVzc2lhbnNFXwAAAFQNAABUDQAAVA0AAHBwcHAAAAAAwBgAAEgPAABOMTBlbXNjcmlwdGVuM3ZhbEUAAMAYAABkDwAATlN0M19fMjEyYmFzaWNfc3RyaW5nSWNOU18xMWNoYXJfdHJhaXRzSWNFRU5TXzlhbGxvY2F0b3JJY0VFRUUAAMAYAACsDwAATlN0M19fMjEyYmFzaWNfc3RyaW5nSXdOU18xMWNoYXJfdHJhaXRzSXdFRU5TXzlhbGxvY2F0b3JJd0VFRUUAAMAYAAD0DwAATlN0M19fMjEyYmFzaWNfc3RyaW5nSURzTlNfMTFjaGFyX3RyYWl0c0lEc0VFTlNfOWFsbG9jYXRvcklEc0VFRUUAAADAGAAAQBAAAE5TdDNfXzIxMmJhc2ljX3N0cmluZ0lEaU5TXzExY2hhcl90cmFpdHNJRGlFRU5TXzlhbGxvY2F0b3JJRGlFRUVFAAAAwBgAAIwQAABOMTBlbXNjcmlwdGVuMTFtZW1vcnlfdmlld0ljRUUAAMAYAAC0EAAATjEwZW1zY3JpcHRlbjExbWVtb3J5X3ZpZXdJYUVFAADAGAAA3BAAAE4xMGVtc2NyaXB0ZW4xMW1lbW9yeV92aWV3SWhFRQAAwBgAAAQRAABOMTBlbXNjcmlwdGVuMTFtZW1vcnlfdmlld0lzRUUAAMAYAAAsEQAATjEwZW1zY3JpcHRlbjExbWVtb3J5X3ZpZXdJdEVFAADAGAAAVBEAAE4x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")}function ht(A){if(ArrayBuffer.isView(A))return A;if(A==WA&&L)return new Uint8Array(L);if(v)return v(A);throw"both async and sync fetching of the wasm failed"}async function ct(A){return ht(A)}async function lt(A,e){try{var g=await ct(A),r=await WebAssembly.instantiate(g,e);return r}catch(s){P(`failed to asynchronously prepare wasm: ${s}`),LA(s)}}async function ut(A,e,g){return lt(e,g)}function dt(){return{a:ri}}async function ft(){function A(B,a){return hA=B.exports,z=hA.ba,Ee(),ve=hA.ga,ii(hA),Et("wasm-instantiate"),hA}Ct("wasm-instantiate");function e(B){return A(B.instance)}var g=dt();if(i.instantiateWasm)return new Promise((B,a)=>{i.instantiateWasm(g,(Q,I)=>{B(A(Q,I))})});WA??=nt();var r=await ut(L,WA,g),s=e(r);return s}class ne{name="ExitStatus";constructor(e){this.message=`Program terminated with exit(${e})`,this.status=e}}var he=A=>{for(;A.length>0;)A.shift()(i)},ce=[],Dt=A=>ce.push(A),le=[],wt=A=>le.push(A),yt=A=>{for(var e,g,r=0,s=0,B=A.length,a=new Uint8Array((B*3>>2)-(A[B-2]=="=")-(A[B-1]=="="));r<B;r+=4,s+=3)e=tA[A.charCodeAt(r+1)],g=tA[A.charCodeAt(r+2)],a[s]=tA[A.charCodeAt(r)]<<2|e>>4,a[s+1]=e<<4|g>>2,a[s+2]=g<<6|tA[A.charCodeAt(r+3)];return a},KA=!0,K=A=>Oe(A),Z=()=>Xe(),NA=[],ZA=0,Ft=A=>{var e=new OA(A);return e.get_caught()||(e.set_caught(!0),ZA--),e.set_rethrown(!1),NA.push(e),Ve(A),qe(A)},eA=0,pt=()=>{_(0,0);var A=NA.pop();je(A.excPtr),eA=0};class OA{constructor(e){this.excPtr=e,this.ptr=e-24}set_type(e){N[this.ptr+4>>2]=e}get_type(){return N[this.ptr+4>>2]}set_destructor(e){N[this.ptr+8>>2]=e}get_destructor(){return N[this.ptr+8>>2]}set_caught(e){e=e?1:0,M[this.ptr+12]=e}get_caught(){return M[this.ptr+12]!=0}set_rethrown(e){e=e?1:0,M[this.ptr+13]=e}get_rethrown(){return M[this.ptr+13]!=0}init(e,g){this.set_adjusted_ptr(0),this.set_type(e),this.set_destructor(g)}set_adjusted_ptr(e){N[this.ptr+16>>2]=e}get_adjusted_ptr(){return N[this.ptr+16>>2]}}var vA=A=>Ze(A),ue=A=>{var e=eA;if(!e)return vA(0),0;var g=new OA(e);g.set_adjusted_ptr(e);var r=g.get_type();if(!r)return vA(0),e;for(var s of A){if(s===0||s===r)break;var B=g.ptr+16;if(ze(s,r,B))return vA(s),e}return vA(r),e},mt=()=>ue([]),Nt=A=>ue([A]),vt=()=>{var A=NA.pop();A||LA("no exception to throw");var e=A.excPtr;throw A.get_rethrown()||(NA.push(A),A.set_rethrown(!0),A.set_caught(!1),ZA++),eA=e,eA},Rt=(A,e,g)=>{var r=new OA(A);throw r.init(e,g),eA=A,ZA++,eA},Yt=A=>{throw eA||(eA=A),eA},Ut=()=>LA(""),RA={},YA=A=>{for(;A.length;){var e=A.pop(),g=A.pop();g(e)}};function uA(A){return this.fromWireType(N[A>>2])}var nA={},IA={},UA={},Gt=class extends Error{constructor(e){super(e),this.name="InternalError"}},GA=A=>{throw new Gt(A)},rA=(A,e,g)=>{A.forEach(Q=>UA[Q]=e);function r(Q){var I=g(Q);I.length!==A.length&&GA("Mismatched type converter count");for(var E=0;E<A.length;++E)q(A[E],I[E])}var s=new Array(e.length),B=[],a=0;e.forEach((Q,I)=>{IA.hasOwnProperty(Q)?s[I]=IA[Q]:(B.push(Q),nA.hasOwnProperty(Q)||(nA[Q]=[]),nA[Q].push(()=>{s[I]=IA[Q],++a,a===B.length&&r(s)}))}),B.length===0&&r(s)},kt=A=>{var e=RA[A];delete RA[A];var g=e.rawConstructor,r=e.rawDestructor,s=e.fields,B=s.map(a=>a.getterReturnType).concat(s.map(a=>a.setterArgumentType));rA([A],B,a=>{var Q={};return s.forEach((I,E)=>{var n=I.fieldName,u=a[E],y=a[E].optional,H=I.getter,T=I.getterContext,BA=a[E+s.length],CA=I.setter,AA=I.setterContext;Q[n]={read:iA=>u.fromWireType(H(T,iA)),write:(iA,x)=>{var JA=[];CA(AA,iA,BA.toWireType(JA,x)),YA(JA)},optional:y}}),[{name:e.name,fromWireType:I=>{var E={};for(var n in Q)E[n]=Q[n].read(I);return r(I),E},toWireType:(I,E)=>{for(var n in Q)if(!(n in E)&&!Q[n].optional)throw new TypeError(`Missing field: "${n}"`);var u=g();for(n in Q)Q[n].write(u,E[n]);return I!==null&&I.push(r,u),u},argPackAdvance:$,readValueFromPointer:uA,destructorFunction:r}]})},k=A=>{for(var e="";;){var g=R[A++];if(!g)return e;e+=String.fromCharCode(g)}},dA=class extends Error{constructor(e){super(e),this.name="BindingError"}},D=A=>{throw new dA(A)};function St(A,e,g={}){var r=e.name;if(A||D(`type "${r}" must have a positive integer typeid pointer`),IA.hasOwnProperty(A)){if(g.ignoreDuplicateRegistrations)return;D(`Cannot register type '${r}' twice`)}if(IA[A]=e,delete UA[A],nA.hasOwnProperty(A)){var s=nA[A];delete nA[A],s.forEach(B=>B())}}function q(A,e,g={}){return St(A,e,g)}var de=(A,e,g)=>{switch(e){case 1:return g?r=>M[r]:r=>R[r];case 2:return g?r=>m[r>>1]:r=>p[r>>1];case 4:return g?r=>QA[r>>2]:r=>N[r>>2];case 8:return g?r=>Ie[r>>3]:r=>oe[r>>3];default:throw new TypeError(`invalid integer width (${e}): ${A}`)}},Mt=(A,e,g,r,s)=>{e=k(e);let B=r===0n,a=Q=>Q;if(B){let Q=g*8;a=I=>BigInt.asUintN(Q,I),s=a(s)}q(A,{name:e,fromWireType:a,toWireType:(Q,I)=>(typeof I=="number"&&(I=BigInt(I)),I),argPackAdvance:$,readValueFromPointer:de(e,g,!B),destructorFunction:null})},$=8,bt=(A,e,g,r)=>{e=k(e),q(A,{name:e,fromWireType:function(s){return!!s},toWireType:function(s,B){return B?g:r},argPackAdvance:$,readValueFromPointer:function(s){return this.fromWireType(R[s])},destructorFunction:null})},Ht=A=>({count:A.count,deleteScheduled:A.deleteScheduled,preservePointerOnDelete:A.preservePointerOnDelete,ptr:A.ptr,ptrType:A.ptrType,smartPtr:A.smartPtr,smartPtrType:A.smartPtrType}),XA=A=>{function e(g){return g.$$.ptrType.registeredClass.name}D(e(A)+" instance already deleted")},VA=!1,fe=A=>{},Jt=A=>{A.smartPtr?A.smartPtrType.rawDestructor(A.smartPtr):A.ptrType.registeredClass.rawDestructor(A.ptr)},De=A=>{A.count.value-=1;var e=A.count.value===0;e&&Jt(A)},fA=A=>typeof FinalizationRegistry>"u"?(fA=e=>e,A):(VA=new FinalizationRegistry(e=>{De(e.$$)}),fA=e=>{var g=e.$$,r=!!g.smartPtr;if(r){var s={$$:g};VA.register(e,s,e)}return e},fe=e=>VA.unregister(e),fA(A)),kA=[],xt=()=>{for(;kA.length;){var A=kA.pop();A.$$.deleteScheduled=!1,A.delete()}},we,Pt=()=>{let A=SA.prototype;Object.assign(A,{isAliasOf(g){if(!(this instanceof SA)||!(g instanceof SA))return!1;var r=this.$$.ptrType.registeredClass,s=this.$$.ptr;g.$$=g.$$;for(var B=g.$$.ptrType.registeredClass,a=g.$$.ptr;r.baseClass;)s=r.upcast(s),r=r.baseClass;for(;B.baseClass;)a=B.upcast(a),B=B.baseClass;return r===B&&s===a},clone(){if(this.$$.ptr||XA(this),this.$$.preservePointerOnDelete)return this.$$.count.value+=1,this;var g=fA(Object.create(Object.getPrototypeOf(this),{$$:{value:Ht(this.$$)}}));return g.$$.count.value+=1,g.$$.deleteScheduled=!1,g},delete(){this.$$.ptr||XA(this),this.$$.deleteScheduled&&!this.$$.preservePointerOnDelete&&D("Object already scheduled for deletion"),fe(this),De(this.$$),this.$$.preservePointerOnDelete||(this.$$.smartPtr=void 0,this.$$.ptr=void 0)},isDeleted(){return!this.$$.ptr},deleteLater(){return this.$$.ptr||XA(this),this.$$.deleteScheduled&&!this.$$.preservePointerOnDelete&&D("Object already scheduled for deletion"),kA.push(this),kA.length===1&&we&&we(xt),this.$$.deleteScheduled=!0,this}});let e=Symbol.dispose;e&&(A[e]=A.delete)};function SA(){}var jA=(A,e)=>Object.defineProperty(e,"name",{value:A}),ye={},_t=(A,e,g)=>{if(A[e].overloadTable===void 0){var r=A[e];A[e]=function(...s){return A[e].overloadTable.hasOwnProperty(s.length)||D(`Function '${g}' called with an invalid number of arguments (${s.length}) - expects one of (${A[e].overloadTable})!`),A[e].overloadTable[s.length].apply(this,s)},A[e].overloadTable=[],A[e].overloadTable[r.argCount]=r}},Fe=(A,e,g)=>{i.hasOwnProperty(A)?((g===void 0||i[A].overloadTable!==void 0&&i[A].overloadTable[g]!==void 0)&&D(`Cannot register public name '${A}' twice`),_t(i,A,A),i[A].overloadTable.hasOwnProperty(g)&&D(`Cannot register multiple overloads of a function with the same number of arguments (${g})!`),i[A].overloadTable[g]=e):(i[A]=e,i[A].argCount=g)},Tt=48,Lt=57,Wt=A=>{A=A.replace(/[^a-zA-Z0-9_]/g,"$");var e=A.charCodeAt(0);return e>=Tt&&e<=Lt?`_${A}`:A};function Kt(A,e,g,r,s,B,a,Q){this.name=A,this.constructor=e,this.instancePrototype=g,this.rawDestructor=r,this.baseClass=s,this.getActualType=B,this.upcast=a,this.downcast=Q,this.pureVirtualFunctions=[]}var MA=(A,e,g)=>{for(;e!==g;)e.upcast||D(`Expected null or instance of ${g.name}, got an instance of ${e.name}`),A=e.upcast(A),e=e.baseClass;return A},zA=A=>{if(A===null)return"null";var e=typeof A;return e==="object"||e==="array"||e==="function"?A.toString():""+A};function Zt(A,e){if(e===null)return this.isReference&&D(`null is not a valid ${this.name}`),0;e.$$||D(`Cannot pass "${zA(e)}" as a ${this.name}`),e.$$.ptr||D(`Cannot pass deleted object as a pointer of type ${this.name}`);var g=e.$$.ptrType.registeredClass,r=MA(e.$$.ptr,g,this.registeredClass);return r}function Ot(A,e){var g;if(e===null)return this.isReference&&D(`null is not a valid ${this.name}`),this.isSmartPointer?(g=this.rawConstructor(),A!==null&&A.push(this.rawDestructor,g),g):0;(!e||!e.$$)&&D(`Cannot pass "${zA(e)}" as a ${this.name}`),e.$$.ptr||D(`Cannot pass deleted object as a pointer of type ${this.name}`),!this.isConst&&e.$$.ptrType.isConst&&D(`Cannot convert argument of type ${e.$$.smartPtrType?e.$$.smartPtrType.name:e.$$.ptrType.name} to parameter type ${this.name}`);var r=e.$$.ptrType.registeredClass;if(g=MA(e.$$.ptr,r,this.registeredClass),this.isSmartPointer)switch(e.$$.smartPtr===void 0&&D("Passing raw pointer to smart pointer is illegal"),this.sharingPolicy){case 0:e.$$.smartPtrType===this?g=e.$$.smartPtr:D(`Cannot convert argument of type ${e.$$.smartPtrType?e.$$.smartPtrType.name:e.$$.ptrType.name} to parameter type ${this.name}`);break;case 1:g=e.$$.smartPtr;break;case 2:if(e.$$.smartPtrType===this)g=e.$$.smartPtr;else{var s=e.clone();g=this.rawShare(g,Y.toHandle(()=>s.delete())),A!==null&&A.push(this.rawDestructor,g)}break;default:D("Unsupporting sharing policy")}return g}function Xt(A,e){if(e===null)return this.isReference&&D(`null is not a valid ${this.name}`),0;e.$$||D(`Cannot pass "${zA(e)}" as a ${this.name}`),e.$$.ptr||D(`Cannot pass deleted object as a pointer of type ${this.name}`),e.$$.ptrType.isConst&&D(`Cannot convert argument of type ${e.$$.ptrType.name} to parameter type ${this.name}`);var g=e.$$.ptrType.registeredClass,r=MA(e.$$.ptr,g,this.registeredClass);return r}var pe=(A,e,g)=>{if(e===g)return A;if(g.baseClass===void 0)return null;var r=pe(A,e,g.baseClass);return r===null?null:g.downcast(r)},Vt={},jt=(A,e)=>{for(e===void 0&&D("ptr should not be undefined");A.baseClass;)e=A.upcast(e),A=A.baseClass;return e},zt=(A,e)=>(e=jt(A,e),Vt[e]),bA=(A,e)=>{(!e.ptrType||!e.ptr)&&GA("makeClassHandle requires ptr and ptrType");var g=!!e.smartPtrType,r=!!e.smartPtr;return g!==r&&GA("Both smartPtrType and smartPtr must be specified"),e.count={value:1},fA(Object.create(A,{$$:{value:e,writable:!0}}))};function qt(A){var e=this.getPointee(A);if(!e)return this.destructor(A),null;var g=zt(this.registeredClass,e);if(g!==void 0){if(g.$$.count.value===0)return g.$$.ptr=e,g.$$.smartPtr=A,g.clone();var r=g.clone();return this.destructor(A),r}function s(){return this.isSmartPointer?bA(this.registeredClass.instancePrototype,{ptrType:this.pointeeType,ptr:e,smartPtrType:this,smartPtr:A}):bA(this.registeredClass.instancePrototype,{ptrType:this,ptr:A})}var B=this.registeredClass.getActualType(e),a=ye[B];if(!a)return s.call(this);var Q;this.isConst?Q=a.constPointerType:Q=a.pointerType;var I=pe(e,this.registeredClass,Q.registeredClass);return I===null?s.call(this):this.isSmartPointer?bA(Q.registeredClass.instancePrototype,{ptrType:Q,ptr:I,smartPtrType:this,smartPtr:A}):bA(Q.registeredClass.instancePrototype,{ptrType:Q,ptr:I})}var $t=()=>{Object.assign(DA.prototype,{getPointee(A){return this.rawGetPointee&&(A=this.rawGetPointee(A)),A},destructor(A){this.rawDestructor?.(A)},argPackAdvance:$,readValueFromPointer:uA,fromWireType:qt})};function DA(A,e,g,r,s,B,a,Q,I,E,n){this.name=A,this.registeredClass=e,this.isReference=g,this.isConst=r,this.isSmartPointer=s,this.pointeeType=B,this.sharingPolicy=a,this.rawGetPointee=Q,this.rawConstructor=I,this.rawShare=E,this.rawDestructor=n,!s&&e.baseClass===void 0?r?(this.toWireType=Zt,this.destructorFunction=null):(this.toWireType=Xt,this.destructorFunction=null):this.toWireType=Ot}var me=(A,e,g)=>{i.hasOwnProperty(A)||GA("Replacing nonexistent public symbol"),i[A].overloadTable!==void 0&&g!==void 0?i[A].overloadTable[g]=e:(i[A]=e,i[A].argCount=g)},Ne=[],ve,W=A=>{var e=Ne[A];return e||(Ne[A]=e=ve.get(A)),e},b=(A,e,g=!1)=>{A=k(A);function r(){var B=W(e);return B}var s=r();return typeof s!="function"&&D(`unknown function pointer with signature ${A}: ${e}`),s};class Ag extends Error{}var Re=A=>{var e=We(A),g=k(e);return gA(e),g},wA=(A,e)=>{var g=[],r={};function s(B){if(!r[B]&&!IA[B]){if(UA[B]){UA[B].forEach(s);return}g.push(B),r[B]=!0}}throw e.forEach(s),new Ag(`${A}: `+g.map(Re).join([", "]))},eg=(A,e,g,r,s,B,a,Q,I,E,n,u,y)=>{n=k(n),B=b(s,B),Q&&=b(a,Q),E&&=b(I,E),y=b(u,y);var H=Wt(n);Fe(H,function(){wA(`Cannot construct ${n} due to unbound types`,[r])}),rA([A,e,g],r?[r]:[],T=>{T=T[0];var BA,CA;r?(BA=T.registeredClass,CA=BA.instancePrototype):CA=SA.prototype;var AA=jA(n,function(...ge){if(Object.getPrototypeOf(this)!==iA)throw new dA(`Use 'new' to construct ${n}`);if(x.constructor_body===void 0)throw new dA(`${n} has no accessible constructor`);var et=x.constructor_body[ge.length];if(et===void 0)throw new dA(`Tried to invoke ctor of ${n} with invalid number of parameters (${ge.length}) - expected (${Object.keys(x.constructor_body).toString()}) parameters instead!`);return et.apply(this,ge)}),iA=Object.create(CA,{constructor:{value:AA}});AA.prototype=iA;var x=new Kt(n,AA,iA,y,BA,B,Q,E);x.baseClass&&(x.baseClass.__derivedClasses??=[],x.baseClass.__derivedClasses.push(x));var JA=new DA(n,x,!0,!1,!1),$e=new DA(n+"*",x,!1,!1,!1),At=new DA(n+" const*",x,!1,!0,!1);return ye[A]={pointerType:$e,constPointerType:At},me(H,AA),[JA,$e,At]})},Ye=(A,e)=>{for(var g=[],r=0;r<A;r++)g.push(N[e+r*4>>2]);return g};function Ue(A){for(var e=1;e<A.length;++e)if(A[e]!==null&&A[e].destructorFunction===void 0)return!0;return!1}function tg(A,e,g,r){var s=Ue(A),B=A.length-2,a=[],Q=["fn"];e&&Q.push("thisWired");for(var I=0;I<B;++I)a.push(`arg${I}`),Q.push(`arg${I}Wired`);a=a.join(","),Q=Q.join(",");var E=`return function (${a}) {
1
+ var di=(async function(R={}){var t,i=R,C=!0,o=!1,h=[],D="./this.program",d=(A,e)=>{throw e},p=import.meta.url,y="",l,N;if(C||o){try{y=new URL(".",p).href}catch{}l=async A=>{var e=await fetch(A,{credentials:"same-origin"});if(e.ok)return e.arrayBuffer();throw new Error(e.status+" : "+e.url)}}var J=console.log.bind(console),_=console.error.bind(console),W,X=!1,S,V,z,j,U,v,m,G,QA,F,ae,Qe,Ie,oe,Ce=!1;function Ee(){var A=j.buffer;U=new Int8Array(A),m=new Int16Array(A),v=new Uint8Array(A),G=new Uint16Array(A),QA=new Int32Array(A),F=new Uint32Array(A),ae=new Float32Array(A),Qe=new Float64Array(A),Ie=new BigInt64Array(A),oe=new BigUint64Array(A)}function Qt(){if(i.preRun)for(typeof i.preRun=="function"&&(i.preRun=[i.preRun]);i.preRun.length;)wt(i.preRun.shift());he(le)}function It(){Ce=!0,hA.ca()}function ot(){if(i.postRun)for(typeof i.postRun=="function"&&(i.postRun=[i.postRun]);i.postRun.length;)Dt(i.postRun.shift());he(ce)}var IA=0,lA=null;function Ct(A){IA++,i.monitorRunDependencies?.(IA)}function Et(A){if(IA--,i.monitorRunDependencies?.(IA),IA==0&&lA){var e=lA;lA=null,e()}}function HA(A){i.onAbort?.(A),A="Aborted("+A+")",_(A),X=!0,A+=". Build with -sASSERTIONS for more info.";var e=new WebAssembly.RuntimeError(A);throw z?.(e),e}var WA;function nt(){return pt("AGFzbQEAAAAB8AEeYAF/AGABfwF/YAJ/fwF/YAN/f38Bf2ACf38AYAN/f38AYAAAYAR/f39/AGAGf39/f39/AGAFf39/f38AYAABf2AEf39/fwF/YAp/f39/f39/f39/AGAEf39/fwF8YAV/f39/fwF8YAd/f39/f39/AGAFf39/fn4AYAh/f39/f39/fwBgBn9/f39/fwF8YAt/f39/f39/f39/fwBgAn98AX9gA39/fwF8YAx/f39/f39/f39/f38AYA1/f39/f39/f39/f39/AGADf39+AX9gBX9/f39/AX9gA39/fQBgAn9/AX1gA39+fwF+YAJ/fAACzAI3AWEBYQAKAWEBYgAEAWEBYwAFAWEBZAAMAWEBZQADAWEBZgABAWEBZwACAWEBaAAAAWEBaQAJAWEBagACAWEBawAAAWEBbAAHAWEBbQABAWEBbgAFAWEBbwAFAWEBcAADAWEBcQANAWEBcgALAWEBcwAFAWEBdAAQAWEBdQARAWEBdgAAAWEBdwAGAWEBeAABAWEBeQASAWEBegANAWEBQQAOAWEBQgAGAWEBQwAFAWEBRAATAWEBRQAAAWEBRgAGAWEBRwAUAWEBSAAGAWEBSQABAWEBSgALAWEBSwAAAWEBTAAAAWEBTQAEAWEBTgAHAWEBTwAEAWEBUAAFAWEBUQAKAWEBUgAOAWEBUwAVAWEBVAABAWEBVQACAWEBVgABAWEBVwAAAWEBWAAMAWEBWQAIAWEBWgAIAWEBXwAAAWEBJAAWAWECYWEAFwN8ewQBAAMAGAMAAQAJAQUAAAEAAAgHBgYBAQMPBQAPBAIFARkEBgEABgELBhoBGwAGAQAAAgkJCAMDAAACHAEDAQIAAAECAAABAgICAgIGAAUDBAIKBAQEBAQEAgQFAgUCAAEAAgoBAQAEAAAdAAoBAQEDCAgJCQMHBwcABgQFAXABb28FBwEBggKAgAIGCAF/AUHAyQQLB1QPAmJhAgACY2EAsQECZGEAdQJlYQA/AmZhADkCZ2EBAAJoYQChAQJpYQCeAQJqYQCdAQJrYQCwAQJsYQCjAQJtYQBwAm5hAG8Cb2EApwECcGEApgEJngEBAEEBC25lnAFkmwGaAZkBmAGXAZYBlQGUAZMBkgFjYZEBkAGPAY4BjQGMAYsBigGJAWQ4MWNhMIgBhwGGAYUBJAmEARsWNA8Q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EFELCzEAIAAgASgCCEEAEDoEQCABIAIgAxBRDwsgACgCCCIAIAEgAiADIAAoAgAoAhwRBwALBgAgACQAC38AQaw6QQE2AgBBsDpBADYCABBlQbA6Qcw6KAIANgIAQcw6Qaw6NgIAQdA6QTs2AgBB1DpBADYCABBaQdQ6Qcw6KAIANgIAQcw6QdA6NgIAQZQ7QYDAADYCAEGMO0HAyQQ2AgBB8DpBKjYCAEG4O0H8OzYCAEGQO0GAgAQ2AgALC4ArFQBBgAgLsR5mYWlsZWQgdG8gYWxsb2NhdGUgbWVtb3J5AFVpbnQ4QXJyYXkAY29sb3JNYXgAc2hNYXgAc2NhbGVNYXgALSsgICAwWDB4AG1pc21hdGNoZWQgdmVyc2lvbiEgZXhwZWN0ZWQgMS4xLngAdW5zaWduZWQgc2hvcnQAdW5zaWduZWQgaW50AHNldABmbG9hdABpbnZhbGlkIGNvbG9yIG5vcm1hbGl6YXRpb24gY29lZmZpY2llbnRzAGludmFsaWQgc2ggbm9ybWFsaXphdGlvbiBjb2VmZmljaWVudHMAaW52YWxpZCBzY2FsZSBub3JtYWxpemF0aW9uIGNvZWZmaWNpZW50cwBzdWNjZXNzAGNvbG9ycwByb3RhdGlvbnMAZmlsZSBjb250YWlucyAwIGdhdXNzaWFucwBHYXVzc2lhbnMAbWVhbnMAc2hzAHNjYWxlcwB2ZWxvY2l0aWVzAG9wYWNpdGllcwB2ZWN0b3IAYXR0ZW1wdGluZyB0byByZWFkIHBhc3QgZW5kIG9mIGJ1ZmZlcgB1bnNpZ25lZCBjaGFyAHN0ZDo6ZXhjZXB0aW9uAGR1cmF0aW9uAGNvbG9yTWluAHNoTWluAHNjYWxlTWluAGJvb2wAbGVuZ3RoAHVuc2lnbmVkIGxvbmcgbG9uZwB1bnNpZ25lZCBsb25nAHN0ZDo6d3N0cmluZwBiYXNpY19zdHJpbmcAc3RkOjpzdHJpbmcAc3RkOjp1MTZzdHJpbmcAc3RkOjp1MzJzdHJpbmcAZ2F1c3NpYW4gY291bnQgbXVzdCBiZSBwb3NpdGl2ZQBjb21iaW5lAGZhaWxlZCB0byByZWFkIGZyb20gZmlsZQBkb3VibGUAb3V0IG9mIGJvdW5kcyBzaCBkZWdyZWUAY2Fubm90IGNvbWJpbmUgZ2F1c3NpYW5zIHdpdGggZGlmZmVyZW50IHNoRGVncmVlAGRlY29kZQBtaXNtYXRjaGVkIG1hZ2ljIHdvcmQAdm9pZABzdGQ6OmJhZF9hbGxvYwBkeW5hbWljAGRnc19lcnJvci5jAGRnc19kZWNvZGUuYwBuZWdhdGl2ZSBkdXJhdGlvbiBlbmNvdW50ZXJlZCBpbiBtZXRhZGF0YQBNZXRhZGF0YQBnYXVzc2lhbiBzcGhlcmljYWwgaGFybW9taWMgZGVncmVlIG11c3QgYmUgbGVzcyB0aGFuIERHU19HQVVTU0lBTlNfTUFYX1NIX0RFR1JFRQBlbXNjcmlwdGVuOjptZW1vcnlfdmlldzxzaG9ydD4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8dW5zaWduZWQgc2hvcnQ+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PGludD4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8dW5zaWduZWQgaW50PgBlbXNjcmlwdGVuOjptZW1vcnlfdmlldzxmbG9hdD4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8dWludDhfdD4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8aW50OF90PgBlbXNjcmlwdGVuOjptZW1vcnlfdmlldzx1aW50MTZfdD4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8aW50MTZfdD4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8dWludDY0X3Q+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PGludDY0X3Q+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PHVpbnQzMl90PgBlbXNjcmlwdGVuOjptZW1vcnlfdmlldzxpbnQzMl90PgBlbXNjcmlwdGVuOjptZW1vcnlfdmlldzxjaGFyPgBlbXNjcmlwdGVuOjptZW1vcnlfdmlldzx1bnNpZ25lZCBjaGFyPgBlbXNjcmlwdGVuOjptZW1vcnlfdmlldzxzaWduZWQgY2hhcj4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8bG9uZz4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8dW5zaWduZWQgbG9uZz4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8ZG91YmxlPgBpbnZhbGlkIGlucHV0IChwcm92aWRlZCBtZW1vcnkvZmlsZSBpbnB1dCB3YXMgaW4gYW4gaW52YWxpZCBmb3JtYXQpAChudWxsKQBpbnZhbGlkIGFyZ3VtZW50cyAoYmFkIGZ1bmN0aW9uIGNhbGwpAGZhaWxlZCB0byB3cml0ZSB0byBhIGZpbGUgKGZ3cml0ZSB3cm90ZSBmZXdlciBieXRlcyB0aGFuIHJlcXVlc3RlZCkAZmFpbGVkIHRvIHJlYWQgZnJvbSBhIGZpbGUgKGZyZWFkIHJlYWQgZmV3ZXIgYnl0ZXMgdGhhbiByZXF1ZXN0ZWQpAGZhaWxlZCB0byBvcGVuIGEgZmlsZSAoZm9wZW4gcmV0dXJuZWQgTlVMTCkAb3V0IG9mIG1lbW9yeSAoREdTX01BTExPQy9ER1NfUkVBTExPQyByZXR1cm5lZCBOVUxMKQBmYWlsZWQgdG8gY2xvc2UgYSBmaWxlIChmY2xvc2UgcmV0dXJuZWQgRU9GKQBER1MgaW50ZXJuYWwgZXJyb3I6ICIAREdTIEVSUk9SOiAiJXMiIGluICVzIGF0IGxpbmUgJWkKAERHUyBXQVJOSU5HOiAiJXMiIGluICVzIGF0IGxpbmUgJWkKAAlpbiAlcyBhdCBsaW5lICVpCgAAAAAAGQAAMAwAADEyREdTZ2F1c3NpYW5zAAAEGAAAUAwAAAAAAAAoDAAAUDEyREdTZ2F1c3NpYW5zAAQYAABwDAAAAQAAACgMAABQSzEyREdTZ2F1c3NpYW5zAHBwAHYAdnAAAAAAAAAAAKgMAAA9AAAAPgAAAD8AAABAAAAAQQAAADgZAAC0DAAA9BQAAE5TdDNfXzIyMF9fc2hhcmVkX3B0cl9wb2ludGVySVAxMkRHU2dhdXNzaWFuc04xMGVtc2NyaXB0ZW4xNXNtYXJ0X3B0cl90cmFpdElOU18xMHNoYXJlZF9wdHJJUzFfRUVFMTF2YWxfZGVsZXRlckVOU185YWxsb2NhdG9ySVMxX0VFRUUATjEwZW1zY3JpcHRlbjE1c21hcnRfcHRyX3RyYWl0SU5TdDNfXzIxMHNoYXJlZF9wdHJJMTJER1NnYXVzc2lhbnNFRUUxMXZhbF9kZWxldGVyRQAAAACADwAAABkAAJwNAABOU3QzX18yMTBzaGFyZWRfcHRySTEyREdTZ2F1c3NpYW5zRUUAcABwcHAAAJQNAAAAAAAA6A0AAEIAAABDAAAARAAAAEUAAABGAAAAOBkAAPQNAAD0FAAATlN0M19fMjIwX19zaGFyZWRfcHRyX2VtcGxhY2VJMTJER1NnYXVzc2lhbnNOU185YWxsb2NhdG9ySVMxX0VFRUUAaXBwAHZwcGkAZnBwAHZwcGYAABkAAFAOAAAxMURHU21ldGFkYXRhAAAAgA8AAIAPAACsFgAAgA8AAAAAAACMDgAARwAAAEgAAABJAAAASgAAAEsAAAA4GQAAmA4AAPQUAABOU3QzX18yMjBfX3NoYXJlZF9wdHJfcG9pbnRlcklQMTJER1NnYXVzc2lhbnNaWkwyMWVtYmluZF9pbml0X2xpYmRnc19qc3ZFTkszJF84Y2xFUktOMTBlbXNjcmlwdGVuM3ZhbEVFVWxTMl9FX05TXzlhbGxvY2F0b3JJUzFfRUVFRQBaWkwyMWVtYmluZF9pbml0X2xpYmRnc19qc3ZFTkszJF84Y2xFUktOMTBlbXNjcmlwdGVuM3ZhbEVFVWxQMTJER1NnYXVzc2lhbnNFXwAAAJQNAACUDQAAlA0AAHBwcHAAAAAAABkAAIgPAABOMTBlbXNjcmlwdGVuM3ZhbEUAAAAZAACkDwAATlN0M19fMjEyYmFzaWNfc3RyaW5nSWNOU18xMWNoYXJfdHJhaXRzSWNFRU5TXzlhbGxvY2F0b3JJY0VFRUUAAAAZAADsDwAATlN0M19fMjEyYmFzaWNfc3RyaW5nSXdOU18xMWNoYXJfdHJhaXRzSXdFRU5TXzlhbGxvY2F0b3JJd0VFRUUAAAAZAAA0EAAATlN0M19fMjEyYmFzaWNfc3RyaW5nSURzTlNfMTFjaGFyX3RyYWl0c0lEc0VFTlNfOWFsbG9jYXRvcklEc0VFRUUAAAAAGQAAgBAAAE5TdDNfXzIxMmJhc2ljX3N0cmluZ0lEaU5TXzExY2hhcl90cmFpdHNJRGlFRU5TXzlhbGxvY2F0b3JJRGlFRUVFAAAAABkAAMwQAABOMTBlbXNjcmlwdGVuMTFtZW1vcnlfdmlld0ljRUUAAAAZAAD0EAAATjEwZW1zY3JpcHRlbjExbWVtb3J5X3ZpZXdJYUVFAAAAGQAAHBEAAE4xMGVtc2NyaXB0ZW4xMW1lbW9yeV92aWV3SWhFRQAAABkAAEQRAABOMTBl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")}function ht(A){if(ArrayBuffer.isView(A))return A;if(A==WA&&W)return new Uint8Array(W);if(N)return N(A);throw"both async and sync fetching of the wasm failed"}async function ct(A){return ht(A)}async function lt(A,e){try{var g=await ct(A),r=await WebAssembly.instantiate(g,e);return r}catch(s){_(`failed to asynchronously prepare wasm: ${s}`),HA(s)}}async function ut(A,e,g){return lt(e,g)}function dt(){return{a:ri}}async function ft(){function A(B,Q){return hA=B.exports,j=hA.ba,Ee(),Ne=hA.ga,ii(hA),Et("wasm-instantiate"),hA}Ct("wasm-instantiate");function e(B){return A(B.instance)}var g=dt();if(i.instantiateWasm)return new Promise((B,Q)=>{i.instantiateWasm(g,(a,I)=>{B(A(a,I))})});WA??=nt();var r=await ut(W,WA,g),s=e(r);return s}class ne{name="ExitStatus";constructor(e){this.message=`Program terminated with exit(${e})`,this.status=e}}var he=A=>{for(;A.length>0;)A.shift()(i)},ce=[],Dt=A=>ce.push(A),le=[],wt=A=>le.push(A),pt=A=>{for(var e,g,r=0,s=0,B=A.length,Q=new Uint8Array((B*3>>2)-(A[B-2]=="=")-(A[B-1]=="="));r<B;r+=4,s+=3)e=gA[A.charCodeAt(r+1)],g=gA[A.charCodeAt(r+2)],Q[s]=gA[A.charCodeAt(r)]<<2|e>>4,Q[s+1]=e<<4|g>>2,Q[s+2]=g<<6|gA[A.charCodeAt(r+3)];return Q},ZA=!0,K=A=>Oe(A),O=()=>Xe(),FA=[],KA=0,yt=A=>{var e=new OA(A);return e.get_caught()||(e.set_caught(!0),KA--),e.set_rethrown(!1),FA.push(e),Ve(A),qe(A)},tA=0,Gt=()=>{L(0,0);var A=FA.pop();ze(A.excPtr),tA=0};class OA{constructor(e){this.excPtr=e,this.ptr=e-24}set_type(e){F[this.ptr+4>>2]=e}get_type(){return F[this.ptr+4>>2]}set_destructor(e){F[this.ptr+8>>2]=e}get_destructor(){return F[this.ptr+8>>2]}set_caught(e){e=e?1:0,U[this.ptr+12]=e}get_caught(){return U[this.ptr+12]!=0}set_rethrown(e){e=e?1:0,U[this.ptr+13]=e}get_rethrown(){return U[this.ptr+13]!=0}init(e,g){this.set_adjusted_ptr(0),this.set_type(e),this.set_destructor(g)}set_adjusted_ptr(e){F[this.ptr+16>>2]=e}get_adjusted_ptr(){return F[this.ptr+16>>2]}}var NA=A=>Ke(A),ue=A=>{var e=tA;if(!e)return NA(0),0;var g=new OA(e);g.set_adjusted_ptr(e);var r=g.get_type();if(!r)return NA(0),e;for(var s of A){if(s===0||s===r)break;var B=g.ptr+16;if(je(s,r,B))return NA(s),e}return NA(r),e},mt=()=>ue([]),Ft=A=>ue([A]),Nt=()=>{var A=FA.pop();A||HA("no exception to throw");var e=A.excPtr;throw A.get_rethrown()||(FA.push(A),A.set_rethrown(!0),A.set_caught(!1),KA++),tA=e,tA},vt=(A,e,g)=>{var r=new OA(A);throw r.init(e,g),tA=A,KA++,tA},kt=A=>{throw tA||(tA=A),tA},Rt=()=>HA(""),vA={},kA=A=>{for(;A.length;){var e=A.pop(),g=A.pop();g(e)}};function uA(A){return this.fromWireType(F[A>>2])}var nA={},oA={},RA={},Yt=class extends Error{constructor(e){super(e),this.name="InternalError"}},YA=A=>{throw new Yt(A)},sA=(A,e,g)=>{A.forEach(a=>RA[a]=e);function r(a){var I=g(a);I.length!==A.length&&YA("Mismatched type converter count");for(var E=0;E<A.length;++E)q(A[E],I[E])}var s=new Array(e.length),B=[],Q=0;e.forEach((a,I)=>{oA.hasOwnProperty(a)?s[I]=oA[a]:(B.push(a),nA.hasOwnProperty(a)||(nA[a]=[]),nA[a].push(()=>{s[I]=oA[a],++Q,Q===B.length&&r(s)}))}),B.length===0&&r(s)},Mt=A=>{var e=vA[A];delete vA[A];var g=e.rawConstructor,r=e.rawDestructor,s=e.fields,B=s.map(Q=>Q.getterReturnType).concat(s.map(Q=>Q.setterArgumentType));sA([A],B,Q=>{var a={};return s.forEach((I,E)=>{var n=I.fieldName,u=Q[E],w=Q[E].optional,x=I.getter,P=I.getterContext,aA=Q[E+s.length],EA=I.setter,AA=I.setterContext;a[n]={read:rA=>u.fromWireType(x(P,rA)),write:(rA,T)=>{var JA=[];EA(AA,rA,aA.toWireType(JA,T)),kA(JA)},optional:w}}),[{name:e.name,fromWireType:I=>{var E={};for(var n in a)E[n]=a[n].read(I);return r(I),E},toWireType:(I,E)=>{for(var n in a)if(!(n in E)&&!a[n].optional)throw new TypeError(`Missing field: "${n}"`);var u=g();for(n in a)a[n].write(u,E[n]);return I!==null&&I.push(r,u),u},argPackAdvance:$,readValueFromPointer:uA,destructorFunction:r}]})},M=A=>{for(var e="";;){var g=v[A++];if(!g)return e;e+=String.fromCharCode(g)}},dA=class extends Error{constructor(e){super(e),this.name="BindingError"}},f=A=>{throw new dA(A)};function St(A,e,g={}){var r=e.name;if(A||f(`type "${r}" must have a positive integer typeid pointer`),oA.hasOwnProperty(A)){if(g.ignoreDuplicateRegistrations)return;f(`Cannot register type '${r}' twice`)}if(oA[A]=e,delete RA[A],nA.hasOwnProperty(A)){var s=nA[A];delete nA[A],s.forEach(B=>B())}}function q(A,e,g={}){return St(A,e,g)}var de=(A,e,g)=>{switch(e){case 1:return g?r=>U[r]:r=>v[r];case 2:return g?r=>m[r>>1]:r=>G[r>>1];case 4:return g?r=>QA[r>>2]:r=>F[r>>2];case 8:return g?r=>Ie[r>>3]:r=>oe[r>>3];default:throw new TypeError(`invalid integer width (${e}): ${A}`)}},Ut=(A,e,g,r,s)=>{e=M(e);let B=r===0n,Q=a=>a;if(B){let a=g*8;Q=I=>BigInt.asUintN(a,I),s=Q(s)}q(A,{name:e,fromWireType:Q,toWireType:(a,I)=>(typeof I=="number"&&(I=BigInt(I)),I),argPackAdvance:$,readValueFromPointer:de(e,g,!B),destructorFunction:null})},$=8,bt=(A,e,g,r)=>{e=M(e),q(A,{name:e,fromWireType:function(s){return!!s},toWireType:function(s,B){return B?g:r},argPackAdvance:$,readValueFromPointer:function(s){return this.fromWireType(v[s])},destructorFunction:null})},xt=A=>({count:A.count,deleteScheduled:A.deleteScheduled,preservePointerOnDelete:A.preservePointerOnDelete,ptr:A.ptr,ptrType:A.ptrType,smartPtr:A.smartPtr,smartPtrType:A.smartPtrType}),XA=A=>{function e(g){return g.$$.ptrType.registeredClass.name}f(e(A)+" instance already deleted")},VA=!1,fe=A=>{},Jt=A=>{A.smartPtr?A.smartPtrType.rawDestructor(A.smartPtr):A.ptrType.registeredClass.rawDestructor(A.ptr)},De=A=>{A.count.value-=1;var e=A.count.value===0;e&&Jt(A)},fA=A=>typeof FinalizationRegistry>"u"?(fA=e=>e,A):(VA=new FinalizationRegistry(e=>{De(e.$$)}),fA=e=>{var g=e.$$,r=!!g.smartPtr;if(r){var s={$$:g};VA.register(e,s,e)}return e},fe=e=>VA.unregister(e),fA(A)),MA=[],Tt=()=>{for(;MA.length;){var A=MA.pop();A.$$.deleteScheduled=!1,A.delete()}},we,_t=()=>{let A=SA.prototype;Object.assign(A,{isAliasOf(g){if(!(this instanceof SA)||!(g instanceof SA))return!1;var r=this.$$.ptrType.registeredClass,s=this.$$.ptr;g.$$=g.$$;for(var B=g.$$.ptrType.registeredClass,Q=g.$$.ptr;r.baseClass;)s=r.upcast(s),r=r.baseClass;for(;B.baseClass;)Q=B.upcast(Q),B=B.baseClass;return r===B&&s===Q},clone(){if(this.$$.ptr||XA(this),this.$$.preservePointerOnDelete)return this.$$.count.value+=1,this;var g=fA(Object.create(Object.getPrototypeOf(this),{$$:{value:xt(this.$$)}}));return g.$$.count.value+=1,g.$$.deleteScheduled=!1,g},delete(){this.$$.ptr||XA(this),this.$$.deleteScheduled&&!this.$$.preservePointerOnDelete&&f("Object already scheduled for deletion"),fe(this),De(this.$$),this.$$.preservePointerOnDelete||(this.$$.smartPtr=void 0,this.$$.ptr=void 0)},isDeleted(){return!this.$$.ptr},deleteLater(){return this.$$.ptr||XA(this),this.$$.deleteScheduled&&!this.$$.preservePointerOnDelete&&f("Object already scheduled for deletion"),MA.push(this),MA.length===1&&we&&we(Tt),this.$$.deleteScheduled=!0,this}});let e=Symbol.dispose;e&&(A[e]=A.delete)};function SA(){}var zA=(A,e)=>Object.defineProperty(e,"name",{value:A}),pe={},Lt=(A,e,g)=>{if(A[e].overloadTable===void 0){var r=A[e];A[e]=function(...s){return A[e].overloadTable.hasOwnProperty(s.length)||f(`Function '${g}' called with an invalid number of arguments (${s.length}) - expects one of (${A[e].overloadTable})!`),A[e].overloadTable[s.length].apply(this,s)},A[e].overloadTable=[],A[e].overloadTable[r.argCount]=r}},ye=(A,e,g)=>{i.hasOwnProperty(A)?((g===void 0||i[A].overloadTable!==void 0&&i[A].overloadTable[g]!==void 0)&&f(`Cannot register public name '${A}' twice`),Lt(i,A,A),i[A].overloadTable.hasOwnProperty(g)&&f(`Cannot register multiple overloads of a function with the same number of arguments (${g})!`),i[A].overloadTable[g]=e):(i[A]=e,i[A].argCount=g)},Pt=48,Ht=57,Wt=A=>{A=A.replace(/[^a-zA-Z0-9_]/g,"$");var e=A.charCodeAt(0);return e>=Pt&&e<=Ht?`_${A}`:A};function Zt(A,e,g,r,s,B,Q,a){this.name=A,this.constructor=e,this.instancePrototype=g,this.rawDestructor=r,this.baseClass=s,this.getActualType=B,this.upcast=Q,this.downcast=a,this.pureVirtualFunctions=[]}var UA=(A,e,g)=>{for(;e!==g;)e.upcast||f(`Expected null or instance of ${g.name}, got an instance of ${e.name}`),A=e.upcast(A),e=e.baseClass;return A},jA=A=>{if(A===null)return"null";var e=typeof A;return e==="object"||e==="array"||e==="function"?A.toString():""+A};function Kt(A,e){if(e===null)return this.isReference&&f(`null is not a valid ${this.name}`),0;e.$$||f(`Cannot pass "${jA(e)}" as a ${this.name}`),e.$$.ptr||f(`Cannot pass deleted object as a pointer of type ${this.name}`);var g=e.$$.ptrType.registeredClass,r=UA(e.$$.ptr,g,this.registeredClass);return r}function Ot(A,e){var g;if(e===null)return this.isReference&&f(`null is not a valid ${this.name}`),this.isSmartPointer?(g=this.rawConstructor(),A!==null&&A.push(this.rawDestructor,g),g):0;(!e||!e.$$)&&f(`Cannot pass "${jA(e)}" as a ${this.name}`),e.$$.ptr||f(`Cannot pass deleted object as a pointer of type ${this.name}`),!this.isConst&&e.$$.ptrType.isConst&&f(`Cannot convert argument of type ${e.$$.smartPtrType?e.$$.smartPtrType.name:e.$$.ptrType.name} to parameter type ${this.name}`);var r=e.$$.ptrType.registeredClass;if(g=UA(e.$$.ptr,r,this.registeredClass),this.isSmartPointer)switch(e.$$.smartPtr===void 0&&f("Passing raw pointer to smart pointer is illegal"),this.sharingPolicy){case 0:e.$$.smartPtrType===this?g=e.$$.smartPtr:f(`Cannot convert argument of type ${e.$$.smartPtrType?e.$$.smartPtrType.name:e.$$.ptrType.name} to parameter type ${this.name}`);break;case 1:g=e.$$.smartPtr;break;case 2:if(e.$$.smartPtrType===this)g=e.$$.smartPtr;else{var s=e.clone();g=this.rawShare(g,k.toHandle(()=>s.delete())),A!==null&&A.push(this.rawDestructor,g)}break;default:f("Unsupporting sharing policy")}return g}function Xt(A,e){if(e===null)return this.isReference&&f(`null is not a valid ${this.name}`),0;e.$$||f(`Cannot pass "${jA(e)}" as a ${this.name}`),e.$$.ptr||f(`Cannot pass deleted object as a pointer of type ${this.name}`),e.$$.ptrType.isConst&&f(`Cannot convert argument of type ${e.$$.ptrType.name} to parameter type ${this.name}`);var g=e.$$.ptrType.registeredClass,r=UA(e.$$.ptr,g,this.registeredClass);return r}var Ge=(A,e,g)=>{if(e===g)return A;if(g.baseClass===void 0)return null;var r=Ge(A,e,g.baseClass);return r===null?null:g.downcast(r)},Vt={},zt=(A,e)=>{for(e===void 0&&f("ptr should not be undefined");A.baseClass;)e=A.upcast(e),A=A.baseClass;return e},jt=(A,e)=>(e=zt(A,e),Vt[e]),bA=(A,e)=>{(!e.ptrType||!e.ptr)&&YA("makeClassHandle requires ptr and ptrType");var g=!!e.smartPtrType,r=!!e.smartPtr;return g!==r&&YA("Both smartPtrType and smartPtr must be specified"),e.count={value:1},fA(Object.create(A,{$$:{value:e,writable:!0}}))};function qt(A){var e=this.getPointee(A);if(!e)return this.destructor(A),null;var g=jt(this.registeredClass,e);if(g!==void 0){if(g.$$.count.value===0)return g.$$.ptr=e,g.$$.smartPtr=A,g.clone();var r=g.clone();return this.destructor(A),r}function s(){return this.isSmartPointer?bA(this.registeredClass.instancePrototype,{ptrType:this.pointeeType,ptr:e,smartPtrType:this,smartPtr:A}):bA(this.registeredClass.instancePrototype,{ptrType:this,ptr:A})}var B=this.registeredClass.getActualType(e),Q=pe[B];if(!Q)return s.call(this);var a;this.isConst?a=Q.constPointerType:a=Q.pointerType;var I=Ge(e,this.registeredClass,a.registeredClass);return I===null?s.call(this):this.isSmartPointer?bA(a.registeredClass.instancePrototype,{ptrType:a,ptr:I,smartPtrType:this,smartPtr:A}):bA(a.registeredClass.instancePrototype,{ptrType:a,ptr:I})}var $t=()=>{Object.assign(DA.prototype,{getPointee(A){return this.rawGetPointee&&(A=this.rawGetPointee(A)),A},destructor(A){this.rawDestructor?.(A)},argPackAdvance:$,readValueFromPointer:uA,fromWireType:qt})};function DA(A,e,g,r,s,B,Q,a,I,E,n){this.name=A,this.registeredClass=e,this.isReference=g,this.isConst=r,this.isSmartPointer=s,this.pointeeType=B,this.sharingPolicy=Q,this.rawGetPointee=a,this.rawConstructor=I,this.rawShare=E,this.rawDestructor=n,!s&&e.baseClass===void 0?r?(this.toWireType=Kt,this.destructorFunction=null):(this.toWireType=Xt,this.destructorFunction=null):this.toWireType=Ot}var me=(A,e,g)=>{i.hasOwnProperty(A)||YA("Replacing nonexistent public symbol"),i[A].overloadTable!==void 0&&g!==void 0?i[A].overloadTable[g]=e:(i[A]=e,i[A].argCount=g)},Fe=[],Ne,Z=A=>{var e=Fe[A];return e||(Fe[A]=e=Ne.get(A)),e},b=(A,e,g=!1)=>{A=M(A);function r(){var B=Z(e);return B}var s=r();return typeof s!="function"&&f(`unknown function pointer with signature ${A}: ${e}`),s};class Ag extends Error{}var ve=A=>{var e=We(A),g=M(e);return iA(e),g},wA=(A,e)=>{var g=[],r={};function s(B){if(!r[B]&&!oA[B]){if(RA[B]){RA[B].forEach(s);return}g.push(B),r[B]=!0}}throw e.forEach(s),new Ag(`${A}: `+g.map(ve).join([", "]))},eg=(A,e,g,r,s,B,Q,a,I,E,n,u,w)=>{n=M(n),B=b(s,B),a&&=b(Q,a),E&&=b(I,E),w=b(u,w);var x=Wt(n);ye(x,function(){wA(`Cannot construct ${n} due to unbound types`,[r])}),sA([A,e,g],r?[r]:[],P=>{P=P[0];var aA,EA;r?(aA=P.registeredClass,EA=aA.instancePrototype):EA=SA.prototype;var AA=zA(n,function(...ge){if(Object.getPrototypeOf(this)!==rA)throw new dA(`Use 'new' to construct ${n}`);if(T.constructor_body===void 0)throw new dA(`${n} has no accessible constructor`);var et=T.constructor_body[ge.length];if(et===void 0)throw new dA(`Tried to invoke ctor of ${n} with invalid number of parameters (${ge.length}) - expected (${Object.keys(T.constructor_body).toString()}) parameters instead!`);return et.apply(this,ge)}),rA=Object.create(EA,{constructor:{value:AA}});AA.prototype=rA;var T=new Zt(n,AA,rA,w,aA,B,a,E);T.baseClass&&(T.baseClass.__derivedClasses??=[],T.baseClass.__derivedClasses.push(T));var JA=new DA(n,T,!0,!1,!1),$e=new DA(n+"*",T,!1,!1,!1),At=new DA(n+" const*",T,!1,!0,!1);return pe[A]={pointerType:$e,constPointerType:At},me(x,AA),[JA,$e,At]})},ke=(A,e)=>{for(var g=[],r=0;r<A;r++)g.push(F[e+r*4>>2]);return g};function Re(A){for(var e=1;e<A.length;++e)if(A[e]!==null&&A[e].destructorFunction===void 0)return!0;return!1}function tg(A,e,g,r){var s=Re(A),B=A.length-2,Q=[],a=["fn"];e&&a.push("thisWired");for(var I=0;I<B;++I)Q.push(`arg${I}`),a.push(`arg${I}Wired`);Q=Q.join(","),a=a.join(",");var E=`return function (${Q}) {
2
2
  `;s&&(E+=`var destructors = [];
3
3
  `);var n=s?"destructors":"null",u=["humanName","throwBindingError","invoker","fn","runDestructors","retType","classParam"];e&&(E+=`var thisWired = classParam['toWireType'](${n}, this);
4
4
  `);for(var I=0;I<B;++I)E+=`var arg${I}Wired = argType${I}['toWireType'](${n}, arg${I});
5
- `,u.push(`argType${I}`);if(E+=(g||r?"var rv = ":"")+`invoker(${Q});
5
+ `,u.push(`argType${I}`);if(E+=(g||r?"var rv = ":"")+`invoker(${a});
6
6
  `,s)E+=`runDestructors(destructors);
7
- `;else for(var I=e?1:2;I<A.length;++I){var y=I===1?"thisWired":"arg"+(I-2)+"Wired";A[I].destructorFunction!==null&&(E+=`${y}_dtor(${y});
8
- `,u.push(`${y}_dtor`))}return g&&(E+=`var ret = retType['fromWireType'](rv);
7
+ `;else for(var I=e?1:2;I<A.length;++I){var w=I===1?"thisWired":"arg"+(I-2)+"Wired";A[I].destructorFunction!==null&&(E+=`${w}_dtor(${w});
8
+ `,u.push(`${w}_dtor`))}return g&&(E+=`var ret = retType['fromWireType'](rv);
9
9
  return ret;
10
10
  `),E+=`}
11
- `,[u,E]}function Ge(A,e,g,r,s,B){var a=e.length;a<2&&D("argTypes array size mismatch! Must at least get return value and 'this' types!");for(var Q=e[1]!==null&&g!==null,I=Ue(e),E=e[0].name!=="void",n=[A,D,r,s,YA,e[0],e[1]],u=0;u<a-2;++u)n.push(e[u+2]);if(!I)for(var u=Q?1:2;u<e.length;++u)e[u].destructorFunction!==null&&n.push(e[u].destructorFunction);let[y,H]=tg(e,Q,E,B);var T=new Function(...y,H)(...n);return jA(A,T)}for(var gg=(A,e,g,r,s,B)=>{var a=Ye(e,g);s=b(r,s),rA([],[A],Q=>{Q=Q[0];var I=`constructor ${Q.name}`;if(Q.registeredClass.constructor_body===void 0&&(Q.registeredClass.constructor_body=[]),Q.registeredClass.constructor_body[e-1]!==void 0)throw new dA(`Cannot register multiple constructors with identical number of parameters (${e-1}) for class '${Q.name}'! Overload resolution is currently only performed using the parameter count, not actual type info!`);return Q.registeredClass.constructor_body[e-1]=()=>{wA(`Cannot construct ${Q.name} due to unbound types`,a)},rA([],a,E=>(E.splice(1,0,null),Q.registeredClass.constructor_body[e-1]=Ge(I,E,null,s,B),[])),[]})},ke=(A,e,g)=>(A instanceof Object||D(`${g} with invalid "this": ${A}`),A instanceof e.registeredClass.constructor||D(`${g} incompatible with "this" of type ${A.constructor.name}`),A.$$.ptr||D(`cannot call emscripten binding method ${g} on deleted object`),MA(A.$$.ptr,A.$$.ptrType.registeredClass,e.registeredClass)),ig=(A,e,g,r,s,B,a,Q,I,E)=>{e=k(e),s=b(r,s),rA([],[A],n=>{n=n[0];var u=`${n.name}.${e}`,y={get(){wA(`Cannot access ${u} due to unbound types`,[g,a])},enumerable:!0,configurable:!0};return I?y.set=()=>wA(`Cannot access ${u} due to unbound types`,[g,a]):y.set=H=>D(u+" is a read-only property"),Object.defineProperty(n.registeredClass.instancePrototype,e,y),rA([],I?[g,a]:[g],H=>{var T=H[0],BA={get(){var AA=ke(this,n,u+" getter");return T.fromWireType(s(B,AA))},enumerable:!0};if(I){I=b(Q,I);var CA=H[1];BA.set=function(AA){var iA=ke(this,n,u+" setter"),x=[];I(E,iA,CA.toWireType(x,AA)),YA(x)}}return Object.defineProperty(n.registeredClass.instancePrototype,e,BA),[]}),[]})},Se=[],oA=[0,1,,1,null,1,!0,1,!1,1],qA=A=>{A>9&&--oA[A+1]===0&&(oA[A]=void 0,Se.push(A))},Y={toValue:A=>(A||D(`Cannot use deleted val. handle = ${A}`),oA[A]),toHandle:A=>{switch(A){case void 0:return 2;case null:return 4;case!0:return 6;case!1:return 8;default:{let e=Se.pop()||oA.length;return oA[e]=A,oA[e+1]=1,e}}}},rg={name:"emscripten::val",fromWireType:A=>{var e=Y.toValue(A);return qA(A),e},toWireType:(A,e)=>Y.toHandle(e),argPackAdvance:$,readValueFromPointer:uA,destructorFunction:null},sg=A=>q(A,rg),Bg=(A,e)=>{switch(e){case 4:return function(g){return this.fromWireType(Qe[g>>2])};case 8:return function(g){return this.fromWireType(ae[g>>3])};default:throw new TypeError(`invalid float width (${e}): ${A}`)}},Qg=(A,e,g)=>{e=k(e),q(A,{name:e,fromWireType:r=>r,toWireType:(r,s)=>s,argPackAdvance:$,readValueFromPointer:Bg(e,g),destructorFunction:null})},ag=A=>{A=A.trim();let e=A.indexOf("(");return e===-1?A:A.slice(0,e)},Ig=(A,e,g,r,s,B,a,Q)=>{var I=Ye(e,g);A=k(A),A=ag(A),s=b(r,s,a),Fe(A,function(){wA(`Cannot call ${A} due to unbound types`,I)},e-1),rA([],I,E=>{var n=[E[0],null].concat(E.slice(1));return me(A,Ge(A,n,null,s,B,a),e-1),[]})},og=(A,e,g,r,s)=>{e=k(e);let B=r===0,a=I=>I;if(B){var Q=32-8*g;a=I=>I<<Q>>>Q,s=a(s)}q(A,{name:e,fromWireType:a,toWireType:(I,E)=>E,argPackAdvance:$,readValueFromPointer:de(e,g,r!==0),destructorFunction:null})},Cg=(A,e,g)=>{var r=[Int8Array,Uint8Array,Int16Array,Uint16Array,Int32Array,Uint32Array,Float32Array,Float64Array,BigInt64Array,BigUint64Array],s=r[e];function B(a){var Q=N[a>>2],I=N[a+4>>2];return new s(M.buffer,I,Q)}g=k(g),q(A,{name:g,fromWireType:B,argPackAdvance:$,readValueFromPointer:B},{ignoreDuplicateRegistrations:!0})},Eg=(A,e,g,r,s,B,a,Q,I,E,n,u)=>{g=k(g),B=b(s,B),Q=b(a,Q),E=b(I,E),u=b(n,u),rA([A],[e],y=>{y=y[0];var H=new DA(g,y.registeredClass,!1,!1,!0,y,r,B,Q,E,u);return[H]})},ng=(A,e,g,r)=>{if(!(r>0))return 0;for(var s=g,B=g+r-1,a=0;a<A.length;++a){var Q=A.codePointAt(a);if(Q<=127){if(g>=B)break;e[g++]=Q}else if(Q<=2047){if(g+1>=B)break;e[g++]=192|Q>>6,e[g++]=128|Q&63}else if(Q<=65535){if(g+2>=B)break;e[g++]=224|Q>>12,e[g++]=128|Q>>6&63,e[g++]=128|Q&63}else{if(g+3>=B)break;e[g++]=240|Q>>18,e[g++]=128|Q>>12&63,e[g++]=128|Q>>6&63,e[g++]=128|Q&63,a++}}return e[g]=0,g-s},hg=(A,e,g)=>ng(A,R,e,g),cg=A=>{for(var e=0,g=0;g<A.length;++g){var r=A.charCodeAt(g);r<=127?e++:r<=2047?e+=2:r>=55296&&r<=57343?(e+=4,++g):e+=3}return e},Me=typeof TextDecoder<"u"?new TextDecoder:void 0,be=(A,e=0,g=NaN)=>{for(var r=e+g,s=e;A[s]&&!(s>=r);)++s;if(s-e>16&&A.buffer&&Me)return Me.decode(A.subarray(e,s));for(var B="";e<s;){var a=A[e++];if(!(a&128)){B+=String.fromCharCode(a);continue}var Q=A[e++]&63;if((a&224)==192){B+=String.fromCharCode((a&31)<<6|Q);continue}var I=A[e++]&63;if((a&240)==224?a=(a&15)<<12|Q<<6|I:a=(a&7)<<18|Q<<12|I<<6|A[e++]&63,a<65536)B+=String.fromCharCode(a);else{var E=a-65536;B+=String.fromCharCode(55296|E>>10,56320|E&1023)}}return B},lg=(A,e)=>A?be(R,A,e):"",ug=(A,e)=>{e=k(e);var g=!0;q(A,{name:e,fromWireType(r){var s=N[r>>2],B=r+4,a;if(g)for(var Q=B,I=0;I<=s;++I){var E=B+I;if(I==s||R[E]==0){var n=E-Q,u=lg(Q,n);a===void 0?a=u:(a+="\0",a+=u),Q=E+1}}else{for(var y=new Array(s),I=0;I<s;++I)y[I]=String.fromCharCode(R[B+I]);a=y.join("")}return gA(r),a},toWireType(r,s){s instanceof ArrayBuffer&&(s=new Uint8Array(s));var B,a=typeof s=="string";a||ArrayBuffer.isView(s)&&s.BYTES_PER_ELEMENT==1||D("Cannot pass non-string to std::string"),g&&a?B=cg(s):B=s.length;var Q=ee(4+B+1),I=Q+4;if(N[Q>>2]=B,a)if(g)hg(s,I,B+1);else for(var E=0;E<B;++E){var n=s.charCodeAt(E);n>255&&(gA(Q),D("String has UTF-16 code units that do not fit in 8 bits")),R[I+E]=n}else R.set(s,I);return r!==null&&r.push(gA,Q),Q},argPackAdvance:$,readValueFromPointer:uA,destructorFunction(r){gA(r)}})},He=typeof TextDecoder<"u"?new TextDecoder("utf-16le"):void 0,dg=(A,e)=>{for(var g=A>>1,r=g+e/2,s=g;!(s>=r)&&p[s];)++s;if(s-g>16&&He)return He.decode(p.subarray(g,s));for(var B="",a=g;!(a>=r);++a){var Q=p[a];if(Q==0)break;B+=String.fromCharCode(Q)}return B},fg=(A,e,g)=>{if(g??=2147483647,g<2)return 0;g-=2;for(var r=e,s=g<A.length*2?g/2:A.length,B=0;B<s;++B){var a=A.charCodeAt(B);m[e>>1]=a,e+=2}return m[e>>1]=0,e-r},Dg=A=>A.length*2,wg=(A,e)=>{for(var g="",r=0;!(r>=e/4);r++){var s=QA[A+r*4>>2];if(!s)break;g+=String.fromCodePoint(s)}return g},yg=(A,e,g)=>{if(g??=2147483647,g<4)return 0;for(var r=e,s=r+g-4,B=0;B<A.length;++B){var a=A.codePointAt(B);if(a>65535&&B++,QA[e>>2]=a,e+=4,e+4>s)break}return QA[e>>2]=0,e-r},Fg=A=>{for(var e=0,g=0;g<A.length;++g){var r=A.codePointAt(g);r>65535&&g++,e+=4}return e},pg=(A,e,g)=>{g=k(g);var r,s,B,a;e===2?(r=dg,s=fg,a=Dg,B=Q=>p[Q>>1]):e===4&&(r=wg,s=yg,a=Fg,B=Q=>N[Q>>2]),q(A,{name:g,fromWireType:Q=>{for(var I=N[Q>>2],E,n=Q+4,u=0;u<=I;++u){var y=Q+4+u*e;if(u==I||B(y)==0){var H=y-n,T=r(n,H);E===void 0?E=T:(E+="\0",E+=T),n=y+e}}return gA(Q),E},toWireType:(Q,I)=>{typeof I!="string"&&D(`Cannot pass non-string to C++ string type ${g}`);var E=a(I),n=ee(4+E+e);return N[n>>2]=E/e,s(I,n+4,E+e),Q!==null&&Q.push(gA,n),n},argPackAdvance:$,readValueFromPointer:uA,destructorFunction(Q){gA(Q)}})},mg=(A,e,g,r,s,B)=>{RA[A]={name:k(e),rawConstructor:b(g,r),rawDestructor:b(s,B),fields:[]}},Ng=(A,e,g,r,s,B,a,Q,I,E)=>{RA[A].fields.push({fieldName:k(e),getterReturnType:g,getter:b(r,s),getterContext:B,setterArgumentType:a,setter:b(Q,I),setterContext:E})},vg=(A,e)=>{e=k(e),q(A,{isVoid:!0,name:e,argPackAdvance:0,fromWireType:()=>{},toWireType:(g,r)=>{}})},Je=0,Rg=()=>{KA=!1,Je=0},$A=(A,e)=>{var g=IA[A];return g===void 0&&D(`${e} has unknown type ${Re(A)}`),g},xe=(A,e,g)=>{var r=[],s=A.toWireType(r,g);return r.length&&(N[e>>2]=Y.toHandle(r)),s},Yg=(A,e,g)=>(A=Y.toValue(A),e=$A(e,"emval::as"),xe(e,g,A)),HA=[],Ug=(A,e,g,r)=>(A=HA[A],e=Y.toValue(e),A(null,e,g,r)),Gg={},Ae=A=>{var e=Gg[A];return e===void 0?k(A):e},kg=(A,e,g,r,s)=>(A=HA[A],e=Y.toValue(e),g=Ae(g),A(e,e[g],r,s)),Pe=()=>globalThis,Sg=A=>A===0?Y.toHandle(Pe()):(A=Ae(A),Y.toHandle(Pe()[A])),Mg=A=>{var e=HA.length;return HA.push(A),e},bg=(A,e)=>{for(var g=new Array(A),r=0;r<A;++r)g[r]=$A(N[e+r*4>>2],`parameter ${r}`);return g},Hg=(A,e,g)=>{var r=bg(A,e),s=r.shift();A--;var B=`return function (obj, func, destructorsRef, args) {
12
- `,a=0,Q=[];g===0&&Q.push("obj");for(var I=["retType"],E=[s],n=0;n<A;++n)Q.push(`arg${n}`),I.push(`argType${n}`),E.push(r[n]),B+=` var arg${n} = argType${n}.readValueFromPointer(args${a?"+"+a:""});
13
- `,a+=r[n].argPackAdvance;var u=g===1?"new func":"func.call";B+=` var rv = ${u}(${Q.join(", ")});
14
- `,s.isVoid||(I.push("emval_returnValue"),E.push(xe),B+=` return emval_returnValue(retType, destructorsRef, rv);
11
+ `,[u,E]}function Ye(A,e,g,r,s,B){var Q=e.length;Q<2&&f("argTypes array size mismatch! Must at least get return value and 'this' types!");for(var a=e[1]!==null&&g!==null,I=Re(e),E=e[0].name!=="void",n=[A,f,r,s,kA,e[0],e[1]],u=0;u<Q-2;++u)n.push(e[u+2]);if(!I)for(var u=a?1:2;u<e.length;++u)e[u].destructorFunction!==null&&n.push(e[u].destructorFunction);let[w,x]=tg(e,a,E,B);var P=new Function(...w,x)(...n);return zA(A,P)}for(var gg=(A,e,g,r,s,B)=>{var Q=ke(e,g);s=b(r,s),sA([],[A],a=>{a=a[0];var I=`constructor ${a.name}`;if(a.registeredClass.constructor_body===void 0&&(a.registeredClass.constructor_body=[]),a.registeredClass.constructor_body[e-1]!==void 0)throw new dA(`Cannot register multiple constructors with identical number of parameters (${e-1}) for class '${a.name}'! Overload resolution is currently only performed using the parameter count, not actual type info!`);return a.registeredClass.constructor_body[e-1]=()=>{wA(`Cannot construct ${a.name} due to unbound types`,Q)},sA([],Q,E=>(E.splice(1,0,null),a.registeredClass.constructor_body[e-1]=Ye(I,E,null,s,B),[])),[]})},Me=(A,e,g)=>(A instanceof Object||f(`${g} with invalid "this": ${A}`),A instanceof e.registeredClass.constructor||f(`${g} incompatible with "this" of type ${A.constructor.name}`),A.$$.ptr||f(`cannot call emscripten binding method ${g} on deleted object`),UA(A.$$.ptr,A.$$.ptrType.registeredClass,e.registeredClass)),ig=(A,e,g,r,s,B,Q,a,I,E)=>{e=M(e),s=b(r,s),sA([],[A],n=>{n=n[0];var u=`${n.name}.${e}`,w={get(){wA(`Cannot access ${u} due to unbound types`,[g,Q])},enumerable:!0,configurable:!0};return I?w.set=()=>wA(`Cannot access ${u} due to unbound types`,[g,Q]):w.set=x=>f(u+" is a read-only property"),Object.defineProperty(n.registeredClass.instancePrototype,e,w),sA([],I?[g,Q]:[g],x=>{var P=x[0],aA={get(){var AA=Me(this,n,u+" getter");return P.fromWireType(s(B,AA))},enumerable:!0};if(I){I=b(a,I);var EA=x[1];aA.set=function(AA){var rA=Me(this,n,u+" setter"),T=[];I(E,rA,EA.toWireType(T,AA)),kA(T)}}return Object.defineProperty(n.registeredClass.instancePrototype,e,aA),[]}),[]})},Se=[],CA=[0,1,,1,null,1,!0,1,!1,1],qA=A=>{A>9&&--CA[A+1]===0&&(CA[A]=void 0,Se.push(A))},k={toValue:A=>(A||f(`Cannot use deleted val. handle = ${A}`),CA[A]),toHandle:A=>{switch(A){case void 0:return 2;case null:return 4;case!0:return 6;case!1:return 8;default:{let e=Se.pop()||CA.length;return CA[e]=A,CA[e+1]=1,e}}}},rg={name:"emscripten::val",fromWireType:A=>{var e=k.toValue(A);return qA(A),e},toWireType:(A,e)=>k.toHandle(e),argPackAdvance:$,readValueFromPointer:uA,destructorFunction:null},sg=A=>q(A,rg),Bg=(A,e)=>{switch(e){case 4:return function(g){return this.fromWireType(ae[g>>2])};case 8:return function(g){return this.fromWireType(Qe[g>>3])};default:throw new TypeError(`invalid float width (${e}): ${A}`)}},ag=(A,e,g)=>{e=M(e),q(A,{name:e,fromWireType:r=>r,toWireType:(r,s)=>s,argPackAdvance:$,readValueFromPointer:Bg(e,g),destructorFunction:null})},Qg=A=>{A=A.trim();let e=A.indexOf("(");return e===-1?A:A.slice(0,e)},Ig=(A,e,g,r,s,B,Q,a)=>{var I=ke(e,g);A=M(A),A=Qg(A),s=b(r,s,Q),ye(A,function(){wA(`Cannot call ${A} due to unbound types`,I)},e-1),sA([],I,E=>{var n=[E[0],null].concat(E.slice(1));return me(A,Ye(A,n,null,s,B,Q),e-1),[]})},og=(A,e,g,r,s)=>{e=M(e);let B=r===0,Q=I=>I;if(B){var a=32-8*g;Q=I=>I<<a>>>a,s=Q(s)}q(A,{name:e,fromWireType:Q,toWireType:(I,E)=>E,argPackAdvance:$,readValueFromPointer:de(e,g,r!==0),destructorFunction:null})},Cg=(A,e,g)=>{var r=[Int8Array,Uint8Array,Int16Array,Uint16Array,Int32Array,Uint32Array,Float32Array,Float64Array,BigInt64Array,BigUint64Array],s=r[e];function B(Q){var a=F[Q>>2],I=F[Q+4>>2];return new s(U.buffer,I,a)}g=M(g),q(A,{name:g,fromWireType:B,argPackAdvance:$,readValueFromPointer:B},{ignoreDuplicateRegistrations:!0})},Eg=(A,e,g,r,s,B,Q,a,I,E,n,u)=>{g=M(g),B=b(s,B),a=b(Q,a),E=b(I,E),u=b(n,u),sA([A],[e],w=>{w=w[0];var x=new DA(g,w.registeredClass,!1,!1,!0,w,r,B,a,E,u);return[x]})},ng=(A,e,g,r)=>{if(!(r>0))return 0;for(var s=g,B=g+r-1,Q=0;Q<A.length;++Q){var a=A.codePointAt(Q);if(a<=127){if(g>=B)break;e[g++]=a}else if(a<=2047){if(g+1>=B)break;e[g++]=192|a>>6,e[g++]=128|a&63}else if(a<=65535){if(g+2>=B)break;e[g++]=224|a>>12,e[g++]=128|a>>6&63,e[g++]=128|a&63}else{if(g+3>=B)break;e[g++]=240|a>>18,e[g++]=128|a>>12&63,e[g++]=128|a>>6&63,e[g++]=128|a&63,Q++}}return e[g]=0,g-s},hg=(A,e,g)=>ng(A,v,e,g),cg=A=>{for(var e=0,g=0;g<A.length;++g){var r=A.charCodeAt(g);r<=127?e++:r<=2047?e+=2:r>=55296&&r<=57343?(e+=4,++g):e+=3}return e},Ue=typeof TextDecoder<"u"?new TextDecoder:void 0,be=(A,e=0,g=NaN)=>{for(var r=e+g,s=e;A[s]&&!(s>=r);)++s;if(s-e>16&&A.buffer&&Ue)return Ue.decode(A.subarray(e,s));for(var B="";e<s;){var Q=A[e++];if(!(Q&128)){B+=String.fromCharCode(Q);continue}var a=A[e++]&63;if((Q&224)==192){B+=String.fromCharCode((Q&31)<<6|a);continue}var I=A[e++]&63;if((Q&240)==224?Q=(Q&15)<<12|a<<6|I:Q=(Q&7)<<18|a<<12|I<<6|A[e++]&63,Q<65536)B+=String.fromCharCode(Q);else{var E=Q-65536;B+=String.fromCharCode(55296|E>>10,56320|E&1023)}}return B},lg=(A,e)=>A?be(v,A,e):"",ug=(A,e)=>{e=M(e);var g=!0;q(A,{name:e,fromWireType(r){var s=F[r>>2],B=r+4,Q;if(g)for(var a=B,I=0;I<=s;++I){var E=B+I;if(I==s||v[E]==0){var n=E-a,u=lg(a,n);Q===void 0?Q=u:(Q+="\0",Q+=u),a=E+1}}else{for(var w=new Array(s),I=0;I<s;++I)w[I]=String.fromCharCode(v[B+I]);Q=w.join("")}return iA(r),Q},toWireType(r,s){s instanceof ArrayBuffer&&(s=new Uint8Array(s));var B,Q=typeof s=="string";Q||ArrayBuffer.isView(s)&&s.BYTES_PER_ELEMENT==1||f("Cannot pass non-string to std::string"),g&&Q?B=cg(s):B=s.length;var a=ee(4+B+1),I=a+4;if(F[a>>2]=B,Q)if(g)hg(s,I,B+1);else for(var E=0;E<B;++E){var n=s.charCodeAt(E);n>255&&(iA(a),f("String has UTF-16 code units that do not fit in 8 bits")),v[I+E]=n}else v.set(s,I);return r!==null&&r.push(iA,a),a},argPackAdvance:$,readValueFromPointer:uA,destructorFunction(r){iA(r)}})},xe=typeof TextDecoder<"u"?new TextDecoder("utf-16le"):void 0,dg=(A,e)=>{for(var g=A>>1,r=g+e/2,s=g;!(s>=r)&&G[s];)++s;if(s-g>16&&xe)return xe.decode(G.subarray(g,s));for(var B="",Q=g;!(Q>=r);++Q){var a=G[Q];if(a==0)break;B+=String.fromCharCode(a)}return B},fg=(A,e,g)=>{if(g??=2147483647,g<2)return 0;g-=2;for(var r=e,s=g<A.length*2?g/2:A.length,B=0;B<s;++B){var Q=A.charCodeAt(B);m[e>>1]=Q,e+=2}return m[e>>1]=0,e-r},Dg=A=>A.length*2,wg=(A,e)=>{for(var g="",r=0;!(r>=e/4);r++){var s=QA[A+r*4>>2];if(!s)break;g+=String.fromCodePoint(s)}return g},pg=(A,e,g)=>{if(g??=2147483647,g<4)return 0;for(var r=e,s=r+g-4,B=0;B<A.length;++B){var Q=A.codePointAt(B);if(Q>65535&&B++,QA[e>>2]=Q,e+=4,e+4>s)break}return QA[e>>2]=0,e-r},yg=A=>{for(var e=0,g=0;g<A.length;++g){var r=A.codePointAt(g);r>65535&&g++,e+=4}return e},Gg=(A,e,g)=>{g=M(g);var r,s,B,Q;e===2?(r=dg,s=fg,Q=Dg,B=a=>G[a>>1]):e===4&&(r=wg,s=pg,Q=yg,B=a=>F[a>>2]),q(A,{name:g,fromWireType:a=>{for(var I=F[a>>2],E,n=a+4,u=0;u<=I;++u){var w=a+4+u*e;if(u==I||B(w)==0){var x=w-n,P=r(n,x);E===void 0?E=P:(E+="\0",E+=P),n=w+e}}return iA(a),E},toWireType:(a,I)=>{typeof I!="string"&&f(`Cannot pass non-string to C++ string type ${g}`);var E=Q(I),n=ee(4+E+e);return F[n>>2]=E/e,s(I,n+4,E+e),a!==null&&a.push(iA,n),n},argPackAdvance:$,readValueFromPointer:uA,destructorFunction(a){iA(a)}})},mg=(A,e,g,r,s,B)=>{vA[A]={name:M(e),rawConstructor:b(g,r),rawDestructor:b(s,B),fields:[]}},Fg=(A,e,g,r,s,B,Q,a,I,E)=>{vA[A].fields.push({fieldName:M(e),getterReturnType:g,getter:b(r,s),getterContext:B,setterArgumentType:Q,setter:b(a,I),setterContext:E})},Ng=(A,e)=>{e=M(e),q(A,{isVoid:!0,name:e,argPackAdvance:0,fromWireType:()=>{},toWireType:(g,r)=>{}})},Je=0,vg=()=>{ZA=!1,Je=0},$A=(A,e)=>{var g=oA[A];return g===void 0&&f(`${e} has unknown type ${ve(A)}`),g},Te=(A,e,g)=>{var r=[],s=A.toWireType(r,g);return r.length&&(F[e>>2]=k.toHandle(r)),s},kg=(A,e,g)=>(A=k.toValue(A),e=$A(e,"emval::as"),Te(e,g,A)),xA=[],Rg=(A,e,g,r)=>(A=xA[A],e=k.toValue(e),A(null,e,g,r)),Yg={},Ae=A=>{var e=Yg[A];return e===void 0?M(A):e},Mg=(A,e,g,r,s)=>(A=xA[A],e=k.toValue(e),g=Ae(g),A(e,e[g],r,s)),_e=()=>globalThis,Sg=A=>A===0?k.toHandle(_e()):(A=Ae(A),k.toHandle(_e()[A])),Ug=A=>{var e=xA.length;return xA.push(A),e},bg=(A,e)=>{for(var g=new Array(A),r=0;r<A;++r)g[r]=$A(F[e+r*4>>2],`parameter ${r}`);return g},xg=(A,e,g)=>{var r=bg(A,e),s=r.shift();A--;var B=`return function (obj, func, destructorsRef, args) {
12
+ `,Q=0,a=[];g===0&&a.push("obj");for(var I=["retType"],E=[s],n=0;n<A;++n)a.push(`arg${n}`),I.push(`argType${n}`),E.push(r[n]),B+=` var arg${n} = argType${n}.readValueFromPointer(args${Q?"+"+Q:""});
13
+ `,Q+=r[n].argPackAdvance;var u=g===1?"new func":"func.call";B+=` var rv = ${u}(${a.join(", ")});
14
+ `,s.isVoid||(I.push("emval_returnValue"),E.push(Te),B+=` return emval_returnValue(retType, destructorsRef, rv);
15
15
  `),B+=`};
16
- `;var y=new Function(...I,B)(...E),H=`methodCaller<(${r.map(T=>T.name).join(", ")}) => ${s.name}>`;return Mg(jA(H,y))},Jg=(A,e)=>(A=Y.toValue(A),e=Y.toValue(e),Y.toHandle(A[e])),xg=A=>{A>9&&(oA[A+1]+=1)},Pg=A=>Y.toHandle(Ae(A)),_g=()=>Y.toHandle({}),Tg=A=>{var e=Y.toValue(A);YA(e),qA(A)},Lg=(A,e,g)=>{A=Y.toValue(A),e=Y.toValue(e),g=Y.toValue(g),A[e]=g},Wg=(A,e)=>{A=$A(A,"_emval_take_value");var g=A.readValueFromPointer(e);return Y.toHandle(g)},yA={},_e=A=>{if(A instanceof ne||A=="unwind")return S;d(1,A)},Te=()=>KA||Je>0,Le=A=>{S=A,Te()||(i.onExit?.(A),O=!0),d(A,new ne(A))},Kg=(A,e)=>{S=A,Le(A)},Zg=Kg,Og=()=>{if(!Te())try{Zg(S)}catch(A){_e(A)}},Xg=A=>{if(!O)try{A(),Og()}catch(e){_e(e)}},Vg=()=>performance.now(),jg=(A,e)=>{if(yA[A]&&(clearTimeout(yA[A].id),delete yA[A]),!e)return 0;var g=setTimeout(()=>{delete yA[A],Xg(()=>Ke(A,Vg()))},e);return yA[A]={id:g,timeout_ms:e},0},zg=()=>2147483648,qg=(A,e)=>Math.ceil(A/e)*e,$g=A=>{var e=z.buffer,g=(A-e.byteLength+65535)/65536|0;try{return z.grow(g),Ee(),1}catch{}},Ai=A=>{var e=R.length;A>>>=0;var g=zg();if(A>g)return!1;for(var r=1;r<=4;r*=2){var s=e*(1+.2/r);s=Math.min(s,A+100663296);var B=Math.min(g,qg(Math.max(A,s),65536)),a=$g(B);if(a)return!0}return!1},ei=[null,[],[]],ti=(A,e)=>{var g=ei[A];e===0||e===10?((A===1?J:P)(be(g)),g.length=0):g.push(e)},gi=(A,e,g,r)=>{for(var s=0,B=0;B<g;B++){var a=N[e>>2],Q=N[e+4>>2];e+=8;for(var I=0;I<Q;I++)ti(A,R[a+I]);s+=Q}return N[r>>2]=s,0},tA=new Uint8Array(123),sA=25;sA>=0;--sA)tA[48+sA]=52+sA,tA[65+sA]=sA,tA[97+sA]=26+sA;tA[43]=62,tA[47]=63,Pt(),$t(),i.noExitRuntime&&(KA=i.noExitRuntime),i.print&&(J=i.print),i.printErr&&(P=i.printErr),i.wasmBinary&&(L=i.wasmBinary),i.arguments&&(h=i.arguments),i.thisProgram&&(f=i.thisProgram);var We,ee,gA,Ke,_,Ze,Oe,Xe,Ve,je,ze,qe;function ii(A){We=A.da,ee=A.ea,gA=A.fa,Ke=A.ha,_=A.ia,Ze=A.ja,Oe=A.ka,Xe=A.la,Ve=A.ma,je=A.na,ze=A.oa,qe=A.pa}var ri={m:Ft,w:pt,a:mt,e:Nt,B:vt,o:Rt,h:Yt,H:Ut,W:kt,t:Mt,N:bt,aa:eg,Z:gg,g:ig,L:sg,s:Qg,u:Ig,i:og,c:Cg,$:Eg,M:ug,n:pg,Y:mg,X:Ng,O:vg,F:Rg,S:Yg,q:Ug,R:kg,_:qA,V:Sg,p:Hg,U:Jg,K:xg,T:Pg,Q:_g,v:Tg,P:Lg,j:Wg,G:jg,I:Ai,J:gi,z:ni,A:Ei,y:hi,x:li,f:si,d:ai,r:Ci,k:Ii,b:Qi,C:oi,l:ci,D:Bi,E:Le},hA=await ft();function si(A,e){var g=Z();try{return W(A)(e)}catch(r){if(K(g),r!==r+0)throw r;_(1,0)}}function Bi(A,e,g,r,s,B,a,Q,I,E,n){var u=Z();try{W(A)(e,g,r,s,B,a,Q,I,E,n)}catch(y){if(K(u),y!==y+0)throw y;_(1,0)}}function Qi(A,e){var g=Z();try{W(A)(e)}catch(r){if(K(g),r!==r+0)throw r;_(1,0)}}function ai(A,e,g){var r=Z();try{return W(A)(e,g)}catch(s){if(K(r),s!==s+0)throw s;_(1,0)}}function Ii(A){var e=Z();try{W(A)()}catch(g){if(K(e),g!==g+0)throw g;_(1,0)}}function oi(A,e,g){var r=Z();try{W(A)(e,g)}catch(s){if(K(r),s!==s+0)throw s;_(1,0)}}function Ci(A,e,g,r){var s=Z();try{return W(A)(e,g,r)}catch(B){if(K(s),B!==B+0)throw B;_(1,0)}}function Ei(A,e,g,r,s){var B=Z();try{return W(A)(e,g,r,s)}catch(a){if(K(B),a!==a+0)throw a;_(1,0)}}function ni(A,e,g,r){var s=Z();try{return W(A)(e,g,r)}catch(B){if(K(s),B!==B+0)throw B;_(1,0)}}function hi(A,e,g,r,s,B){var a=Z();try{return W(A)(e,g,r,s,B)}catch(Q){if(K(a),Q!==Q+0)throw Q;_(1,0)}}function ci(A,e,g,r){var s=Z();try{W(A)(e,g,r)}catch(B){if(K(s),B!==B+0)throw B;_(1,0)}}function li(A){var e=Z();try{return W(A)()}catch(g){if(K(e),g!==g+0)throw g;_(1,0)}}function te(){if(aA>0){lA=te;return}if(at(),aA>0){lA=te;return}function A(){i.calledRun=!0,!O&&(It(),X?.(i),i.onRuntimeInitialized?.(),ot())}i.setStatus?(i.setStatus("Running..."),setTimeout(()=>{setTimeout(()=>i.setStatus(""),1),A()},1)):A()}function ui(){if(i.preInit)for(typeof i.preInit=="function"&&(i.preInit=[i.preInit]);i.preInit.length>0;)i.preInit.shift()()}return ui(),te(),Ce?t=i:t=new Promise((A,e)=>{X=A,V=e}),t}),tt=di;var xA=tt(),PA=navigator.gpu?.requestAdapter({powerPreference:"high-performance"}),ie=PA?.then(async U=>{if(!U)return null;let t=U.limits,i=U.features,o=await U.requestDevice({requiredFeatures:i.has("timestamp-query")?["timestamp-query"]:[],requiredLimits:{maxBufferSize:t.maxBufferSize,maxStorageBufferBindingSize:t.maxStorageBufferBindingSize,maxStorageBuffersPerShaderStage:t.maxStorageBuffersPerShaderStage}});return o.lost.then(C=>{if(C.reason!=="destroyed")throw new Error(`WebGPU device was lost with info: ${C.message}`)}),o});if(!navigator.gpu)console.warn("WebGPU not supported, you will be unable to create <dgs-player>");else if(!PA||!ie)throw new Error("WebGPU supported, but failed to create adapter or device!");import{mat4 as Bt,vec3 as re}from"gl-matrix";var FA=class{constructor(t,i){let o=t.means.byteLength+t.velocities.byteLength+t.length*Uint32Array.BYTES_PER_ELEMENT,C;try{C=new SharedArrayBuffer(o)}catch{throw new Error(`SharedArrayBuffer is not available in this environment.
16
+ `;var w=new Function(...I,B)(...E),x=`methodCaller<(${r.map(P=>P.name).join(", ")}) => ${s.name}>`;return Ug(zA(x,w))},Jg=(A,e)=>(A=k.toValue(A),e=k.toValue(e),k.toHandle(A[e])),Tg=A=>{A>9&&(CA[A+1]+=1)},_g=A=>k.toHandle(Ae(A)),Lg=()=>k.toHandle({}),Pg=A=>{var e=k.toValue(A);kA(e),qA(A)},Hg=(A,e,g)=>{A=k.toValue(A),e=k.toValue(e),g=k.toValue(g),A[e]=g},Wg=(A,e)=>{A=$A(A,"_emval_take_value");var g=A.readValueFromPointer(e);return k.toHandle(g)},pA={},Le=A=>{if(A instanceof ne||A=="unwind")return S;d(1,A)},Pe=()=>ZA||Je>0,He=A=>{S=A,Pe()||(i.onExit?.(A),X=!0),d(A,new ne(A))},Zg=(A,e)=>{S=A,He(A)},Kg=Zg,Og=()=>{if(!Pe())try{Kg(S)}catch(A){Le(A)}},Xg=A=>{if(!X)try{A(),Og()}catch(e){Le(e)}},Vg=()=>performance.now(),zg=(A,e)=>{if(pA[A]&&(clearTimeout(pA[A].id),delete pA[A]),!e)return 0;var g=setTimeout(()=>{delete pA[A],Xg(()=>Ze(A,Vg()))},e);return pA[A]={id:g,timeout_ms:e},0},jg=()=>2147483648,qg=(A,e)=>Math.ceil(A/e)*e,$g=A=>{var e=j.buffer,g=(A-e.byteLength+65535)/65536|0;try{return j.grow(g),Ee(),1}catch{}},Ai=A=>{var e=v.length;A>>>=0;var g=jg();if(A>g)return!1;for(var r=1;r<=4;r*=2){var s=e*(1+.2/r);s=Math.min(s,A+100663296);var B=Math.min(g,qg(Math.max(A,s),65536)),Q=$g(B);if(Q)return!0}return!1},ei=[null,[],[]],ti=(A,e)=>{var g=ei[A];e===0||e===10?((A===1?J:_)(be(g)),g.length=0):g.push(e)},gi=(A,e,g,r)=>{for(var s=0,B=0;B<g;B++){var Q=F[e>>2],a=F[e+4>>2];e+=8;for(var I=0;I<a;I++)ti(A,v[Q+I]);s+=a}return F[r>>2]=s,0},gA=new Uint8Array(123),BA=25;BA>=0;--BA)gA[48+BA]=52+BA,gA[65+BA]=BA,gA[97+BA]=26+BA;gA[43]=62,gA[47]=63,_t(),$t(),i.noExitRuntime&&(ZA=i.noExitRuntime),i.print&&(J=i.print),i.printErr&&(_=i.printErr),i.wasmBinary&&(W=i.wasmBinary),i.arguments&&(h=i.arguments),i.thisProgram&&(D=i.thisProgram);var We,ee,iA,Ze,L,Ke,Oe,Xe,Ve,ze,je,qe;function ii(A){We=A.da,ee=A.ea,iA=A.fa,Ze=A.ha,L=A.ia,Ke=A.ja,Oe=A.ka,Xe=A.la,Ve=A.ma,ze=A.na,je=A.oa,qe=A.pa}var ri={m:yt,w:Gt,a:mt,f:Ft,B:Nt,o:vt,h:kt,H:Rt,W:Mt,t:Ut,N:bt,aa:eg,Z:gg,d:ig,L:sg,s:ag,u:Ig,i:og,c:Cg,$:Eg,M:ug,n:Gg,Y:mg,X:Fg,O:Ng,F:vg,S:kg,q:Rg,R:Mg,_:qA,V:Sg,p:xg,U:Jg,K:Tg,T:_g,Q:Lg,v:Pg,P:Hg,j:Wg,G:zg,I:Ai,J:gi,z:ni,A:Ei,y:hi,x:li,g:si,e:Qi,r:Ci,k:Ii,b:ai,C:oi,l:ci,D:Bi,E:He},hA=await ft();function si(A,e){var g=O();try{return Z(A)(e)}catch(r){if(K(g),r!==r+0)throw r;L(1,0)}}function Bi(A,e,g,r,s,B,Q,a,I,E,n){var u=O();try{Z(A)(e,g,r,s,B,Q,a,I,E,n)}catch(w){if(K(u),w!==w+0)throw w;L(1,0)}}function ai(A,e){var g=O();try{Z(A)(e)}catch(r){if(K(g),r!==r+0)throw r;L(1,0)}}function Qi(A,e,g){var r=O();try{return Z(A)(e,g)}catch(s){if(K(r),s!==s+0)throw s;L(1,0)}}function Ii(A){var e=O();try{Z(A)()}catch(g){if(K(e),g!==g+0)throw g;L(1,0)}}function oi(A,e,g){var r=O();try{Z(A)(e,g)}catch(s){if(K(r),s!==s+0)throw s;L(1,0)}}function Ci(A,e,g,r){var s=O();try{return Z(A)(e,g,r)}catch(B){if(K(s),B!==B+0)throw B;L(1,0)}}function Ei(A,e,g,r,s){var B=O();try{return Z(A)(e,g,r,s)}catch(Q){if(K(B),Q!==Q+0)throw Q;L(1,0)}}function ni(A,e,g,r){var s=O();try{return Z(A)(e,g,r)}catch(B){if(K(s),B!==B+0)throw B;L(1,0)}}function hi(A,e,g,r,s,B){var Q=O();try{return Z(A)(e,g,r,s,B)}catch(a){if(K(Q),a!==a+0)throw a;L(1,0)}}function ci(A,e,g,r){var s=O();try{Z(A)(e,g,r)}catch(B){if(K(s),B!==B+0)throw B;L(1,0)}}function li(A){var e=O();try{return Z(A)()}catch(g){if(K(e),g!==g+0)throw g;L(1,0)}}function te(){if(IA>0){lA=te;return}if(Qt(),IA>0){lA=te;return}function A(){i.calledRun=!0,!X&&(It(),V?.(i),i.onRuntimeInitialized?.(),ot())}i.setStatus?(i.setStatus("Running..."),setTimeout(()=>{setTimeout(()=>i.setStatus(""),1),A()},1)):A()}function ui(){if(i.preInit)for(typeof i.preInit=="function"&&(i.preInit=[i.preInit]);i.preInit.length>0;)i.preInit.shift()()}return ui(),te(),Ce?t=i:t=new Promise((A,e)=>{V=A,z=e}),t}),tt=di;var TA=tt(),_A=navigator.gpu?.requestAdapter({powerPreference:"high-performance"}),ie=_A?.then(async R=>{if(!R)return null;let t=R.limits,i=R.features,C=await R.requestDevice({requiredFeatures:i.has("timestamp-query")?["timestamp-query"]:[],requiredLimits:{maxBufferSize:t.maxBufferSize,maxStorageBufferBindingSize:t.maxStorageBufferBindingSize,maxStorageBuffersPerShaderStage:t.maxStorageBuffersPerShaderStage}});return C.lost.then(o=>{if(o.reason!=="destroyed")throw new Error(`WebGPU device was lost with info: ${o.message}`)}),C});if(!navigator.gpu)console.warn("WebGPU not supported, you will be unable to create <dgs-player>");else if(!_A||!ie)throw new Error("WebGPU supported, but failed to create adapter or device!");import{mat4 as Bt,vec3 as re}from"gl-matrix";var yA=class{constructor(t,i){let C=t.means.byteLength+t.velocities.byteLength+t.length*Uint32Array.BYTES_PER_ELEMENT,o;try{o=new SharedArrayBuffer(C)}catch{throw new Error(`SharedArrayBuffer is not available in this environment.
17
17
 
18
18
  This commonly means either:
19
19
  \u2022 Cross-origin isolation is not enabled.
20
- \u2022 You are on an unsupported browser`)}let h=0;new Float32Array(C,h,t.means.length).set(t.means);let d=h+t.means.byteLength;new Float32Array(C,d,t.velocities.length).set(t.velocities);let F=d+t.velocities.byteLength;this.#t=new Worker(new URL("./workers/sort.js",import.meta.url),{type:"module"}),this.#t.onmessage=l=>{if(l.data.type!=="sorted")return;let v=new Uint32Array(C,t.means.byteLength+t.velocities.byteLength,l.data.count);i(v,l.data.duration)},this.#t.postMessage({type:"init",count:t.length,dynamic:!!t.dynamic,sab:C,meansOffset:h,velocitiesOffset:d,indicesOffset:F})}sort(t,i,o){this.#t.postMessage({type:"sort",view:t.slice(),proj:i.slice(),time:o})}#t=null};var gt=`/* gaussian_preprocess.wgsl
20
+ \u2022 You are on an unsupported browser`)}let h=0;new Float32Array(o,h,t.means.length).set(t.means);let d=h+t.means.byteLength;new Float32Array(o,d,t.velocities.length).set(t.velocities);let y=d+t.velocities.byteLength;this.#r=new Worker(new URL("./workers/sort.js",import.meta.url),{type:"module"}),this.#r.onmessage=l=>{if(l.data.type!=="sorted")return;let N=new Uint32Array(o,t.means.byteLength+t.velocities.byteLength,l.data.count);i(N,l.data.duration)},this.#r.postMessage({type:"init",count:t.length,dynamic:!!t.dynamic,sab:o,meansOffset:h,velocitiesOffset:d,indicesOffset:y})}sort(t,i,C){this.#r.postMessage({type:"sort",view:t.slice(),proj:i.slice(),time:C})}#r=null};var gt=`/* gaussian_preprocess.wgsl
21
21
  *
22
22
  * performs gaussian culling + preprocessing
23
23
  */
@@ -59,21 +59,23 @@ struct Params
59
59
  view: mat4x4f,
60
60
  proj: mat4x4f,
61
61
  camPos: vec3f,
62
-
63
- shDegree: u32,
62
+ time: f32,
64
63
 
65
64
  focalLengths: vec2f,
66
65
  viewPort: vec2f,
67
66
 
67
+ pointModeSize: f32,
68
+
69
+ numGaussians: u32,
70
+ dynamic: u32,
71
+ shDegree: u32,
72
+
73
+ scaleMin: f32,
74
+ scaleMax: f32,
68
75
  colorMin: f32,
69
76
  colorMax: f32,
70
77
  shMin: f32,
71
- shMax: f32,
72
-
73
- dynamic: u32,
74
- time: f32,
75
-
76
- numGaussians: u32
78
+ shMax: f32
77
79
  };
78
80
 
79
81
  struct RenderedGaussian
@@ -92,21 +94,31 @@ struct RenderedGaussian
92
94
  @group(0) @binding(0) var<uniform> u_params: Params;
93
95
 
94
96
  @group(0) @binding(1) var<storage, read> u_means : array<vec4f>;
95
- @group(0) @binding(2) var<storage, read> u_covariances : array<f32>;
96
- @group(0) @binding(3) var<storage, read> u_opacities : array<u32>;
97
- @group(0) @binding(4) var<storage, read> u_colors : array<u32>;
98
- @group(0) @binding(5) var<storage, read> u_shs : array<u32>;
99
- @group(0) @binding(6) var<storage, read> u_velocities : array<vec4f>;
100
- @group(0) @binding(7) var<storage, read> u_sortedIndices : array<u32>;
97
+ @group(0) @binding(2) var<storage, read> u_scales : array<u32>;
98
+ @group(0) @binding(3) var<storage, read> u_rotations : array<u32>;
99
+ @group(0) @binding(4) var<storage, read> u_opacities : array<u32>;
100
+ @group(0) @binding(5) var<storage, read> u_colors : array<u32>;
101
+ @group(0) @binding(6) var<storage, read> u_shs : array<u32>;
102
+ @group(0) @binding(7) var<storage, read> u_velocities : array<vec4f>;
103
+ @group(0) @binding(8) var<storage, read> u_sortedIndices : array<u32>;
101
104
 
102
- @group(0) @binding(8) var<storage, read_write> u_renderedGaussians: array<RenderedGaussian>;
105
+ @group(0) @binding(9) var<storage, read_write> u_renderedGaussians: array<RenderedGaussian>;
103
106
 
104
107
  var<workgroup> s_numGaussians: atomic<u32>;
105
108
  var<workgroup> s_writePosWorkgroup: u32;
106
109
 
107
110
  //-------------------------//
108
111
 
109
- fn get_sh_coeffs(gaussianIdx: u32, i: u32) -> vec3f
112
+ fn read_vec3_unorm16(buf: ptr<storage, array<u32>, read>, idx: u32) -> vec3f
113
+ {
114
+ return vec3f(vec3u(
115
+ (buf[(idx * 3 + 0) / 2] >> (((idx * 3 + 0) % 2) * 16)) & 0xFFFF,
116
+ (buf[(idx * 3 + 1) / 2] >> (((idx * 3 + 1) % 2) * 16)) & 0xFFFF,
117
+ (buf[(idx * 3 + 2) / 2] >> (((idx * 3 + 2) % 2) * 16)) & 0xFFFF
118
+ )) / 0xFFFF;
119
+ }
120
+
121
+ fn read_sh_coeffs(gaussianIdx: u32, i: u32) -> vec3f
110
122
  {
111
123
  let numCoeffs = (u_params.shDegree + 1) * (u_params.shDegree + 1) - 1;
112
124
  let idx = (gaussianIdx * numCoeffs + i - 1) * 3;
@@ -120,6 +132,38 @@ fn get_sh_coeffs(gaussianIdx: u32, i: u32) -> vec3f
120
132
  return (vec3f(shRead) / 0xFF) * (u_params.shMax - u_params.shMin) + u_params.shMin;
121
133
  }
122
134
 
135
+ fn quat_to_mat4(q: vec4f) -> mat3x3f
136
+ {
137
+ let x2 = q.x + q.x;
138
+ let y2 = q.y + q.y;
139
+ let z2 = q.z + q.z;
140
+ let xx2 = q.x * x2;
141
+ let xy2 = q.x * y2;
142
+ let xz2 = q.x * z2;
143
+ let yy2 = q.y * y2;
144
+ let yz2 = q.y * z2;
145
+ let zz2 = q.z * z2;
146
+ let sx2 = q.w * x2;
147
+ let sy2 = q.w * y2;
148
+ let sz2 = q.w * z2;
149
+
150
+ var result: mat3x3f;
151
+
152
+ result[0][0] = 1.0 - (yy2 + zz2);
153
+ result[0][1] = xy2 - sz2;
154
+ result[0][2] = xz2 + sy2;
155
+ result[1][0] = xy2 + sz2;
156
+ result[1][1] = 1.0 - (xx2 + zz2);
157
+ result[1][2] = yz2 - sx2;
158
+ result[2][0] = xz2 - sy2;
159
+ result[2][1] = yz2 + sx2;
160
+ result[2][2] = 1.0 - (xx2 + yy2);
161
+
162
+ return result;
163
+ }
164
+
165
+ //-------------------------//
166
+
123
167
  @compute @workgroup_size(WORKGROUP_SIZE)
124
168
  fn preprocess(@builtin(global_invocation_id) GID: vec3u, @builtin(local_invocation_id) LID: vec3u)
125
169
  {
@@ -145,18 +189,20 @@ fn preprocess(@builtin(global_invocation_id) GID: vec3u, @builtin(local_invocati
145
189
 
146
190
  //unpack covariance matrix:
147
191
  //---------------
148
- let c0 = u_covariances[idx * 6 + 0];
149
- let c1 = u_covariances[idx * 6 + 1];
150
- let c2 = u_covariances[idx * 6 + 2];
151
- let c3 = u_covariances[idx * 6 + 3];
152
- let c4 = u_covariances[idx * 6 + 4];
153
- let c5 = u_covariances[idx * 6 + 5];
154
-
155
- let cov = mat3x3f(
156
- vec3f(c0, c1, c2),
157
- vec3f(c1, c3, c4),
158
- vec3f(c2, c4, c5)
192
+ let scales = exp(
193
+ read_vec3_unorm16(&u_scales, idx) * (u_params.scaleMax - u_params.scaleMin) + u_params.scaleMin
194
+ );
195
+ let rots = read_vec3_unorm16(&u_rotations, idx) * 2.0 - 1.0;
196
+
197
+ let scaleMat = mat3x3f(
198
+ scales.x, 0.0, 0.0,
199
+ 0.0, scales.y, 0.0,
200
+ 0.0, 0.0, scales.z
159
201
  );
202
+ let rotMat = quat_to_mat4(vec4f(rots, sqrt(1.0 - dot(rots, rots))));
203
+
204
+ let M = scaleMat * rotMat;
205
+ let cov = 4.0 * transpose(M) * M;
160
206
 
161
207
  //project covariance matrix to 2D:
162
208
  //---------------
@@ -186,18 +232,22 @@ fn preprocess(@builtin(global_invocation_id) GID: vec3u, @builtin(local_invocati
186
232
  let v1 = normalize(vec2f(cov2d[0][1], lambda1 - cov2d[0][0]));
187
233
  let v2 = vec2f(v1.y, -v1.x);
188
234
 
189
- let major = min(sqrt(2.0 * lambda1), 1024.0) * v1;
190
- let minor = min(sqrt(2.0 * lambda2), 1024.0) * v2;
235
+ var major: vec2f;
236
+ var minor: vec2f;
237
+ if(u_params.pointModeSize > 0.0)
238
+ {
239
+ major = vec2f(0.0, u_params.pointModeSize);
240
+ minor = vec2f(u_params.pointModeSize, 0.0);
241
+ }
242
+ else
243
+ {
244
+ major = min(sqrt(2.0 * lambda1), 1024.0) * v1;
245
+ minor = min(sqrt(2.0 * lambda2), 1024.0) * v2;
246
+ }
191
247
 
192
248
  //evalate sh:
193
249
  //---------------
194
- let dcRead = vec3u(
195
- (u_colors[(idx * 3 + 0) / 2] >> (((idx * 3 + 0) % 2) * 16)) & 0xFFFF,
196
- (u_colors[(idx * 3 + 1) / 2] >> (((idx * 3 + 1) % 2) * 16)) & 0xFFFF,
197
- (u_colors[(idx * 3 + 2) / 2] >> (((idx * 3 + 2) % 2) * 16)) & 0xFFFF
198
- );
199
-
200
- let dc = (vec3f(dcRead) / f32(0xFFFF)) * (u_params.colorMax - u_params.colorMin) + u_params.colorMin;
250
+ let dc = read_vec3_unorm16(&u_colors, idx) * (u_params.colorMax - u_params.colorMin) + u_params.colorMin;
201
251
  let dir = normalize(mean.xyz - u_params.camPos);
202
252
 
203
253
  var color = SH_C0 * dc;
@@ -206,9 +256,9 @@ fn preprocess(@builtin(global_invocation_id) GID: vec3u, @builtin(local_invocati
206
256
  let x = dir.x;
207
257
  let y = dir.y;
208
258
  let z = dir.z;
209
- color += -SH_C1 * y * get_sh_coeffs(idx, 1) +
210
- SH_C1 * z * get_sh_coeffs(idx, 2) -
211
- SH_C1 * x * get_sh_coeffs(idx, 3);
259
+ color += -SH_C1 * y * read_sh_coeffs(idx, 1) +
260
+ SH_C1 * z * read_sh_coeffs(idx, 2) -
261
+ SH_C1 * x * read_sh_coeffs(idx, 3);
212
262
 
213
263
  if(u_params.shDegree > 1)
214
264
  {
@@ -219,21 +269,21 @@ fn preprocess(@builtin(global_invocation_id) GID: vec3u, @builtin(local_invocati
219
269
  let yz = dir.y * dir.z;
220
270
  let xz = dir.x * dir.z;
221
271
 
222
- color += SH_C2[0] * xy * get_sh_coeffs(idx, 4) +
223
- SH_C2[1] * yz * get_sh_coeffs(idx, 5) +
224
- SH_C2[2] * (2.0 * zz - xx - yy) * get_sh_coeffs(idx, 6) +
225
- SH_C2[3] * xz * get_sh_coeffs(idx, 7) +
226
- SH_C2[4] * (xx - yy) * get_sh_coeffs(idx, 8);
272
+ color += SH_C2[0] * xy * read_sh_coeffs(idx, 4) +
273
+ SH_C2[1] * yz * read_sh_coeffs(idx, 5) +
274
+ SH_C2[2] * (2.0 * zz - xx - yy) * read_sh_coeffs(idx, 6) +
275
+ SH_C2[3] * xz * read_sh_coeffs(idx, 7) +
276
+ SH_C2[4] * (xx - yy) * read_sh_coeffs(idx, 8);
227
277
 
228
278
  if(u_params.shDegree > 2)
229
279
  {
230
- color += SH_C3[0] * y * (3.0 * xx - yy) * get_sh_coeffs(idx, 9) +
231
- SH_C3[1] * xy * z * get_sh_coeffs(idx, 10) +
232
- SH_C3[2] * y * (4.0 * zz - xx - yy) * get_sh_coeffs(idx, 11) +
233
- SH_C3[3] * z * (2.0 * zz - 3.0 * xx - 3.0 * yy) * get_sh_coeffs(idx, 12) +
234
- SH_C3[4] * x * (4.0 * zz - xx - yy) * get_sh_coeffs(idx, 13) +
235
- SH_C3[5] * z * (xx - yy) * get_sh_coeffs(idx, 14) +
236
- SH_C3[6] * x * (xx - 3.0 * yy) * get_sh_coeffs(idx, 15);
280
+ color += SH_C3[0] * y * (3.0 * xx - yy) * read_sh_coeffs(idx, 9) +
281
+ SH_C3[1] * xy * z * read_sh_coeffs(idx, 10) +
282
+ SH_C3[2] * y * (4.0 * zz - xx - yy) * read_sh_coeffs(idx, 11) +
283
+ SH_C3[3] * z * (2.0 * zz - 3.0 * xx - 3.0 * yy) * read_sh_coeffs(idx, 12) +
284
+ SH_C3[4] * x * (4.0 * zz - xx - yy) * read_sh_coeffs(idx, 13) +
285
+ SH_C3[5] * z * (xx - yy) * read_sh_coeffs(idx, 14) +
286
+ SH_C3[6] * x * (xx - 3.0 * yy) * read_sh_coeffs(idx, 15);
237
287
  }
238
288
  }
239
289
  }
@@ -280,8 +330,7 @@ struct Params
280
330
  view: mat4x4f,
281
331
  proj: mat4x4f,
282
332
  camPos: vec3f,
283
-
284
- shDegree: u32,
333
+ time: f32,
285
334
 
286
335
  focalLengths: vec2f,
287
336
  viewPort: vec2f
@@ -370,7 +419,7 @@ fn fs(in: VertexOutput) -> @location(0) vec4f
370
419
  let c = textureSample(colorTex, colorSampler, in.uv);
371
420
  // output premultiplied-like color: rgb in src, alpha = src.a
372
421
  return vec4<f32>(c.rgb, c.a);
373
- }`;var j=Float32Array.BYTES_PER_ELEMENT,EA=Uint32Array.BYTES_PER_ELEMENT,st=64,pA=4,yi=.001,Fi=.001,pi=0,se=class{constructor(t){this.#g=t}async initialize(){this.#t=await xA,this.#A=await ie,this.#C=await PA,this.#d=this.#p(),this.#c=this.#m(),this.#f=this.#y(),this.#D=this.#N(),this.#u=this.#v(),this.#s=this.#F(),this.#I=this.#G(),this.#C.features.has("timestamp-query")&&(this.#i=this.#R())}resize(){this.#c=this.#m()}setGaussians(t){this.#B=this.#a?this.#t.combine(t,this.#a):t,this.#e=this.#k(this.#B);let i=new FA(this.#B,(o,C)=>{this.#r=!1,this.#E==i&&(this.#H(o),this.#n=!0,this.#h.lastSortTime=C)});this.#n=!1,this.#o=null,this.#E=i}setScene(t){this.#a=t}draw(t,i,o,C={},h=!1){if(!this.#B||(this.#i==null&&(h=!1),!this.#r&&this.#b(t,o)&&(this.#r=!0,this.#E.sort(t,i,o),this.#o={view:t.slice(),time:o}),!this.#n))return;let f=performance.now();var d=0;this.#w&&(d=f-this.#w),this.#w=f;let w=re.transformMat4(re.create(),re.fromValues(0,0,0),Bt.invert(Bt.create(),t)),F=[i[0]*(this.#g.width/2),i[5]*(this.#g.height/2)],l=[this.#g.width,this.#g.height];this.#S(t,i,w,F,l,o);let v=this.#M(),J=null,P=null;h&&(J=this.#A.createBuffer({size:pA*8,usage:GPUBufferUsage.QUERY_RESOLVE|GPUBufferUsage.COPY_SRC}),P=this.#A.createBuffer({size:pA*8,usage:GPUBufferUsage.COPY_DST|GPUBufferUsage.MAP_READ}));let L=this.#A.createCommandEncoder(),O=L.beginComputePass({timestampWrites:h?{querySet:this.#i.querySet,beginningOfPassWriteIndex:0,endOfPassWriteIndex:1}:void 0});O.setPipeline(this.#f),O.setBindGroup(0,v.preprocess),this.#Q>0&&O.dispatchWorkgroups(Math.ceil(this.#Q/st)),O.end();let S=L.beginRenderPass({label:"main",colorAttachments:[{view:this.#c.view,clearValue:{r:0,g:0,b:0,a:0},loadOp:"clear",storeOp:"store"}],timestampWrites:h?{querySet:this.#i.querySet,beginningOfPassWriteIndex:2,endOfPassWriteIndex:3}:void 0});S.setPipeline(this.#D),S.setVertexBuffer(0,this.#s.vertex),S.setIndexBuffer(this.#s.index,"uint16"),S.setBindGroup(0,v.rasterize),this.#Q>0&&S.drawIndexed(6,this.#Q),S.end();let X=C.backgroundColor??[0,0,0],V=L.beginRenderPass({label:"composite",colorAttachments:[{view:this.#d.getCurrentTexture().createView(),clearValue:{r:X[0],g:X[1],b:X[2],a:1},loadOp:"clear",storeOp:"store"}]});V.setPipeline(this.#u),V.setBindGroup(0,v.composite),V.draw(3),V.end(),h&&(L.resolveQuerySet(this.#i.querySet,0,pA,J,0),L.copyBufferToBuffer(J,0,P,0,pA*8)),this.#A.queue.submit([L.finish()]),h&&P.mapAsync(GPUMapMode.READ).then(()=>{let z=P.getMappedRange(),M=new BigUint64Array(z);if(this.#i.accumFrames++,this.#i.accumTime+=d,this.#i.accumPreprocessTime+=Number(M[1]-M[0]),this.#i.accumRasterTime+=Number(M[3]-M[2]),P.unmap(),this.#i.accumTime>=1e3){let R=this.#i.accumPreprocessTime/1e6/this.#i.accumFrames,m=this.#i.accumRasterTime/1e6/this.#i.accumFrames,p=R+m;this.#h.preprocessTime=R,this.#h.rasterTime=m,this.#h.totalTime=p,this.#i.accumFrames=0,this.#i.accumTime=0,this.#i.accumPreprocessTime=0,this.#i.accumRasterTime=0}})}getPerformanceProfile(){return this.#h}#t=null;#A=null;#C=null;#g=null;#d=null;#c=null;#f=null;#D=null;#u=null;#i=null;#a=null;#B=null;#e=null;#s=null;#I=null;#Q=0;#E=null;#n=!1;#r=!1;#o=null;#w=null;#h={};#p(){let t=this.#g.getContext("webgpu");return t.configure({device:this.#A,format:navigator.gpu.getPreferredCanvasFormat(),alphaMode:"opaque"}),t}#m(){let t=this.#g.width|0,i=this.#g.height|0;if(t==0||i==0)return;let o=navigator.gpu.getPreferredCanvasFormat(),C=this.#A.createTexture({size:[t,i,1],format:o,usage:GPUTextureUsage.RENDER_ATTACHMENT|GPUTextureUsage.TEXTURE_BINDING});return{tex:C,view:C.createView(),sampler:this.#A.createSampler({magFilter:"linear",minFilter:"linear"})}}#y(){let t=this.#A.createShaderModule({label:"gaussian preprocess",code:gt});return this.#A.createComputePipeline({label:"gaussian preprocess",layout:"auto",compute:{module:t,entryPoint:"preprocess",constants:{WORKGROUP_SIZE:st}}})}#N(){let t=this.#A.createShaderModule({label:"gaussian rasterize",code:it});return this.#A.createRenderPipeline({label:"gaussian",layout:"auto",vertex:{module:t,entryPoint:"vs",buffers:[{stepMode:"vertex",arrayStride:2*j,attributes:[{shaderLocation:0,offset:0,format:"float32x2"}]}]},fragment:{module:t,entryPoint:"fs",targets:[{format:navigator.gpu.getPreferredCanvasFormat(),blend:{alpha:{srcFactor:"one-minus-dst-alpha",dstFactor:"one",operation:"add"},color:{srcFactor:"one-minus-dst-alpha",dstFactor:"one",operation:"add"}}}]},primitive:{topology:"triangle-list",cullMode:"none"}})}#v(){let t=this.#A.createShaderModule({label:"composite",code:rt});return this.#A.createRenderPipeline({label:"composite",layout:"auto",vertex:{module:t,entryPoint:"vs"},fragment:{module:t,entryPoint:"fs",targets:[{format:navigator.gpu.getPreferredCanvasFormat(),blend:{color:{srcFactor:"src-alpha",dstFactor:"one-minus-src-alpha",operation:"add"},alpha:{srcFactor:"one",dstFactor:"one-minus-src-alpha",operation:"add"}}}]},primitive:{topology:"triangle-list",cullMode:"none"}})}#R(){return{querySet:this.#A.createQuerySet({type:"timestamp",count:pA}),accumFrames:0,accumTime:0,accumRasterTime:0,accumPreprocessTime:0}}#F(){let t=new Float32Array([-2,-2,2,-2,2,2,-2,2]),i=this.#A.createBuffer({label:"quad vertices",size:t.byteLength,usage:GPUBufferUsage.VERTEX|GPUBufferUsage.COPY_DST});this.#A.queue.writeBuffer(i,0,t);let o=new Uint16Array([0,1,2,0,2,3]),C=this.#A.createBuffer({label:"quad indices",size:o.byteLength,usage:GPUBufferUsage.INDEX|GPUBufferUsage.COPY_DST});return this.#A.queue.writeBuffer(C,0,o),{vertex:i,index:C}}#G(){let t=0;return t+=16*j,t+=16*j,t+=3*j,t+=1*EA,t+=2*j,t+=2*j,t+=2*j,t+=2*j,t+=1*EA,t+=1*j,t+=2*EA,this.#A.createBuffer({label:"params",size:t,usage:GPUBufferUsage.UNIFORM|GPUBufferUsage.COPY_DST})}#k(t){let i=12*j,o=this.#l(this.#e?.means,{label:"means",size:t.means.byteLength,usage:GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_DST});this.#A.queue.writeBuffer(o,0,t.means);let C=this.#l(this.#e?.covariances,{label:"covariances",size:t.covariances.byteLength,usage:GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_DST});this.#A.queue.writeBuffer(C,0,t.covariances);let h=this.#l(this.#e?.opacities,{label:"opacities",size:this.#U(t.opacities.byteLength,EA),usage:GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_DST});this.#Y(h,t.opacities);let f=this.#l(this.#e?.colors,{label:"colors",size:this.#U(t.colors.byteLength,EA),usage:GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_DST});this.#Y(f,t.colors);let d=this.#l(this.#e?.shs,{label:"spherical harmomics",size:this.#U(t.shs.byteLength,EA),usage:GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_DST});this.#Y(d,t.shs);let w=this.#l(this.#e?.velocities,{label:"velocities",size:Math.max(t.velocities.byteLength,4*j),usage:GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_DST});this.#A.queue.writeBuffer(w,0,t.velocities);let F=this.#l(this.#e?.sortedIndices,{label:"sorted indices",size:t.length*EA,usage:GPUBufferUsage.COPY_DST|GPUBufferUsage.STORAGE}),l=this.#l(this.#e?.rendered,{label:"rendered gaussians",size:t.length*i,usage:GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_DST|GPUBufferUsage.INDIRECT});return{means:o,covariances:C,opacities:h,colors:f,shs:d,velocities:w,sortedIndices:F,rendered:l}}#S(t,i,o,C,h,f){let d=new ArrayBuffer(this.#I.size),w=new Float32Array(d),F=new Uint32Array(d),l=0;w.set(t,l),l+=16,w.set(i,l),l+=16,w.set(o,l),l+=3,F.set([this.#B.shDegree],l),l+=1,w.set(C,l),l+=2,w.set(h,l),l+=2,w.set([this.#B.colorMin,this.#B.colorMax],l),l+=2,w.set([this.#B.shMin,this.#B.shMax],l),l+=2,F.set([Number(this.#B.dynamic)],l),l+=1,w.set([f],l),l+=1,F.set([this.#Q],l),l+=1,this.#A.queue.writeBuffer(this.#I,0,d)}#M(){let t=this.#A.createBindGroup({label:"gaussian preprocess",layout:this.#f.getBindGroupLayout(0),entries:[{binding:0,resource:{buffer:this.#I}},{binding:1,resource:{buffer:this.#e.means}},{binding:2,resource:{buffer:this.#e.covariances}},{binding:3,resource:{buffer:this.#e.opacities}},{binding:4,resource:{buffer:this.#e.colors}},{binding:5,resource:{buffer:this.#e.shs}},{binding:6,resource:{buffer:this.#e.velocities}},{binding:7,resource:{buffer:this.#e.sortedIndices}},{binding:8,resource:{buffer:this.#e.rendered}}]}),i=this.#A.createBindGroup({label:"gaussian rasterize",layout:this.#D.getBindGroupLayout(0),entries:[{binding:0,resource:{buffer:this.#I}},{binding:1,resource:{buffer:this.#e.rendered}}]}),o=this.#A.createBindGroup({label:"composite",layout:this.#u.getBindGroupLayout(0),entries:[{binding:0,resource:this.#c.view},{binding:1,resource:this.#c.sampler}]});return{preprocess:t,rasterize:i,composite:o}}#b(t,i){if(this.#o==null)return!0;let o=this.#o.view,C=[t[2],t[6],t[10]],h=[t[12],t[13],t[14]],f=[o[2],o[6],o[10]],d=[o[12],o[13],o[14]],w=1-(C[0]*f[0]+C[1]*f[1]+C[2]*f[2]),F=Math.pow(h[0]-d[0],2)+Math.pow(h[1]-d[1],2)+Math.pow(h[2]-d[2],2),l=Math.abs(i-this.#o.time);return w>yi||F>Fi||l>pi}#H(t){this.#Q=t.length,this.#A.queue.writeBuffer(this.#e.sortedIndices,0,t)}#l(t,i){return t==null||t.size<i.size?(t?.destroy(),this.#A.createBuffer(i)):t}#Y(t,i){let o,C,h;i instanceof ArrayBuffer?(o=i,C=0,h=i.byteLength):(o=i.buffer,C=i.byteOffset,h=i.byteLength);let f=h&-4;f>0&&this.#A.queue.writeBuffer(t,0,o,C,f);let d=h-f;if(d>0){let w=new Uint8Array(4);w.set(new Uint8Array(o,C+f,d)),this.#A.queue.writeBuffer(t,f,w,0,4)}}#U(t,i){return t==0?i:t+i-1&~(i-1)}},Qt=se;import{mat4 as G,vec3 as c}from"gl-matrix";var mA=class U{constructor(){if(new.target===U)throw new Error("Cannot instantiate abstract class Camera directly");this.keysPressed=new Set,this.mouseDown=!1,this.mouseX=0,this.mouseY=0}getViewMatrix(){return null}getProjMatrix(t){let i=this.fov||80;return G.perspective(G.create(),i*Math.PI/180,t,.01,100)}getParams(){return{}}onMouseDown(t){t.button===0&&(this.mouseDown=!0)}onMouseUp(t){t.button===0&&(this.mouseDown=!1)}onMouseMove(t){this.mouseX=t.clientX,this.mouseY=t.clientY}onDoubleClick(t){}onScroll(t){}onTouchStart(t){t.touches.length===1&&(this.mouseDown=!0),this.mouseX=t.touches[0].clientX,this.mouseY=t.touches[0].clientY}onTouchEnd(t){t.touches.length===1&&(this.mouseDown=!1)}onTouchMove(t){this.mouseX=t.touches[0].clientX,this.mouseY=t.touches[0].clientY}onKeyDown(t){this.keysPressed.add(t.code)}onKeyUp(t){this.keysPressed.delete(t.code)}update(t){}_editingSomething(){let t=document.activeElement;return t&&(t.tagName==="INPUT"||t.tagName==="TEXTAREA"||t.isContentEditable)}attachToCanvas(t){this._onMouseDown=i=>this.onMouseDown(i),this._onMouseUp=i=>this.onMouseUp(i),this._onMouseMove=i=>this.onMouseMove(i),this._onMouseLeave=i=>this.onMouseUp(i),this._onDoubleClick=i=>this.onDoubleClick(i),this._onWheel=i=>{this.onScroll!==U.prototype.onScroll&&i.preventDefault(),this.onScroll(i.deltaY)},this._onTouchStart=i=>{this.onTouchStart!=U.prototype.onTouchStart&&i.preventDefault(),this.onTouchStart(i)},this._onTouchMove=i=>{this.onTouchMove!=U.prototype.onTouchMove&&i.preventDefault(),this.onTouchMove(i)},this._onTouchEnd=i=>{this.onTouchEnd!=U.prototype.onTouchEnd&&i.preventDefault(),this.onTouchEnd(i)},this._onKeyDown=i=>{this._editingSomething()||(i.code==="Space"&&i.preventDefault(),this.onKeyDown(i))},this._onKeyUp=i=>{this._editingSomething()||(i.code==="Space"&&i.preventDefault(),this.onKeyUp(i))},t.addEventListener("mousedown",this._onMouseDown),t.addEventListener("mouseup",this._onMouseUp),t.addEventListener("mousemove",this._onMouseMove),t.addEventListener("mouseleave",this._onMouseLeave),t.addEventListener("dblclick",this._onDoubleClick),t.addEventListener("wheel",this._onWheel),t.addEventListener("touchstart",this._onTouchStart),t.addEventListener("touchmove",this._onTouchMove),t.addEventListener("touchend",this._onTouchEnd),window.addEventListener("keydown",this._onKeyDown),window.addEventListener("keyup",this._onKeyUp),this._canvas=t}detachFromCanvas(){this._canvas&&(this._canvas.removeEventListener("mousedown",this._onMouseDown),this._canvas.removeEventListener("mouseup",this._onMouseUp),this._canvas.removeEventListener("mousemove",this._onMouseMove),this._canvas.removeEventListener("mouseleave",this._onMouseLeave),this._canvas.removeEventListener("dblclick",this._onDoubleClick),this._canvas.removeEventListener("wheel",this._onWheel),this._canvas.removeEventListener("touchstart",this._onTouchStart),this._canvas.removeEventListener("touchmove",this._onTouchMove),this._canvas.removeEventListener("touchend",this._onTouchEnd),window.removeEventListener("keydown",this._onKeyDown),window.removeEventListener("keyup",this._onKeyUp),this._canvas=null)}},cA=class extends mA{constructor(t={}){super(),this.fov=t.fov||80,this.sens=t.sens||.003,this.panSens=t.panSens||.0025,this.scrollSens=t.scrollSens||.0025,this.keyMoveSpeed=t.keyMoveSpeed||.02,this.minRadius=t.minRadius||.5,this.maxRadius=t.maxRadius||3,this.targetRadius=t.radius||(this.minRadius+this.maxRadius)/2,this.radius=this.targetRadius,this.targetTheta=t.theta||0,this.theta=this.targetTheta,this.targetPhi=t.phi||0,this.phi=this.targetPhi,this.targetPos=c.fromValues(t.targetX||0,t.targetY||0,t.targetZ||0),this.pos=this.targetPos,this.mouseX=t.mouseX||0,this.mouseY=t.mouseY||0,this.rotating=t.startRotating||!1,this.dragging=t.startRotating||!1,this.pinchStartDistance=0}getViewMatrix(){let t=c.fromValues(this.pos[0]+this.radius*Math.sin(this.theta)*Math.cos(this.phi),this.pos[1]+this.radius*Math.sin(this.phi),this.pos[2]+this.radius*Math.cos(this.theta)*Math.cos(this.phi));return G.lookAt(G.create(),t,this.pos,c.fromValues(0,1,0))}getParams(){return{fov:this.fov,sens:this.sens,panSens:this.panSens,scrollSens:this.scrollSens,radius:this.radius,minRadius:this.minRadius,maxRadius:this.maxRadius,theta:this.theta,phi:this.phi,targetX:this.pos[0],targetY:this.pos[1],targetZ:this.pos[2],mouseX:this.mouseX,mouseY:this.mouseY,startRotating:this.rotating||this.dragging}}onMouseDown(t){if(t.button===0)this.rotating=!0;else return;this.mouseX=t.clientX,this.mouseY=t.clientY}onMouseUp(t){this.rotating=!1}onDoubleClick(t){this.targetRadius/=2}onMouseMove(t){if(this.rotating){let i=t.clientX-this.mouseX,o=t.clientY-this.mouseY;this.targetTheta+=i*this.sens,this.targetPhi-=o*this.sens,this.targetPhi=Math.max(this.targetPhi,-Math.PI/2+.01),this.targetPhi=Math.min(this.targetPhi,Math.PI/2-.01)}this.mouseX=t.clientX,this.mouseY=t.clientY}onScroll(t){this.targetRadius+=t*this.scrollSens,this.targetRadius=Math.max(this.targetRadius,this.minRadius),this.targetRadius=Math.min(this.targetRadius,this.maxRadius)}onTouchStart(t){if(t.touches.length===1)this.mouseX=t.touches[0].clientX,this.mouseY=t.touches[0].clientY,this.dragging=!0;else if(t.touches.length===2){this.dragging=!1;let i=t.touches[0],o=t.touches[1];this.pinchStartDistance=Math.hypot(o.clientX-i.clientX,o.clientY-i.clientY)}}onTouchMove(t){if(t.touches.length===1&&this.dragging){let i=t.touches[0],o=i.clientX-this.mouseX,C=i.clientY-this.mouseY;this.targetTheta+=o*this.sens,this.targetPhi-=C*this.sens,this.targetPhi=Math.max(this.targetPhi,-Math.PI/2),this.targetPhi=Math.min(this.targetPhi,Math.PI/2),this.mouseX=i.clientX,this.mouseY=i.clientY}else if(t.touches.length===2){let i=t.touches[0],o=t.touches[1],C=Math.hypot(o.clientX-i.clientX,o.clientY-i.clientY),h=this.pinchStartDistance-C;this.onScroll(h),this.pinchStartDistance=C}}onTouchEnd(t){t.touches.length===0?this.dragging=!1:t.touches.length===1&&(this.mouseX=t.touches[0].clientX,this.mouseY=t.touches[0].clientY)}update(t){super.update(t);let i=1-Math.pow(.99,t);this.pos=c.add(c.create(),this.pos,c.scale(c.create(),c.sub(c.create(),this.targetPos,this.pos),i)),this.radius+=(this.targetRadius-this.radius)*i,this.theta+=(this.targetTheta-this.theta)*i,this.phi+=(this.targetPhi-this.phi)*i,this.keysPressed.size>0&&this.handleKeyboardMovement(t)}handleKeyboardMovement(t){let i=this.keyMoveSpeed*(t/16.67),o=Math.cos(this.targetTheta),C=-Math.sin(this.targetTheta),h=-Math.sin(this.targetTheta),f=-Math.cos(this.targetTheta),d=0,w=0,F=0;this.keysPressed.has("KeyW")&&(d+=h,F+=f),this.keysPressed.has("KeyS")&&(d-=h,F-=f),this.keysPressed.has("KeyA")&&(d+=o,F+=C),this.keysPressed.has("KeyD")&&(d-=o,F-=C),this.keysPressed.has("Space")&&(w-=1),this.keysPressed.has("ShiftLeft")&&(w+=1),this.targetPos=c.add(c.create(),this.targetPos,c.scale(c.create(),c.normalize(c.create(),c.fromValues(d,w,F)),i))}},_A=class extends mA{constructor(t={}){super(),this.fov=t.fov||80,this.baseTheta=t.baseTheta||Math.PI/4,this.basePhi=t.basePhi||Math.PI/4,this.targetTheta=t.theta||this.baseTheta,this.targetPhi=t.phi||this.basePhi,this.targetRadius=t.radius||1.5,this.theta=this.targetTheta,this.phi=this.targetPhi,this.radius=this.targetRadius,this.minRadius=t.minRadius||.5,this.maxRadius=t.maxRadius||3,this.targetX=t.targetX||0,this.targetY=t.targetY||0,this.targetZ=t.targetZ||0,this.sens=t.sens||.003,this.scrollSens=t.scrollSens||.0025,this.resistance=t.resistance||.25,this.deadZone=t.deadZone||.1,this.snapSmoothness=t.snapSmoothness||.9925,this.valueSmoothness=t.valueSmoothness||.9925,this.radiusSmoothness=t.radiusSmoothness||.99,this.mouseX=t.mouseX||0,this.mouseY=t.mouseY||0,this.rotating=t.startRotating||!1,this.pinchStartDistance=0,this.canvas=null}attachToCanvas(t){super.attachToCanvas(t),this.canvas=t}getViewMatrix(){let t=this.targetX+this.radius*Math.sin(this.theta)*Math.cos(this.phi),i=this.targetY+this.radius*Math.sin(this.phi),o=this.targetZ+this.radius*Math.cos(this.theta)*Math.cos(this.phi);return G.lookAt(G.create(),c.fromValues(t,i,o),c.fromValues(this.targetX,this.targetY,this.targetZ),c.fromValues(0,1,0))}onMouseDown(t){t.button===0&&(this.rotating=!0,this.mouseX=t.clientX,this.mouseY=t.clientY,this.targetTheta=this.theta,this.targetPhi=this.phi,this.targetRadius=this.radius)}onMouseUp(t){t.button===0&&(this.rotating=!1)}onMouseMove(t){if(!this.rotating){this.mouseX=t.clientX,this.mouseY=t.clientY;return}let i=t.clientX-this.mouseX,o=t.clientY-this.mouseY,C=this.targetTheta-this.baseTheta,h=this.targetPhi-this.basePhi,f=this.#t(C,h,this.resistance);this.targetTheta+=i*this.sens*f,this.targetPhi-=o*this.sens*f,this.targetPhi=Math.max(this.targetPhi,-Math.PI/2+.01),this.targetPhi=Math.min(this.targetPhi,Math.PI/2-.01),this.mouseX=t.clientX,this.mouseY=t.clientY}onScroll(t){this.targetRadius+=t*this.scrollSens,this.targetRadius=Math.max(this.targetRadius,this.minRadius),this.targetRadius=Math.min(this.targetRadius,this.maxRadius)}onTouchStart(t){if(t.touches.length===1){let i=t.touches[0];this.rotating=!0,this.mouseX=i.clientX,this.mouseY=i.clientY}else if(t.touches.length===2){this.rotating=!1;let i=t.touches[0],o=t.touches[1];this.pinchStartDistance=Math.hypot(o.clientX-i.clientX,o.clientY-i.clientY)}}onTouchMove(t){if(t.touches.length===1&&this.rotating){let i=t.touches[0],o=i.clientX-this.mouseX,C=i.clientY-this.mouseY,h=this.targetTheta-this.baseTheta,f=this.targetPhi-this.basePhi,d=this.#t(h,f,this.resistance);this.targetTheta+=o*this.sens*d,this.targetPhi-=C*this.sens*d,this.targetPhi=Math.max(this.targetPhi,-Math.PI/2+.01),this.targetPhi=Math.min(this.targetPhi,Math.PI/2-.01),this.mouseX=i.clientX,this.mouseY=i.clientY}else if(t.touches.length===2){let i=t.touches[0],o=t.touches[1],C=Math.hypot(o.clientX-i.clientX,o.clientY-i.clientY),h=this.pinchStartDistance-C;this.onScroll(h),this.pinchStartDistance=C}}onTouchEnd(t){if(t.touches.length===0)this.rotating=!1;else if(t.touches.length===1){let i=t.touches[0];this.mouseX=i.clientX,this.mouseY=i.clientY}}update(t){super.update(t);let i=1-Math.pow(this.snapSmoothness,t),o=1-Math.pow(this.valueSmoothness,t);if(this.rotating)this.theta=this.targetTheta,this.phi=this.targetPhi,this.radius=this.targetRadius;else{let C=this.#A(this.targetTheta,this.targetPhi,this.baseTheta,this.basePhi,this.deadZone);this.targetTheta+=(C.theta-this.targetTheta)*i,this.targetPhi+=(C.phi-this.targetPhi)*i,this.theta+=(this.targetTheta-this.theta)*o,this.phi+=(this.targetPhi-this.phi)*o,this.radius+=(this.targetRadius-this.radius)*(1-Math.pow(this.radiusSmoothness,t))}}#t(t,i,o){let h=Math.hypot(t,i)/(1-o);return 1/(1+h*h)}#A(t,i,o,C,h){let f=t-o,d=i-C,w=Math.hypot(f,d);if(w<=h)return{theta:t,phi:i};{let F=h/w;return{theta:o+f*F,phi:C+d*F}}}getParams(){return{viewMat:this.getViewMatrix(),fov:this.fov,baseTheta:this.baseTheta,basePhi:this.basePhi,theta:this.theta,phi:this.phi,radius:this.radius,minRadius:this.minRadius,maxRadius:this.maxRadius,targetX:this.targetX,targetY:this.targetY,targetZ:this.targetZ,sens:this.sens,scrollSens:this.scrollSens,resistance:this.resistance,deadZone:this.deadZone,snapSmoothness:this.snapSmoothness,valueSmoothness:this.valueSmoothness,radiusSmoothness:this.radiusSmoothness,startRotating:this.mouseDown,mouseX:this.mouseX,mouseY:this.mouseY}}},TA=class extends mA{constructor(t={}){super(),this.screenPos=t.screenPos||[0,0,1],this.screenTarget=t.screenTarget||[0,0,0],this.screenScale=t.screenScale||1,this.eyePosWorld=t.eyePosWorld||[0,0,1],this.worldToVoxelScale=t.worldToVoxelScale||1,this.screenTransform=G.invert(G.create(),G.lookAt(G.create(),this.screenPos,this.screenTarget,[0,1,0]))}getViewMatrix(t){return this.#t(t).view}getProjMatrix(t){return this.#t(t).proj}#t(t){var C=t>1?1:t,h=t>1?1/t:1;C*=this.screenScale,h*=this.screenScale;let f=c.transformMat4(c.create(),c.fromValues(-C,-h,0),this.screenTransform),d=c.transformMat4(c.create(),c.fromValues(C,-h,0),this.screenTransform),w=c.transformMat4(c.create(),c.fromValues(-C,h,0),this.screenTransform),F=c.scale(c.create(),this.eyePosWorld,this.worldToVoxelScale);F[1]+=h,F[2]=Math.max(F[2],1e-4);let l=c.transformMat4(c.create(),F,this.screenTransform),v=c.sub(c.create(),d,f),J=c.sub(c.create(),w,f),P=c.sub(c.create(),f,l),L=c.sub(c.create(),d,l),O=c.sub(c.create(),w,l);v=c.normalize(c.create(),v),J=c.normalize(c.create(),J);let S=c.scale(c.create(),c.cross(c.create(),v,J),1),X=-c.dot(P,S),V=c.dot(v,P)*.01/X,z=c.dot(v,L)*.01/X,M=c.dot(J,P)*.01/X,R=c.dot(J,O)*.01/X,m=G.create();m[0]=2*.01/(z-V),m[4]=0,m[8]=(z+V)/(z-V),m[12]=0,m[1]=0,m[5]=2*.01/(R-M),m[9]=(R+M)/(R-M),m[13]=0,m[2]=0,m[6]=0,m[10]=(100+.01)/(.01-100),m[14]=200*.01/(.01-100),m[3]=0,m[7]=0,m[11]=-1,m[15]=0;let p=G.create();p[0]=v[0],p[4]=v[1],p[8]=v[2],p[12]=0,p[1]=J[0],p[5]=J[1],p[9]=J[2],p[13]=0,p[2]=S[0],p[6]=S[1],p[10]=S[2],p[14]=0,p[3]=0,p[7]=0,p[11]=0,p[15]=1;let QA=G.translate(G.create(),G.identity(G.create()),c.scale(c.create(),l,-1));return{view:G.mul(G.create(),p,QA),proj:m}}getParams(){return{screenPos:this.screenPos,screenTarget:this.screenTarget,screenScale:this.screenScale,eyePosWorld:this.eyePosWorld,worldToVoxelScale:this.worldToVoxelScale,startRotating:this.mouseDown,mouseX:this.mouseX,mouseY:this.mouseY}}};var Be=class extends HTMLElement{constructor(){super();let t=this.attachShadow({mode:"open"});xA.then(o=>{this.#t=o,this.#v()});let i=document.createElement("div");i.style.position="relative",i.style.width="100%",i.style.height="100%",i.style.overflow="hidden",t.appendChild(i),this.#A=document.createElement("canvas"),Object.assign(this.#A.style,{width:"100%",height:"100%",display:"block"}),i.appendChild(this.#A),this.#o=document.createElement("div"),Object.assign(this.#o.style,{position:"absolute",display:"none",top:"1%",left:"1%",color:"white",background:"rgba(0,0,0,0.4)",padding:"8px 8px",fontFamily:"monospace",fontSize:"12px",borderRadius:"8px",backdropFilter:"blur(6px)",whiteSpace:"pre",pointerEvents:"none",userSelect:"none"}),i.appendChild(this.#o),this.#E=document.createElement("div"),Object.assign(this.#E.style,{position:"absolute",bottom:"1%",left:"50%",transform:"translateX(-50%)",display:"none",alignItems:"center",justifyContent:"center",gap:"8px",background:"rgba(0, 0, 0, 0.4)",padding:"8px 8px",borderRadius:"8px",backdropFilter:"blur(6px)",boxSizing:"border-box",width:"50%",flexWrap:"wrap"}),i.appendChild(this.#E),this.#n=document.createElement("button"),this.#n.type="button",Object.assign(this.#n.style,{border:"none",background:"transparent",color:"white",fontSize:"24px",cursor:"pointer",padding:"4px",flexShrink:"0"}),this.#n.addEventListener("click",()=>{this.#Q=!this.#Q,this.#a.length==1&&this.#s>=this.#a[0].metadata.duration&&(this.#s=0)}),this.#E.appendChild(this.#n),this.#r=document.createElement("input"),this.#r.type="range",this.#r.min=0,this.#r.max=1,this.#r.step=.001,this.#r.value=0,Object.assign(this.#r.style,{flex:"1 1 auto",minWidth:"120px",maxWidth:"100%",cursor:"pointer",accentColor:"#fff"}),this.#I=!1,this.#r.addEventListener("input",()=>{this.#s=parseFloat(this.#r.value)}),this.#r.addEventListener("pointerdown",()=>{this.#I=!0}),this.#r.addEventListener("pointerup",()=>{this.#I=!1}),this.#E.appendChild(this.#r)}connectedCallback(){this.#C=new Qt(this.#A),this.#g=new cA,this.#g.attachToCanvas(this.#A),this.#d=new ResizeObserver(t=>{let i=t[0],o=Math.round(i.contentBoxSize[0].inlineSize*window.devicePixelRatio),C=Math.round(i.contentBoxSize[0].blockSize*window.devicePixelRatio),h=i.target;h.width=o,h.height=C,this.#C.resize()}),this.clear(),this.#C.initialize().then(()=>{this.#d.observe(this.#A),requestAnimationFrame(t=>{this.#w(t)})})}disconnectedCallback(){this.#g.detachFromCanvas(),this.#d.disconnect()}static get observedAttributes(){return["src","scene","camera","background-color","loop","autoplay","controls","debug"]}attributeChangedCallback(t,i,o){if(i!==o)switch(t){case"src":{o==null?this.#h(null):this.#m(o).then(C=>{this.#F(()=>{o.endsWith(".ply")?this.#h(this.#t.loadPly(C)):this.#h(this.#t.decode(C))})});break}case"scene":{o==null?this.#p(null):this.#m(o).then(C=>{this.#F(()=>{o.endsWith(".ply")?this.#p(this.#t.loadPly(C)):this.#p(this.#t.decode(C)),this.#B=!0})});break}case"camera":{let C="default",h={};try{h=JSON.parse(o),C=h.type}catch{}this.setCamera(C,h);break}case"background-color":{try{let C=this.getAttribute("background-color").split(" ").map(h=>Number(h)/255);C.length===3&&(this.#i.backgroundColor=C)}catch{}break}case"loop":this.#c=this.hasAttribute("loop");break;case"autoplay":this.#f=this.hasAttribute("autoplay");break;case"controls":this.#D=this.hasAttribute("controls");break;case"debug":this.#u=this.hasAttribute("debug");break;default:break}}play(){this.#Q=!0}pause(){this.#Q=!1}enqueue(t){this.#F(()=>{this.#a.push(this.#t.decode(t))})}clear(){this.#F(()=>{this.#a=[{gaussians:new this.#t.Gaussians,metadata:{duration:0}}],this.#B=!0})}setCamera(t,i){this.#g.detachFromCanvas(),t==="default"?this.#g=new cA(i):t==="snap"?this.#g=new _A(i):t==="window"?this.#g=new TA(i):(console.warn("Invalid camera provided, defaulting to 'default'"),this.#g=new cA),this.#g.attachToCanvas(this.#A)}get paused(){return!this.#Q}get currentTime(){return this.#s}set currentTime(t){let i=this.#a[0].metadata.duration;if(t<0||t>i){console.warn("Setting out-of-bounds currentTime");return}this.#s=t}get currentSegment(){return this.#a[0]}#t=null;#A=null;#C=null;#g=null;#d=null;#c=!1;#f=!1;#D=!1;#u=!1;#i={};#a=[];#B=!1;#e=null;#s=0;#I=!1;#Q=!1;#E=null;#n=null;#r=null;#o=null;#w(t){t/=1e3;var i=0;this.#e&&(i=t-this.#e),this.#Q&&!this.#I&&(this.#s+=i);let o=this.#a[0],C=o.metadata.duration,h=!1;for(;this.#s>=C&&this.#a.length>1;)C>0&&this.onSegmentEnd?.(!1),this.#s-=C,this.#a.shift(),o=this.#a[0],C=o.metadata.duration,h=!0;(h||this.#B)&&(this.#C.setGaussians(o.gaussians),this.#B=!1),this.#c?this.#s%=C>0?C:1:this.#s>C&&(C>0&&this.onSegmentEnd?.(!0),this.#s=C,this.#Q=!1);let f=this.#D&&C>0;Object.assign(this.#E.style,{display:f?"flex":"none"}),this.#n.textContent=this.#Q?"\u23F8\uFE0F":"\u25B6\uFE0F",this.#r.max=C,!this.#I&&this.#r&&(this.#r.value=this.#s),this.#e=t,this.#g.update(i*1e3);let d=this.#g.getViewMatrix(this.#A.width/this.#A.height),w=this.#g.getProjMatrix(this.#A.width/this.#A.height),F=this.#s/(C>0?C:1);this.#C.draw(d,w,F,this.#i,this.#u);let l=this.#C.getPerformanceProfile();Object.assign(this.#o.style,{display:this.#u?"flex":"none"}),this.#o.textContent=`Frame Time: ${this.#y(l.totalTime)}
374
- - Preprocess: ${this.#y(l.preprocessTime)}
375
- - Raster: ${this.#y(l.rasterTime)}
376
- Last Sort Time: ${this.#y(l.lastSortTime)}`,requestAnimationFrame(v=>{this.#w(v)})}#h(t){this.#a=[t],this.#s=0,this.#Q=this.#f,this.#B=!0}#p(t){this.#C.setScene(t.gaussians)}async#m(t){let i=await fetch(t);if(!i.ok)throw new Error("Failed to fetch buffer at "+t);return await i.arrayBuffer()}#y(t){return(t?.toFixed(2)??"N/A")+" ms"}#N=Promise.resolve();#v=null;#R=new Promise(t=>this.#v=t);#F(t){return this.#N=this.#N.then(async()=>(await this.#R,await t()),i=>{throw console.error("Enqueuing call failed: ",i),i}),this.#N}};customElements.define("dgs-player",Be);export{Be as DGSPlayer};
422
+ }`;var H=Float32Array.BYTES_PER_ELEMENT,eA=Uint32Array.BYTES_PER_ELEMENT,st=64,GA=4,pi=.001,yi=.001,Gi=0,se=class{constructor(t){this.#t=t}async initialize(){this.#r=await TA,this.#A=await ie,this.#I=await _A,this.#d=this.#G(),this.#h=this.#m(),this.#f=this.#N(),this.#D=this.#p(),this.#l=this.#F(),this.#C=this.#k(),this.#a=this.#y(),this.#I.features.has("timestamp-query")&&(this.#g=this.#v())}resize(){this.#h=this.#m()}setGaussians(t){this.#s=this.#B?this.#r.combine(t,this.#B):t,this.#e=this.#Y(this.#s);let i=new yA(this.#s,(C,o)=>{this.#E=!1,this.#o==i&&(this.#b(C),this.#i=!0,this.#n.lastSortTime=o)});this.#i=!1,this.#c=null,this.#o=i}setScene(t){this.#B=t}setPointSize(t){this.#w=t}draw(t,i,C,o={},h=!1){if(!this.#s||(this.#g==null&&(h=!1),!this.#E&&this.#U(t,C)&&(this.#E=!0,this.#o.sort(t,i,C),this.#c={view:t.slice(),time:C}),!this.#i))return;let D=performance.now();var d=0;this.#u&&(d=D-this.#u),this.#u=D;let p=re.transformMat4(re.create(),re.fromValues(0,0,0),Bt.invert(Bt.create(),t)),y=[i[0]*(this.#t.width/2),i[5]*(this.#t.height/2)],l=[this.#t.width,this.#t.height];this.#M(t,i,p,y,l,C);let N=this.#S(),J=null,_=null;h&&(J=this.#A.createBuffer({size:GA*8,usage:GPUBufferUsage.QUERY_RESOLVE|GPUBufferUsage.COPY_SRC}),_=this.#A.createBuffer({size:GA*8,usage:GPUBufferUsage.COPY_DST|GPUBufferUsage.MAP_READ}));let W=this.#A.createCommandEncoder(),X=W.beginComputePass({timestampWrites:h?{querySet:this.#g.querySet,beginningOfPassWriteIndex:0,endOfPassWriteIndex:1}:void 0});X.setPipeline(this.#f),X.setBindGroup(0,N.preprocess),this.#Q>0&&X.dispatchWorkgroups(Math.ceil(this.#Q/st)),X.end();let S=W.beginRenderPass({label:"main",colorAttachments:[{view:this.#h.view,clearValue:{r:0,g:0,b:0,a:0},loadOp:"clear",storeOp:"store"}],timestampWrites:h?{querySet:this.#g.querySet,beginningOfPassWriteIndex:2,endOfPassWriteIndex:3}:void 0});S.setPipeline(this.#D),S.setVertexBuffer(0,this.#C.vertex),S.setIndexBuffer(this.#C.index,"uint16"),S.setBindGroup(0,N.rasterize),this.#Q>0&&S.drawIndexed(6,this.#Q),S.end();let V=o.backgroundColor??[0,0,0],z=W.beginRenderPass({label:"composite",colorAttachments:[{view:this.#d.getCurrentTexture().createView(),clearValue:{r:V[0],g:V[1],b:V[2],a:1},loadOp:"clear",storeOp:"store"}]});z.setPipeline(this.#l),z.setBindGroup(0,N.composite),z.draw(3),z.end(),h&&(W.resolveQuerySet(this.#g.querySet,0,GA,J,0),W.copyBufferToBuffer(J,0,_,0,GA*8)),this.#A.queue.submit([W.finish()]),h&&_.mapAsync(GPUMapMode.READ).then(()=>{let j=_.getMappedRange(),U=new BigUint64Array(j);if(this.#g.accumFrames++,this.#g.accumTime+=d,this.#g.accumPreprocessTime+=Number(U[1]-U[0]),this.#g.accumRasterTime+=Number(U[3]-U[2]),_.unmap(),this.#g.accumTime>=1e3){let v=this.#g.accumPreprocessTime/1e6/this.#g.accumFrames,m=this.#g.accumRasterTime/1e6/this.#g.accumFrames,G=v+m;this.#n.preprocessTime=v,this.#n.rasterTime=m,this.#n.totalTime=G,this.#g.accumFrames=0,this.#g.accumTime=0,this.#g.accumPreprocessTime=0,this.#g.accumRasterTime=0}})}getPerformanceProfile(){return this.#n}#r=null;#A=null;#I=null;#t=null;#d=null;#h=null;#f=null;#D=null;#l=null;#g=null;#B=null;#s=null;#w=null;#e=null;#C=null;#a=null;#Q=0;#o=null;#i=!1;#E=!1;#c=null;#u=null;#n={};#G(){let t=this.#t.getContext("webgpu");return t.configure({device:this.#A,format:navigator.gpu.getPreferredCanvasFormat(),alphaMode:"opaque"}),t}#m(){let t=this.#t.width|0,i=this.#t.height|0;if(t==0||i==0)return;let C=navigator.gpu.getPreferredCanvasFormat(),o=this.#A.createTexture({size:[t,i,1],format:C,usage:GPUTextureUsage.RENDER_ATTACHMENT|GPUTextureUsage.TEXTURE_BINDING});return{tex:o,view:o.createView(),sampler:this.#A.createSampler({magFilter:"linear",minFilter:"linear"})}}#N(){let t=this.#A.createShaderModule({label:"gaussian preprocess",code:gt});return this.#A.createComputePipeline({label:"gaussian preprocess",layout:"auto",compute:{module:t,entryPoint:"preprocess",constants:{WORKGROUP_SIZE:st}}})}#p(){let t=this.#A.createShaderModule({label:"gaussian rasterize",code:it});return this.#A.createRenderPipeline({label:"gaussian",layout:"auto",vertex:{module:t,entryPoint:"vs",buffers:[{stepMode:"vertex",arrayStride:2*H,attributes:[{shaderLocation:0,offset:0,format:"float32x2"}]}]},fragment:{module:t,entryPoint:"fs",targets:[{format:navigator.gpu.getPreferredCanvasFormat(),blend:{alpha:{srcFactor:"one-minus-dst-alpha",dstFactor:"one",operation:"add"},color:{srcFactor:"one-minus-dst-alpha",dstFactor:"one",operation:"add"}}}]},primitive:{topology:"triangle-list",cullMode:"none"}})}#F(){let t=this.#A.createShaderModule({label:"composite",code:rt});return this.#A.createRenderPipeline({label:"composite",layout:"auto",vertex:{module:t,entryPoint:"vs"},fragment:{module:t,entryPoint:"fs",targets:[{format:navigator.gpu.getPreferredCanvasFormat(),blend:{color:{srcFactor:"src-alpha",dstFactor:"one-minus-src-alpha",operation:"add"},alpha:{srcFactor:"one",dstFactor:"one-minus-src-alpha",operation:"add"}}}]},primitive:{topology:"triangle-list",cullMode:"none"}})}#v(){return{querySet:this.#A.createQuerySet({type:"timestamp",count:GA}),accumFrames:0,accumTime:0,accumRasterTime:0,accumPreprocessTime:0}}#k(){let t=new Float32Array([-2,-2,2,-2,2,2,-2,2]),i=this.#A.createBuffer({label:"quad vertices",size:t.byteLength,usage:GPUBufferUsage.VERTEX|GPUBufferUsage.COPY_DST});this.#A.queue.writeBuffer(i,0,t);let C=new Uint16Array([0,1,2,0,2,3]),o=this.#A.createBuffer({label:"quad indices",size:C.byteLength,usage:GPUBufferUsage.INDEX|GPUBufferUsage.COPY_DST});return this.#A.queue.writeBuffer(o,0,C),{vertex:i,index:o}}#y(){let t=0;return t+=16*H,t+=16*H,t+=3*H,t+=1*H,t+=2*H,t+=2*H,t+=1*H,t+=1*eA,t+=1*eA,t+=1*eA,t+=2*H,t+=2*H,t+=2*H,t+=2*eA,this.#A.createBuffer({label:"params",size:t,usage:GPUBufferUsage.UNIFORM|GPUBufferUsage.COPY_DST})}#Y(t){let i={};return[{name:"means",alignment:4*H},{name:"scales",alignment:eA},{name:"rotations",alignment:eA},{name:"opacities",alignment:eA},{name:"colors",alignment:eA},{name:"shs",alignment:eA},{name:"velocities",alignment:4*H}].forEach(o=>{i[o.name]=this.#R(this.#e?.[o.name],{label:o.name,size:this.#J(t[o.name].byteLength,o.alignment),usage:GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_DST}),this.#x(i[o.name],t[o.name])}),i.sortedIndices=this.#R(this.#e?.sortedIndices,{label:"sorted indices",size:Math.max(t.length,1)*eA,usage:GPUBufferUsage.COPY_DST|GPUBufferUsage.STORAGE}),i.rendered=this.#R(this.#e?.rendered,{label:"rendered gaussians",size:Math.max(t.length,1)*12*H,usage:GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_DST|GPUBufferUsage.INDIRECT}),i}#M(t,i,C,o,h,D){let d=new ArrayBuffer(this.#a.size),p=new Float32Array(d),y=new Uint32Array(d),l=0;p.set(t,l),l+=16,p.set(i,l),l+=16,p.set(C,l),l+=3,p.set([D],l),l+=1,p.set(o,l),l+=2,p.set(h,l),l+=2,p.set([this.#w??0],l),l+=1,y.set([this.#Q],l),l+=1,y.set([Number(this.#s.dynamic)],l),l+=1,y.set([this.#s.shDegree],l),l+=1,p.set([this.#s.scaleMin,this.#s.scaleMax],l),l+=2,p.set([this.#s.colorMin,this.#s.colorMax],l),l+=2,p.set([this.#s.shMin,this.#s.shMax],l),l+=2,this.#A.queue.writeBuffer(this.#a,0,d)}#S(){let t=this.#A.createBindGroup({label:"gaussian preprocess",layout:this.#f.getBindGroupLayout(0),entries:[{binding:0,resource:{buffer:this.#a}},{binding:1,resource:{buffer:this.#e.means}},{binding:2,resource:{buffer:this.#e.scales}},{binding:3,resource:{buffer:this.#e.rotations}},{binding:4,resource:{buffer:this.#e.opacities}},{binding:5,resource:{buffer:this.#e.colors}},{binding:6,resource:{buffer:this.#e.shs}},{binding:7,resource:{buffer:this.#e.velocities}},{binding:8,resource:{buffer:this.#e.sortedIndices}},{binding:9,resource:{buffer:this.#e.rendered}}]}),i=this.#A.createBindGroup({label:"gaussian rasterize",layout:this.#D.getBindGroupLayout(0),entries:[{binding:0,resource:{buffer:this.#a}},{binding:1,resource:{buffer:this.#e.rendered}}]}),C=this.#A.createBindGroup({label:"composite",layout:this.#l.getBindGroupLayout(0),entries:[{binding:0,resource:this.#h.view},{binding:1,resource:this.#h.sampler}]});return{preprocess:t,rasterize:i,composite:C}}#U(t,i){if(this.#c==null)return!0;let C=this.#c.view,o=[t[2],t[6],t[10]],h=[t[12],t[13],t[14]],D=[C[2],C[6],C[10]],d=[C[12],C[13],C[14]],p=1-(o[0]*D[0]+o[1]*D[1]+o[2]*D[2]),y=Math.pow(h[0]-d[0],2)+Math.pow(h[1]-d[1],2)+Math.pow(h[2]-d[2],2),l=Math.abs(i-this.#c.time);return p>pi||y>yi||l>Gi}#b(t){this.#Q=t.length,this.#A.queue.writeBuffer(this.#e.sortedIndices,0,t)}#R(t,i){return t==null||t.size<i.size?(t?.destroy(),this.#A.createBuffer(i)):t}#x(t,i){let C,o,h;i instanceof ArrayBuffer?(C=i,o=0,h=i.byteLength):(C=i.buffer,o=i.byteOffset,h=i.byteLength);let D=h&-4;D>0&&this.#A.queue.writeBuffer(t,0,C,o,D);let d=h-D;if(d>0){let p=new Uint8Array(4);p.set(new Uint8Array(C,o+D,d)),this.#A.queue.writeBuffer(t,D,p,0,4)}}#J(t,i){return t==0?i:t+i-1&~(i-1)}},at=se;import{mat4 as Y,vec3 as c}from"gl-matrix";var mA=class R{constructor(){if(new.target===R)throw new Error("Cannot instantiate abstract class Camera directly");this.keysPressed=new Set,this.mouseDown=!1,this.mouseX=0,this.mouseY=0}getViewMatrix(){return null}getProjMatrix(t){let i=this.fov||80;return Y.perspective(Y.create(),i*Math.PI/180,t,.01,100)}getParams(){return{}}onMouseDown(t){t.button===0&&(this.mouseDown=!0)}onMouseUp(t){t.button===0&&(this.mouseDown=!1)}onMouseMove(t){this.mouseX=t.clientX,this.mouseY=t.clientY}onDoubleClick(t){}onScroll(t){}onTouchStart(t){t.touches.length===1&&(this.mouseDown=!0),this.mouseX=t.touches[0].clientX,this.mouseY=t.touches[0].clientY}onTouchEnd(t){t.touches.length===1&&(this.mouseDown=!1)}onTouchMove(t){this.mouseX=t.touches[0].clientX,this.mouseY=t.touches[0].clientY}onKeyDown(t){this.keysPressed.add(t.code)}onKeyUp(t){this.keysPressed.delete(t.code)}update(t){}_editingSomething(){let t=document.activeElement;return t&&(t.tagName==="INPUT"||t.tagName==="TEXTAREA"||t.isContentEditable)}attachToCanvas(t){this._onMouseDown=i=>this.onMouseDown(i),this._onMouseUp=i=>this.onMouseUp(i),this._onMouseMove=i=>this.onMouseMove(i),this._onMouseLeave=i=>this.onMouseUp(i),this._onDoubleClick=i=>this.onDoubleClick(i),this._onWheel=i=>{this.onScroll!==R.prototype.onScroll&&i.preventDefault(),this.onScroll(i.deltaY)},this._onTouchStart=i=>{this.onTouchStart!=R.prototype.onTouchStart&&i.preventDefault(),this.onTouchStart(i)},this._onTouchMove=i=>{this.onTouchMove!=R.prototype.onTouchMove&&i.preventDefault(),this.onTouchMove(i)},this._onTouchEnd=i=>{this.onTouchEnd!=R.prototype.onTouchEnd&&i.preventDefault(),this.onTouchEnd(i)},this._onKeyDown=i=>{this._editingSomething()||(i.code==="Space"&&i.preventDefault(),this.onKeyDown(i))},this._onKeyUp=i=>{this._editingSomething()||(i.code==="Space"&&i.preventDefault(),this.onKeyUp(i))},t.addEventListener("mousedown",this._onMouseDown),t.addEventListener("mouseup",this._onMouseUp),t.addEventListener("mousemove",this._onMouseMove),t.addEventListener("mouseleave",this._onMouseLeave),t.addEventListener("dblclick",this._onDoubleClick),t.addEventListener("wheel",this._onWheel),t.addEventListener("touchstart",this._onTouchStart),t.addEventListener("touchmove",this._onTouchMove),t.addEventListener("touchend",this._onTouchEnd),window.addEventListener("keydown",this._onKeyDown),window.addEventListener("keyup",this._onKeyUp),this._canvas=t}detachFromCanvas(){this._canvas&&(this._canvas.removeEventListener("mousedown",this._onMouseDown),this._canvas.removeEventListener("mouseup",this._onMouseUp),this._canvas.removeEventListener("mousemove",this._onMouseMove),this._canvas.removeEventListener("mouseleave",this._onMouseLeave),this._canvas.removeEventListener("dblclick",this._onDoubleClick),this._canvas.removeEventListener("wheel",this._onWheel),this._canvas.removeEventListener("touchstart",this._onTouchStart),this._canvas.removeEventListener("touchmove",this._onTouchMove),this._canvas.removeEventListener("touchend",this._onTouchEnd),window.removeEventListener("keydown",this._onKeyDown),window.removeEventListener("keyup",this._onKeyUp),this._canvas=null)}},cA=class extends mA{constructor(t={}){super(),this.fov=t.fov||80,this.sens=t.sens||.003,this.panSens=t.panSens||.0025,this.scrollSens=t.scrollSens||.0025,this.keyMoveSpeed=t.keyMoveSpeed||.02,this.minRadius=t.minRadius||.5,this.maxRadius=t.maxRadius||3,this.targetRadius=t.radius||(this.minRadius+this.maxRadius)/2,this.radius=this.targetRadius,this.targetTheta=t.theta||0,this.theta=this.targetTheta,this.targetPhi=t.phi||0,this.phi=this.targetPhi,this.targetPos=c.fromValues(t.targetX||0,t.targetY||0,t.targetZ||0),this.pos=this.targetPos,this.mouseX=t.mouseX||0,this.mouseY=t.mouseY||0,this.rotating=t.startRotating||!1,this.dragging=t.startRotating||!1,this.pinchStartDistance=0}getViewMatrix(){let t=c.fromValues(this.pos[0]+this.radius*Math.sin(this.theta)*Math.cos(this.phi),this.pos[1]+this.radius*Math.sin(this.phi),this.pos[2]+this.radius*Math.cos(this.theta)*Math.cos(this.phi));return Y.lookAt(Y.create(),t,this.pos,c.fromValues(0,1,0))}getParams(){return{fov:this.fov,sens:this.sens,panSens:this.panSens,scrollSens:this.scrollSens,radius:this.radius,minRadius:this.minRadius,maxRadius:this.maxRadius,theta:this.theta,phi:this.phi,targetX:this.pos[0],targetY:this.pos[1],targetZ:this.pos[2],mouseX:this.mouseX,mouseY:this.mouseY,startRotating:this.rotating||this.dragging}}onMouseDown(t){if(t.button===0)this.rotating=!0;else return;this.mouseX=t.clientX,this.mouseY=t.clientY}onMouseUp(t){this.rotating=!1}onDoubleClick(t){this.targetRadius/=2}onMouseMove(t){if(this.rotating){let i=t.clientX-this.mouseX,C=t.clientY-this.mouseY;this.targetTheta+=i*this.sens,this.targetPhi-=C*this.sens,this.targetPhi=Math.max(this.targetPhi,-Math.PI/2+.01),this.targetPhi=Math.min(this.targetPhi,Math.PI/2-.01)}this.mouseX=t.clientX,this.mouseY=t.clientY}onScroll(t){this.targetRadius+=t*this.scrollSens,this.targetRadius=Math.max(this.targetRadius,this.minRadius),this.targetRadius=Math.min(this.targetRadius,this.maxRadius)}onTouchStart(t){if(t.touches.length===1)this.mouseX=t.touches[0].clientX,this.mouseY=t.touches[0].clientY,this.dragging=!0;else if(t.touches.length===2){this.dragging=!1;let i=t.touches[0],C=t.touches[1];this.pinchStartDistance=Math.hypot(C.clientX-i.clientX,C.clientY-i.clientY)}}onTouchMove(t){if(t.touches.length===1&&this.dragging){let i=t.touches[0],C=i.clientX-this.mouseX,o=i.clientY-this.mouseY;this.targetTheta+=C*this.sens,this.targetPhi-=o*this.sens,this.targetPhi=Math.max(this.targetPhi,-Math.PI/2),this.targetPhi=Math.min(this.targetPhi,Math.PI/2),this.mouseX=i.clientX,this.mouseY=i.clientY}else if(t.touches.length===2){let i=t.touches[0],C=t.touches[1],o=Math.hypot(C.clientX-i.clientX,C.clientY-i.clientY),h=this.pinchStartDistance-o;this.onScroll(h),this.pinchStartDistance=o}}onTouchEnd(t){t.touches.length===0?this.dragging=!1:t.touches.length===1&&(this.mouseX=t.touches[0].clientX,this.mouseY=t.touches[0].clientY)}update(t){super.update(t);let i=1-Math.pow(.99,t);this.pos=c.add(c.create(),this.pos,c.scale(c.create(),c.sub(c.create(),this.targetPos,this.pos),i)),this.radius+=(this.targetRadius-this.radius)*i,this.theta+=(this.targetTheta-this.theta)*i,this.phi+=(this.targetPhi-this.phi)*i,this.keysPressed.size>0&&this.handleKeyboardMovement(t)}handleKeyboardMovement(t){let i=this.keyMoveSpeed*(t/16.67),C=Math.cos(this.targetTheta),o=-Math.sin(this.targetTheta),h=-Math.sin(this.targetTheta),D=-Math.cos(this.targetTheta),d=0,p=0,y=0;this.keysPressed.has("KeyW")&&(d+=h,y+=D),this.keysPressed.has("KeyS")&&(d-=h,y-=D),this.keysPressed.has("KeyA")&&(d+=C,y+=o),this.keysPressed.has("KeyD")&&(d-=C,y-=o),this.keysPressed.has("Space")&&(p-=1),this.keysPressed.has("ShiftLeft")&&(p+=1),this.targetPos=c.add(c.create(),this.targetPos,c.scale(c.create(),c.normalize(c.create(),c.fromValues(d,p,y)),i))}},LA=class extends mA{constructor(t={}){super(),this.fov=t.fov||80,this.baseTheta=t.baseTheta||Math.PI/4,this.basePhi=t.basePhi||Math.PI/4,this.targetTheta=t.theta||this.baseTheta,this.targetPhi=t.phi||this.basePhi,this.targetRadius=t.radius||1.5,this.theta=this.targetTheta,this.phi=this.targetPhi,this.radius=this.targetRadius,this.minRadius=t.minRadius||.5,this.maxRadius=t.maxRadius||3,this.targetX=t.targetX||0,this.targetY=t.targetY||0,this.targetZ=t.targetZ||0,this.sens=t.sens||.003,this.scrollSens=t.scrollSens||.0025,this.resistance=t.resistance||.25,this.deadZone=t.deadZone||.1,this.snapSmoothness=t.snapSmoothness||.9925,this.valueSmoothness=t.valueSmoothness||.9925,this.radiusSmoothness=t.radiusSmoothness||.99,this.mouseX=t.mouseX||0,this.mouseY=t.mouseY||0,this.rotating=t.startRotating||!1,this.pinchStartDistance=0,this.canvas=null}attachToCanvas(t){super.attachToCanvas(t),this.canvas=t}getViewMatrix(){let t=this.targetX+this.radius*Math.sin(this.theta)*Math.cos(this.phi),i=this.targetY+this.radius*Math.sin(this.phi),C=this.targetZ+this.radius*Math.cos(this.theta)*Math.cos(this.phi);return Y.lookAt(Y.create(),c.fromValues(t,i,C),c.fromValues(this.targetX,this.targetY,this.targetZ),c.fromValues(0,1,0))}onMouseDown(t){t.button===0&&(this.rotating=!0,this.mouseX=t.clientX,this.mouseY=t.clientY,this.targetTheta=this.theta,this.targetPhi=this.phi,this.targetRadius=this.radius)}onMouseUp(t){t.button===0&&(this.rotating=!1)}onMouseMove(t){if(!this.rotating){this.mouseX=t.clientX,this.mouseY=t.clientY;return}let i=t.clientX-this.mouseX,C=t.clientY-this.mouseY,o=this.targetTheta-this.baseTheta,h=this.targetPhi-this.basePhi,D=this.#r(o,h,this.resistance);this.targetTheta+=i*this.sens*D,this.targetPhi-=C*this.sens*D,this.targetPhi=Math.max(this.targetPhi,-Math.PI/2+.01),this.targetPhi=Math.min(this.targetPhi,Math.PI/2-.01),this.mouseX=t.clientX,this.mouseY=t.clientY}onScroll(t){this.targetRadius+=t*this.scrollSens,this.targetRadius=Math.max(this.targetRadius,this.minRadius),this.targetRadius=Math.min(this.targetRadius,this.maxRadius)}onTouchStart(t){if(t.touches.length===1){let i=t.touches[0];this.rotating=!0,this.mouseX=i.clientX,this.mouseY=i.clientY}else if(t.touches.length===2){this.rotating=!1;let i=t.touches[0],C=t.touches[1];this.pinchStartDistance=Math.hypot(C.clientX-i.clientX,C.clientY-i.clientY)}}onTouchMove(t){if(t.touches.length===1&&this.rotating){let i=t.touches[0],C=i.clientX-this.mouseX,o=i.clientY-this.mouseY,h=this.targetTheta-this.baseTheta,D=this.targetPhi-this.basePhi,d=this.#r(h,D,this.resistance);this.targetTheta+=C*this.sens*d,this.targetPhi-=o*this.sens*d,this.targetPhi=Math.max(this.targetPhi,-Math.PI/2+.01),this.targetPhi=Math.min(this.targetPhi,Math.PI/2-.01),this.mouseX=i.clientX,this.mouseY=i.clientY}else if(t.touches.length===2){let i=t.touches[0],C=t.touches[1],o=Math.hypot(C.clientX-i.clientX,C.clientY-i.clientY),h=this.pinchStartDistance-o;this.onScroll(h),this.pinchStartDistance=o}}onTouchEnd(t){if(t.touches.length===0)this.rotating=!1;else if(t.touches.length===1){let i=t.touches[0];this.mouseX=i.clientX,this.mouseY=i.clientY}}update(t){super.update(t);let i=1-Math.pow(this.snapSmoothness,t),C=1-Math.pow(this.valueSmoothness,t);if(this.rotating)this.theta=this.targetTheta,this.phi=this.targetPhi,this.radius=this.targetRadius;else{let o=this.#A(this.targetTheta,this.targetPhi,this.baseTheta,this.basePhi,this.deadZone);this.targetTheta+=(o.theta-this.targetTheta)*i,this.targetPhi+=(o.phi-this.targetPhi)*i,this.theta+=(this.targetTheta-this.theta)*C,this.phi+=(this.targetPhi-this.phi)*C,this.radius+=(this.targetRadius-this.radius)*(1-Math.pow(this.radiusSmoothness,t))}}#r(t,i,C){let h=Math.hypot(t,i)/(1-C);return 1/(1+h*h)}#A(t,i,C,o,h){let D=t-C,d=i-o,p=Math.hypot(D,d);if(p<=h)return{theta:t,phi:i};{let y=h/p;return{theta:C+D*y,phi:o+d*y}}}getParams(){return{viewMat:this.getViewMatrix(),fov:this.fov,baseTheta:this.baseTheta,basePhi:this.basePhi,theta:this.theta,phi:this.phi,radius:this.radius,minRadius:this.minRadius,maxRadius:this.maxRadius,targetX:this.targetX,targetY:this.targetY,targetZ:this.targetZ,sens:this.sens,scrollSens:this.scrollSens,resistance:this.resistance,deadZone:this.deadZone,snapSmoothness:this.snapSmoothness,valueSmoothness:this.valueSmoothness,radiusSmoothness:this.radiusSmoothness,startRotating:this.mouseDown,mouseX:this.mouseX,mouseY:this.mouseY}}},PA=class extends mA{constructor(t={}){super(),this.screenPos=t.screenPos||[0,0,1],this.screenTarget=t.screenTarget||[0,0,0],this.screenScale=t.screenScale||1,this.eyePosWorld=t.eyePosWorld||[0,0,1],this.worldToVoxelScale=t.worldToVoxelScale||1,this.screenTransform=Y.invert(Y.create(),Y.lookAt(Y.create(),this.screenPos,this.screenTarget,[0,1,0]))}getViewMatrix(t){return this.#r(t).view}getProjMatrix(t){return this.#r(t).proj}#r(t){var o=t>1?1:t,h=t>1?1/t:1;o*=this.screenScale,h*=this.screenScale;let D=c.transformMat4(c.create(),c.fromValues(-o,-h,0),this.screenTransform),d=c.transformMat4(c.create(),c.fromValues(o,-h,0),this.screenTransform),p=c.transformMat4(c.create(),c.fromValues(-o,h,0),this.screenTransform),y=c.scale(c.create(),this.eyePosWorld,this.worldToVoxelScale);y[1]+=h,y[2]=Math.max(y[2],1e-4);let l=c.transformMat4(c.create(),y,this.screenTransform),N=c.sub(c.create(),d,D),J=c.sub(c.create(),p,D),_=c.sub(c.create(),D,l),W=c.sub(c.create(),d,l),X=c.sub(c.create(),p,l);N=c.normalize(c.create(),N),J=c.normalize(c.create(),J);let S=c.scale(c.create(),c.cross(c.create(),N,J),1),V=-c.dot(_,S),z=c.dot(N,_)*.01/V,j=c.dot(N,W)*.01/V,U=c.dot(J,_)*.01/V,v=c.dot(J,X)*.01/V,m=Y.create();m[0]=2*.01/(j-z),m[4]=0,m[8]=(j+z)/(j-z),m[12]=0,m[1]=0,m[5]=2*.01/(v-U),m[9]=(v+U)/(v-U),m[13]=0,m[2]=0,m[6]=0,m[10]=(100+.01)/(.01-100),m[14]=200*.01/(.01-100),m[3]=0,m[7]=0,m[11]=-1,m[15]=0;let G=Y.create();G[0]=N[0],G[4]=N[1],G[8]=N[2],G[12]=0,G[1]=J[0],G[5]=J[1],G[9]=J[2],G[13]=0,G[2]=S[0],G[6]=S[1],G[10]=S[2],G[14]=0,G[3]=0,G[7]=0,G[11]=0,G[15]=1;let QA=Y.translate(Y.create(),Y.identity(Y.create()),c.scale(c.create(),l,-1));return{view:Y.mul(Y.create(),G,QA),proj:m}}getParams(){return{screenPos:this.screenPos,screenTarget:this.screenTarget,screenScale:this.screenScale,eyePosWorld:this.eyePosWorld,worldToVoxelScale:this.worldToVoxelScale,startRotating:this.mouseDown,mouseX:this.mouseX,mouseY:this.mouseY}}};var Be=class extends HTMLElement{constructor(){super();let t=this.attachShadow({mode:"open"});TA.then(C=>{this.#r=C,this.#v()});let i=document.createElement("div");i.style.position="relative",i.style.width="100%",i.style.height="100%",i.style.overflow="hidden",t.appendChild(i),this.#A=document.createElement("canvas"),Object.assign(this.#A.style,{width:"100%",height:"100%",display:"block"}),i.appendChild(this.#A),this.#E=document.createElement("div"),Object.assign(this.#E.style,{position:"absolute",display:"none",top:"1%",left:"1%",color:"white",background:"rgba(0,0,0,0.4)",padding:"8px 8px",fontFamily:"monospace",fontSize:"12px",borderRadius:"8px",backdropFilter:"blur(6px)",whiteSpace:"pre",pointerEvents:"none",userSelect:"none"}),i.appendChild(this.#E),this.#Q=document.createElement("div"),Object.assign(this.#Q.style,{position:"absolute",bottom:"1%",left:"50%",transform:"translateX(-50%)",display:"none",alignItems:"center",justifyContent:"center",gap:"8px",background:"rgba(0, 0, 0, 0.4)",padding:"8px 8px",borderRadius:"8px",backdropFilter:"blur(6px)",boxSizing:"border-box",width:"50%",flexWrap:"wrap"}),i.appendChild(this.#Q),this.#o=document.createElement("button"),this.#o.type="button",Object.assign(this.#o.style,{border:"none",background:"transparent",color:"white",fontSize:"24px",cursor:"pointer",padding:"4px",flexShrink:"0"}),this.#o.addEventListener("click",()=>{this.#a=!this.#a,this.#B.length==1&&this.#e>=this.#B[0].metadata.duration&&(this.#e=0)}),this.#Q.appendChild(this.#o),this.#i=document.createElement("input"),this.#i.type="range",this.#i.min=0,this.#i.max=1,this.#i.step=.001,this.#i.value=0,Object.assign(this.#i.style,{flex:"1 1 auto",minWidth:"120px",maxWidth:"100%",cursor:"pointer",accentColor:"#fff"}),this.#C=!1,this.#i.addEventListener("input",()=>{this.#e=parseFloat(this.#i.value)}),this.#i.addEventListener("pointerdown",()=>{this.#C=!0}),this.#i.addEventListener("pointerup",()=>{this.#C=!1}),this.#Q.appendChild(this.#i),this.#I=new at(this.#A),this.#t=new cA}connectedCallback(){this.#t.attachToCanvas(this.#A),this.#d=new ResizeObserver(t=>{let i=t[0],C=Math.round(i.contentBoxSize[0].inlineSize*window.devicePixelRatio),o=Math.round(i.contentBoxSize[0].blockSize*window.devicePixelRatio),h=i.target;h.width=C,h.height=o,this.#I.resize()}),this.clear(),this.#I.initialize().then(()=>{this.#d.observe(this.#A),requestAnimationFrame(t=>{this.#c(t)})})}disconnectedCallback(){this.#t.detachFromCanvas(),this.#d.disconnect()}static get observedAttributes(){return["src","scene","camera","background-color","loop","autoplay","controls","point-size","debug"]}attributeChangedCallback(t,i,C){if(i!==C)switch(t){case"src":{C==null?this.#u(null):this.#N(C).then(o=>{this.#y(()=>{C.endsWith(".ply")?this.#u(this.#m(o)):this.#u(this.#G(o))})});break}case"scene":{C==null?this.#n(null):this.#N(C).then(o=>{this.#y(()=>{C.endsWith(".ply")?this.#n(this.#m(o)):this.#n(this.#G(o)),this.#s=!0})});break}case"camera":{let o="default",h={};try{h=JSON.parse(C),o=h.type}catch{}this.setCamera(o,h);break}case"background-color":{try{let o=this.getAttribute("background-color").split(" ").map(h=>Number(h)/255);o.length===3&&(this.#g.backgroundColor=o)}catch{}break}case"loop":this.#h=this.hasAttribute("loop");break;case"autoplay":this.#f=this.hasAttribute("autoplay");break;case"controls":this.#D=this.hasAttribute("controls");break;case"point-size":this.#I.setPointSize(C);break;case"debug":this.#l=this.hasAttribute("debug");break;default:break}}play(){this.#a=!0}pause(){this.#a=!1}enqueue(t){this.#y(()=>{this.#B.push(this.#G(t))})}clear(){this.#y(()=>{this.#B=[{gaussians:new this.#r.Gaussians,metadata:{duration:0}}],this.#s=!0})}setCamera(t,i){this.#t.detachFromCanvas(),t==="default"?this.#t=new cA(i):t==="snap"?this.#t=new LA(i):t==="window"?this.#t=new PA(i):(console.warn("Invalid camera provided, defaulting to 'default'"),this.#t=new cA),this.#t.attachToCanvas(this.#A)}get paused(){return!this.#a}get currentTime(){return this.#e}set currentTime(t){let i=this.#B[0].metadata.duration;if(t<0||t>i){console.warn("Setting out-of-bounds currentTime");return}this.#e=t}get currentSegment(){return this.#B[0]}#r=null;#A=null;#I=null;#t=null;#d=null;#h=!1;#f=!1;#D=!1;#l=!1;#g={};#B=[];#s=!1;#w=null;#e=0;#C=!1;#a=!1;#Q=null;#o=null;#i=null;#E=null;#c(t){t/=1e3;var i=0;this.#w&&(i=t-this.#w),this.#a&&!this.#C&&(this.#e+=i);let C=this.#B[0],o=C.metadata.duration,h=!1;for(;this.#e>=o&&this.#B.length>1;)o>0&&this.onSegmentEnd?.(!1),this.#e-=o,this.#B.shift(),C=this.#B[0],o=C.metadata.duration,h=!0;(h||this.#s)&&(this.#I.setGaussians(C.gaussians),this.#s=!1),this.#h?this.#e%=o>0?o:1:this.#e>o&&(o>0&&this.onSegmentEnd?.(!0),this.#e=o,this.#a=!1);let D=this.#D&&o>0;Object.assign(this.#Q.style,{display:D?"flex":"none"}),this.#o.textContent=this.#a?"\u23F8\uFE0F":"\u25B6\uFE0F",this.#i.max=o,!this.#C&&this.#i&&(this.#i.value=this.#e),this.#w=t,this.#t.update(i*1e3);let d=this.#t.getViewMatrix(this.#A.width/this.#A.height),p=this.#t.getProjMatrix(this.#A.width/this.#A.height),y=this.#e/(o>0?o:1);this.#I.draw(d,p,y,this.#g,this.#l);let l=this.#I.getPerformanceProfile();Object.assign(this.#E.style,{display:this.#l?"flex":"none"}),this.#E.textContent=`Frame Time: ${this.#p(l.totalTime)}
423
+ - Preprocess: ${this.#p(l.preprocessTime)}
424
+ - Raster: ${this.#p(l.rasterTime)}
425
+ Last Sort Time: ${this.#p(l.lastSortTime)}`,requestAnimationFrame(N=>{this.#c(N)})}#u(t){this.#B=[t],this.#e=0,this.#a=this.#f,this.#s=!0}#n(t){this.#I.setScene(t.gaussians)}#G(t){try{return this.#r.decode(t)}catch(i){throw new Error("Failed to decode .dgs file, see the above stack trace for details: "+i)}}#m(t){try{return this.#r.loadPly(t)}catch(i){throw new Error("Failed to load .ply file, see the above stack trace for details: "+i)}}async#N(t){let i=await fetch(t);if(!i.ok)throw new Error("Failed to fetch buffer at "+t);return await i.arrayBuffer()}#p(t){return(t?.toFixed(2)??"N/A")+" ms"}#F=Promise.resolve();#v=null;#k=new Promise(t=>this.#v=t);#y(t){return this.#F=this.#F.then(async()=>(await this.#k,await t()),i=>{throw console.error("Enqueuing call failed: ",i),i}),this.#F}};customElements.define("dgs-player",Be);export{Be as DGSPlayer};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "dgs-js",
3
- "version": "1.0.6",
3
+ "version": "1.1.1",
4
4
  "main": "dist/index.js",
5
5
  "files": [
6
6
  "dist/**/*"