dgs-js 1.0.5 → 1.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (3) hide show
  1. package/LICENSE.md +21 -0
  2. package/dist/index.js +96 -56
  3. package/package.json +1 -1
package/LICENSE.md ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2025 Splats
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
package/dist/index.js CHANGED
@@ -1,23 +1,23 @@
1
- var dr=(async function(Y={}){var t,r=Y,C=!0,o=!1,h=[],D="./this.program",d=(A,e)=>{throw e},w=import.meta.url,F="",l,v;if(C||o){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),x=console.error.bind(console),P,Z=!1,M,X,V,j,k,U,m,p,QA,N,Qe,ae,Ie,Ce,oe=!1;function Ee(){var A=j.buffer;k=new Int8Array(A),m=new Int16Array(A),U=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),Ce=new BigUint64Array(A)}function at(){if(r.preRun)for(typeof r.preRun=="function"&&(r.preRun=[r.preRun]);r.preRun.length;)wt(r.preRun.shift());he(le)}function It(){oe=!0,hA.ca()}function Ct(){if(r.postRun)for(typeof r.postRun=="function"&&(r.postRun=[r.postRun]);r.postRun.length;)ft(r.postRun.shift());he(ce)}var aA=0,lA=null;function ot(A){aA++,r.monitorRunDependencies?.(aA)}function Et(A){if(aA--,r.monitorRunDependencies?.(aA),aA==0&&lA){var e=lA;lA=null,e()}}function PA(A){r.onAbort?.(A),A="Aborted("+A+")",x(A),Z=!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/fAACzAI3AWEBYQAKAWEBYgAEAWEBYwAFAWEBZAADAWEBZQABAWEBZgACAWEBZwAMAWEBaAAAAWEBaQAJAWEBagACAWEBawAAAWEBbAAHAWEBbQABAWEBbgAFAWEBbwAFAWEBcAADAWEBcQANAWEBcgALAWEBcwAFAWEBdAAQAWEBdQARAWEBdgAAAWEBdwAGAWEBeAABAWEBeQASAWEBegANAWEBQQAOAWEBQgAGAWEBQwAFAWEBRAATAWEBRQAAAWEBRgAGAWEBRwAUAWEBSAAGAWEBSQABAWEBSgALAWEBSwAAAWEBTAAAAWEBTQAEAWEBTgAHAWEBTwAEAWEBUAAFAWEBUQAKAWEBUgAOAWEBUwAVAWEBVAABAWEBVQACAWEBVgABAWEBVwAAAWEBWAAMAWEBWQAIAWEBWgAIAWEBXwAAAWEBJAAWAWECYWEAFwN7egQAAQMAAwAYAAEJAQUAAAEAAAgHBgYBAQMPBQAPBAIFAQQZBgEABgELBhoBGwAGAQAAAgkHCQgDAwAAAhwBAwECAAABAgAAAQICAgICBgAFAwQCCgQEBAQEAgQFAgUCAAEAAgoBAQAEAAAdCgABAQEDCAgJCQMHBwAGBAUBcAFubgUHAQGCAoCAAgYIAX8BQfDIBAsHVA8CYmECAAJjYQCwAQJkYQB2AmVhAEACZmEAOAJnYQEAAmhhAKEBAmlhAJ4BAmphAJ0BAmthAK8BAmxhAKIBAm1hAHECbmEAcAJvYQCnAQJwYQCmAQmcAQEAQQELbWWcAWSbAZoBmQGYAZcBlgGVAZQBkwGSAWNhkQGQAY8BjgGNAYwBiwGKAWQ5MWNhMIkBiAGHAYYBJAmFARsWNA8QFS0u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cWoiBigCECIEDQALIAYgAzYCEEEYIQEgAiEEQQgLIQAgAyICDAELIAIoAggiBCADNgIMIAIgAzYCCEEYIQBBCCEBQQALIQYgASADaiAENgIAIAMgAjYCDCAAIANqIAY2AgBBhDZBhDYoAgBBAWsiAEF/IAAbNgIACwtiAQF/An9BASAAIABBAU0bIQADQAJAIAAQQCIBBH8gAQVB2MMAKAIAIgENAUEACwwCCyABEQYADAALAAsiAEUEQEEEEEYiAEGYMjYCACAAQdAvNgIAIABB7C9BOxAOAAsgAAt0AQF/IAJFBEAgACgCBCABKAIERg8LIAAgAUYEQEEBDwsgASgCBCICLQAAIQECQCAAKAIEIgMtAAAiAEUNACAAIAFHDQADQCACLQABIQEgAy0AASIARQ0BIAJBAWohAiADQQFqIQMgACABRg0ACwsgACABRgtEAQF/AkAgACgCBCIBQQlPBEBB1DlBADYCAEEnIAEQAUHUOSgCAEHUOUEANgIAQQFGDQEgAEEANgIECw8LQQAQBBA/AAutAwEFfyMAQRBrIgQkACAEIAAoAgAiBUEIaygCACIDNgIMIAQgACADajYCBCAEIAVBBGsoAgA2AgggBCgCBCEGAkAgBCgCCCIFIAJBABA6BEBBACAGIAQoAgwbIQMMAQsjAEFAaiIDJAAgACAGTgRAIAMgAjYCDCADIAU2AgQgAyAANgIIIANBEGpBAEEk/AsAIANBADYCPCADQoGAgICAgICAATcCNCAFIANBBGogBiAGQQFBACAFKAIAKAIUEQgAIABBACADKAIcGyEHCyADQUBrJAAgByIDDQAjAEFAaiIDJAAgAyABNgIMIAMgADYCCCADIAI2AgRBACEAIANBEGpBAEEr/AsAIANBADYCPCADQQE6ADsgBSADQQRqIAZBAUEAIAUoAgAoAhgRCQACQAJAAkAgAygCKA4CAAECCyADKAIYQQAgAygCJEEBRhtBACADKAIgQQFGG0EAIAMoAixBAUYbIQAMAQsgAygCHEEBRwRAIAMoAiwNASADKAIgQQFHDQEgAygCJEEBRw0BCyADKAIUIQALIANBQGskACAAIQMLIARBEGokACADCwYAIAAQOAvOAwIFfwF+IwBBIGsiBCQAAn8gAC0AAARAQQACfyACpyEGIAAoAggiAygCTBogAyADKAJIIgBB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ASAAQQhqIgAgBEkNAAsLCxgAIAAgASgCCEEAEDoEQCABIAIgAxBRCwsGACAAJAALfwBB3DlBATYCAEHgOUEANgIAEGVB4DlB/DkoAgA2AgBB/DlB3Dk2AgBBgDpBOjYCAEGEOkEANgIAEFpBhDpB/DkoAgA2AgBB/DlBgDo2AgBBxDpBgMAANgIAQbw6QfDIBDYCAEGgOkEqNgIAQeg6Qaw7NgIAQcA6QYCABDYCAAsLsCoVAEGACAvhHWZhaWxlZCB0byBhbGxvY2F0ZSBtZW1vcnkAVWludDhBcnJheQBjb2xvck1heABzaE1heAAtKyAgIDBYMHgAdW5zaWduZWQgc2hvcnQAdW5zaWduZWQgaW50AHNldABmbG9hdABpbnZhbGlkIGNvbG9yIG5vcm1hbGl6YXRpb24gY29lZmZpY2llbnRzAGludmFsaWQgc2ggbm9ybWFsaXphdGlvbiBjb2VmZmljaWVudHMAc3VjY2VzcwBjb2xvcnMAZmlsZSBjb250YWlucyAwIGdhdXNzaWFucwBHYXVzc2lhbnMAbWVhbnMAc2hzAHZlbG9jaXRpZXMAb3BhY2l0aWVzAGNvdmFyaWFuY2VzAHZlY3RvcgBhdHRlbXB0aW5nIHRvIHJlYWQgcGFzdCBlbmQgb2YgYnVmZmVyAHVuc2lnbmVkIGNoYXIAc3RkOjpleGNlcHRpb24AZHVyYXRpb24AbWlzbWF0Y2hlZCB2ZXJzaW9uAGNvbG9yTWluAHNoTWluAGJvb2wAbGVuZ3RoAHVuc2lnbmVkIGxvbmcgbG9uZwB1bnNpZ25lZCBsb25nAHN0ZDo6d3N0cmluZwBiYXNpY19zdHJpbmcAc3RkOjpzdHJpbmcAc3RkOjp1MTZzdHJpbmcAc3RkOjp1MzJzdHJpbmcAZ2F1c3NpYW4gY291bnQgbXVzdCBiZSBwb3NpdGl2ZQBjb21iaW5lAGZhaWxlZCB0byByZWFkIGZyb20gZmlsZQBkb3VibGUAb3V0IG9mIGJvdW5kcyBzaCBkZWdyZWUAY2Fubm90IGNvbWJpbmUgZ2F1c3NpYW5zIHdpdGggZGlmZmVyZW50IHNoRGVncmVlAGRlY29kZQBtaXNtYXRjaGVkIG1hZ2ljIHdvcmQAdm9pZABzdGQ6OmJhZF9hbGxvYwBkeW5hbWljAG1nc19lcnJvci5jAG1nc19kZWNvZGUuYwBuZWdhdGl2ZSBkdXJhdGlvbiBlbmNvdW50ZXJlZCBpbiBtZXRhZGF0YQBNZXRhZGF0YQBnYXVzc2lhbiBzcGhlcmljYWwgaGFybW9taWMgZGVncmVlIG11c3QgYmUgbGVzcyB0aGFuIE1HU19HQVVTU0lBTlNfTUFYX1NIX0RFR1JFRQBlbXNjcmlwdGVuOjptZW1vcnlfdmlldzxzaG9ydD4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8dW5zaWduZWQgc2hvcnQ+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PGludD4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8dW5zaWduZWQgaW50PgBlbXNjcmlwdGVuOjptZW1vcnlfdmlldzxmbG9hdD4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8dWludDhfdD4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8aW50OF90PgBlbXNjcmlwdGVuOjptZW1vcnlfdmlldzx1aW50MTZfdD4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8aW50MTZfdD4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8dWludDY0X3Q+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PGludDY0X3Q+AGVtc2NyaXB0ZW46Om1lbW9yeV92aWV3PHVpbnQzMl90PgBlbXNjcmlwdGVuOjptZW1vcnlfdmlldzxpbnQzMl90PgBlbXNjcmlwdGVuOjptZW1vcnlfdmlldzxjaGFyPgBlbXNjcmlwdGVuOjptZW1vcnlfdmlldzx1bnNpZ25lZCBjaGFyPgBlbXNjcmlwdGVuOjptZW1vcnlfdmlldzxzaWduZWQgY2hhcj4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8bG9uZz4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8dW5zaWduZWQgbG9uZz4AZW1zY3JpcHRlbjo6bWVtb3J5X3ZpZXc8ZG91YmxlPgBpbnZhbGlkIGlucHV0IChwcm92aWRlZCBtZW1vcnkvZmlsZSBpbnB1dCB3YXMgaW4gYW4gaW52YWxpZCBmb3JtYXQpAChudWxsKQBpbnZhbGlkIGFyZ3VtZW50cyAoYmFkIGZ1bmN0aW9uIGNhbGwpAGZhaWxlZCB0byB3cml0ZSB0byBhIGZpbGUgKGZ3cml0ZSB3cm90ZSBmZXdlciBieXRlcyB0aGFuIHJlcXVlc3RlZCkAZmFpbGVkIHRvIHJlYWQgZnJvbSBhIGZpbGUgKGZyZWFkIHJlYWQgZmV3ZXIgYnl0ZXMgdGhhbiByZXF1ZXN0ZWQpAGZhaWxlZCB0byBvcGVuIGEgZmlsZSAoZm9wZW4gcmV0dXJuZWQgTlVMTCkAb3V0IG9mIG1lbW9yeSAoTUdTX01BTExPQy9NR1NfUkVBTExPQyByZXR1cm5lZCBOVUxMKQBmYWlsZWQgdG8gY2xvc2UgYSBmaWxlIChmY2xvc2UgcmV0dXJuZWQgRU9GKQBER1MgaW50ZXJuYWwgZXJyb3I6ICIATUdTIEVSUk9SOiAiJXMiIGluICVzIGF0IGxpbmUgJWkKAE1HUyBXQVJOSU5HOiAiJXMiIGluICVzIGF0IGxpbmUgJWkKAAlpbiAlcyBhdCBsaW5lICVpCgAAAACwGAAA4AsAADEyTUdTZ2F1c3NpYW5zAAC0FwAAAAwAAAAAAADYCwAAUDEyTUdTZ2F1c3NpYW5zALQXAAAgDAAAAQAAANgLAABQSzEyTUdTZ2F1c3NpYW5zAHBwAHYAdnAAAAAAAAAAAFgMAAA8AAAAPQAAAD4AAAA/AAAAQAAAAOgYAABkDAAApBQAAE5TdDNfXzIyMF9fc2hhcmVkX3B0cl9wb2ludGVySVAxMk1HU2dhdXNzaWFuc04xMGVtc2NyaXB0ZW4xNXNtYXJ0X3B0cl90cmFpdElOU18xMHNoYXJlZF9wdHJJUzFfRUVFMTF2YWxfZGVsZXRlckVOU185YWxsb2NhdG9ySVMxX0VFRUUATjEwZW1zY3JpcHRlbjE1c21hcnRfcHRyX3RyYWl0SU5TdDNfXzIxMHNoYXJlZF9wdHJJMTJNR1NnYXVzc2lhbnNFRUUxMXZhbF9kZWxldGVyRQAAAAAwDwAAsBgAAEwNAABOU3QzX18yMTBzaGFyZWRfcHRySTEyTUdTZ2F1c3NpYW5zRUUAcABwcHAAAEQNAAAAAAAAmA0AAEEAAABCAAAAQwAAAEQAAABFAAAA6BgAAKQNAACkFAAATlN0M19fMjIwX19zaGFyZWRfcHRyX2VtcGxhY2VJMTJNR1NnYXVzc2lhbnNOU185YWxsb2NhdG9ySVMxX0VFRUUAaXBwAHZwcGkAZnBwAHZwcGYAsBgAAAAOAAAxMU1HU21ldGFkYXRhAAAAMA8AADAPAABcFgAAMA8AAAAAAAA8DgAARgAAAEcAAABIAAAASQAAAEoAAADoGAAASA4AAKQUAABOU3QzX18yMjBfX3NoYXJlZF9wdHJfcG9pbnRlcklQMTJNR1NnYXVzc2lhbnNaWkwyMWVtYmluZF9pbml0X2xpYmRnc19qc3ZFTkszJF83Y2xFUktOMTBlbXNjcmlwdGVuM3ZhbEVFVWxTMl9FX05TXzlhbGxvY2F0b3JJUzFfRUVFRQBaWkwyMWVtYmluZF9pbml0X2xpYmRnc19qc3ZFTkszJF83Y2xFUktOMTBlbXNjcmlwdGVuM3ZhbEVFVWxQMTJNR1NnYXVzc2lhbnNFXwAAAEQNAABEDQAARA0AAHBwcHAAAAAAsBgAADgPAABOMTBlbXNjcmlwdGVuM3ZhbEUAALAYAABUDwAATlN0M19fMjEyYmFzaWNfc3RyaW5nSWNOU18xMWNoYXJfdHJhaXRzSWNFRU5TXzlhbGxvY2F0b3JJY0VFRUUAALAYAACcDwAATlN0M19fMjEyYmFzaWNfc3RyaW5nSXdOU18xMWNoYXJfdHJhaXRzSXdFRU5TXzlhbGxvY2F0b3JJd0VFRUUAALAYAADkDwAATlN0M19fMjEyYmFzaWNfc3RyaW5nSURzTlNfMTFjaGFyX3RyYWl0c0lEc0VFTlNfOWFsbG9jYXRvcklEc0VFRUUAAACwGAAAMBAAAE5TdDNfXzIxMmJhc2ljX3N0cmluZ0lEaU5TXzExY2hhcl90cmFpdHNJRGlFRU5TXzlhbGxvY2F0b3JJRGlFRUVFAAAAsBgAAHwQAABOMTBlbXNjcmlwdGVuMTFtZW1vcnlfdmlld0ljRUUAALAYAACkEAAATjEwZW1zY3JpcHRlbjExbWVtb3J5X3ZpZXdJYUVFAACwGAAAzBAAAE4xMGVtc2NyaXB0ZW4xMW1lbW9yeV92aWV3SWhFRQAAsBgAAPQQAABOMTBlbXNjcmlwdGVuMTFtZW1vcnlfdmlld0lzRUUAALAYAAAcEQAATjEwZW1zY3JpcHRlbjExbWVtb3J5X3ZpZXdJdEVFAACwGAAARBEAAE4xMGVtc2NyaXB0ZW4xMW1l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")}function ht(A){if(ArrayBuffer.isView(A))return A;if(A==WA&&P)return new Uint8Array(P);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),i=await WebAssembly.instantiate(g,e);return i}catch(s){x(`failed to asynchronously prepare wasm: ${s}`),PA(s)}}async function ut(A,e,g){return lt(e,g)}function dt(){return{a:ir}}async function Dt(){function A(B,a){return hA=B.exports,j=hA.ba,Ee(),ve=hA.ga,rr(hA),Et("wasm-instantiate"),hA}ot("wasm-instantiate");function e(B){return A(B.instance)}var g=dt();if(r.instantiateWasm)return new Promise((B,a)=>{r.instantiateWasm(g,(Q,I)=>{B(A(Q,I))})});WA??=nt();var i=await ut(P,WA,g),s=e(i);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()(r)},ce=[],ft=A=>ce.push(A),le=[],wt=A=>le.push(A),yt=A=>{for(var e,g,i=0,s=0,B=A.length,a=new Uint8Array((B*3>>2)-(A[B-2]=="=")-(A[B-1]=="="));i<B;i+=4,s+=3)e=tA[A.charCodeAt(i+1)],g=tA[A.charCodeAt(i+2)],a[s]=tA[A.charCodeAt(i)]<<2|e>>4,a[s+1]=e<<4|g>>2,a[s+2]=g<<6|tA[A.charCodeAt(i+3)];return a},KA=!0,K=A=>Ze(A),O=()=>Xe(),NA=[],OA=0,Ft=A=>{var e=new ZA(A);return e.get_caught()||(e.set_caught(!0),OA--),e.set_rethrown(!1),NA.push(e),Ve(A),qe(A)},eA=0,pt=()=>{_(0,0);var A=NA.pop();ze(A.excPtr),eA=0};class ZA{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,k[this.ptr+12]=e}get_caught(){return k[this.ptr+12]!=0}set_rethrown(e){e=e?1:0,k[this.ptr+13]=e}get_rethrown(){return k[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=>Oe(A),ue=A=>{var e=eA;if(!e)return vA(0),0;var g=new ZA(e);g.set_adjusted_ptr(e);var i=g.get_type();if(!i)return vA(0),e;for(var s of A){if(s===0||s===i)break;var B=g.ptr+16;if(je(s,i,B))return vA(s),e}return vA(i),e},mt=()=>ue([]),Nt=A=>ue([A]),vt=()=>{var A=NA.pop();A||PA("no exception to throw");var e=A.excPtr;throw A.get_rethrown()||(NA.push(A),A.set_rethrown(!0),A.set_caught(!1),OA++),eA=e,eA},Ut=(A,e,g)=>{var i=new ZA(A);throw i.init(e,g),eA=A,OA++,eA},Rt=A=>{throw eA||(eA=A),eA},Yt=()=>PA(""),UA={},RA=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={},YA={},St=class extends Error{constructor(e){super(e),this.name="InternalError"}},SA=A=>{throw new St(A)},iA=(A,e,g)=>{A.forEach(Q=>YA[Q]=e);function i(Q){var I=g(Q);I.length!==A.length&&SA("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&&i(s)}))}),B.length===0&&i(s)},Gt=A=>{var e=UA[A];delete UA[A];var g=e.rawConstructor,i=e.rawDestructor,s=e.fields,B=s.map(a=>a.getterReturnType).concat(s.map(a=>a.setterArgumentType));iA([A],B,a=>{var Q={};return s.forEach((I,E)=>{var n=I.fieldName,u=a[E],y=a[E].optional,H=I.getter,L=I.getterContext,BA=a[E+s.length],oA=I.setter,AA=I.setterContext;Q[n]={read:rA=>u.fromWireType(H(L,rA)),write:(rA,T)=>{var JA=[];oA(AA,rA,BA.toWireType(JA,T)),RA(JA)},optional:y}}),[{name:e.name,fromWireType:I=>{var E={};for(var n in Q)E[n]=Q[n].read(I);return i(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(i,u),u},argPackAdvance:$,readValueFromPointer:uA,destructorFunction:i}]})},G=A=>{for(var e="";;){var g=U[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 Mt(A,e,g={}){var i=e.name;if(A||f(`type "${i}" must have a positive integer typeid pointer`),IA.hasOwnProperty(A)){if(g.ignoreDuplicateRegistrations)return;f(`Cannot register type '${i}' twice`)}if(IA[A]=e,delete YA[A],nA.hasOwnProperty(A)){var s=nA[A];delete nA[A],s.forEach(B=>B())}}function q(A,e,g={}){return Mt(A,e,g)}var de=(A,e,g)=>{switch(e){case 1:return g?i=>k[i]:i=>U[i];case 2:return g?i=>m[i>>1]:i=>p[i>>1];case 4:return g?i=>QA[i>>2]:i=>N[i>>2];case 8:return g?i=>Ie[i>>3]:i=>Ce[i>>3];default:throw new TypeError(`invalid integer width (${e}): ${A}`)}},kt=(A,e,g,i,s)=>{e=G(e);let B=i===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,i)=>{e=G(e),q(A,{name:e,fromWireType:function(s){return!!s},toWireType:function(s,B){return B?g:i},argPackAdvance:$,readValueFromPointer:function(s){return this.fromWireType(U[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}f(e(A)+" instance already deleted")},VA=!1,De=A=>{},Jt=A=>{A.smartPtr?A.smartPtrType.rawDestructor(A.smartPtr):A.ptrType.registeredClass.rawDestructor(A.ptr)},fe=A=>{A.count.value-=1;var e=A.count.value===0;e&&Jt(A)},DA=A=>typeof FinalizationRegistry>"u"?(DA=e=>e,A):(VA=new FinalizationRegistry(e=>{fe(e.$$)}),DA=e=>{var g=e.$$,i=!!g.smartPtr;if(i){var s={$$:g};VA.register(e,s,e)}return e},De=e=>VA.unregister(e),DA(A)),GA=[],Tt=()=>{for(;GA.length;){var A=GA.pop();A.$$.deleteScheduled=!1,A.delete()}},we,xt=()=>{let A=MA.prototype;Object.assign(A,{isAliasOf(g){if(!(this instanceof MA)||!(g instanceof MA))return!1;var i=this.$$.ptrType.registeredClass,s=this.$$.ptr;g.$$=g.$$;for(var B=g.$$.ptrType.registeredClass,a=g.$$.ptr;i.baseClass;)s=i.upcast(s),i=i.baseClass;for(;B.baseClass;)a=B.upcast(a),B=B.baseClass;return i===B&&s===a},clone(){if(this.$$.ptr||XA(this),this.$$.preservePointerOnDelete)return this.$$.count.value+=1,this;var g=DA(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&&f("Object already scheduled for deletion"),De(this),fe(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"),GA.push(this),GA.length===1&&we&&we(Tt),this.$$.deleteScheduled=!0,this}});let e=Symbol.dispose;e&&(A[e]=A.delete)};function MA(){}var zA=(A,e)=>Object.defineProperty(e,"name",{value:A}),ye={},_t=(A,e,g)=>{if(A[e].overloadTable===void 0){var i=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[i.argCount]=i}},Fe=(A,e,g)=>{r.hasOwnProperty(A)?((g===void 0||r[A].overloadTable!==void 0&&r[A].overloadTable[g]!==void 0)&&f(`Cannot register public name '${A}' twice`),_t(r,A,A),r[A].overloadTable.hasOwnProperty(g)&&f(`Cannot register multiple overloads of a function with the same number of arguments (${g})!`),r[A].overloadTable[g]=e):(r[A]=e,r[A].argCount=g)},Lt=48,Pt=57,Wt=A=>{A=A.replace(/[^a-zA-Z0-9_]/g,"$");var e=A.charCodeAt(0);return e>=Lt&&e<=Pt?`_${A}`:A};function Kt(A,e,g,i,s,B,a,Q){this.name=A,this.constructor=e,this.instancePrototype=g,this.rawDestructor=i,this.baseClass=s,this.getActualType=B,this.upcast=a,this.downcast=Q,this.pureVirtualFunctions=[]}var kA=(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 Ot(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,i=kA(e.$$.ptr,g,this.registeredClass);return i}function Zt(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 i=e.$$.ptrType.registeredClass;if(g=kA(e.$$.ptr,i,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,R.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,i=kA(e.$$.ptr,g,this.registeredClass);return i}var pe=(A,e,g)=>{if(e===g)return A;if(g.baseClass===void 0)return null;var i=pe(A,e,g.baseClass);return i===null?null:g.downcast(i)},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)&&SA("makeClassHandle requires ptr and ptrType");var g=!!e.smartPtrType,i=!!e.smartPtr;return g!==i&&SA("Both smartPtrType and smartPtr must be specified"),e.count={value:1},DA(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 i=g.clone();return this.destructor(A),i}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(fA.prototype,{getPointee(A){return this.rawGetPointee&&(A=this.rawGetPointee(A)),A},destructor(A){this.rawDestructor?.(A)},argPackAdvance:$,readValueFromPointer:uA,fromWireType:qt})};function fA(A,e,g,i,s,B,a,Q,I,E,n){this.name=A,this.registeredClass=e,this.isReference=g,this.isConst=i,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?i?(this.toWireType=Ot,this.destructorFunction=null):(this.toWireType=Xt,this.destructorFunction=null):this.toWireType=Zt}var me=(A,e,g)=>{r.hasOwnProperty(A)||SA("Replacing nonexistent public symbol"),r[A].overloadTable!==void 0&&g!==void 0?r[A].overloadTable[g]=e:(r[A]=e,r[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=G(A);function i(){var B=W(e);return B}var s=i();return typeof s!="function"&&f(`unknown function pointer with signature ${A}: ${e}`),s};class Ag extends Error{}var Ue=A=>{var e=We(A),g=G(e);return gA(e),g},wA=(A,e)=>{var g=[],i={};function s(B){if(!i[B]&&!IA[B]){if(YA[B]){YA[B].forEach(s);return}g.push(B),i[B]=!0}}throw e.forEach(s),new Ag(`${A}: `+g.map(Ue).join([", "]))},eg=(A,e,g,i,s,B,a,Q,I,E,n,u,y)=>{n=G(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`,[i])}),iA([A,e,g],i?[i]:[],L=>{L=L[0];var BA,oA;i?(BA=L.registeredClass,oA=BA.instancePrototype):oA=MA.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(oA,{constructor:{value:AA}});AA.prototype=rA;var T=new Kt(n,AA,rA,y,BA,B,Q,E);T.baseClass&&(T.baseClass.__derivedClasses??=[],T.baseClass.__derivedClasses.push(T));var JA=new fA(n,T,!0,!1,!1),$e=new fA(n+"*",T,!1,!1,!1),At=new fA(n+" const*",T,!1,!0,!1);return ye[A]={pointerType:$e,constPointerType:At},me(H,AA),[JA,$e,At]})},Re=(A,e)=>{for(var g=[],i=0;i<A;i++)g.push(N[e+i*4>>2]);return g};function Ye(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,i){var s=Ye(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,o=!0,C=!1,h=[],D="./this.program",d=(A,e)=>{throw e},p=import.meta.url,y="",l,N;if(o||C){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),H,X=!1,U,V,z,j,S,v,F,G,aA,m,Qe,ae,Ie,Ce,oe=!1;function Ee(){var A=j.buffer;S=new Int8Array(A),F=new Int16Array(A),v=new Uint8Array(A),G=new Uint16Array(A),aA=new Int32Array(A),m=new Uint32Array(A),Qe=new Float32Array(A),ae=new Float64Array(A),Ie=new BigInt64Array(A),Ce=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(){oe=!0,hA.ca()}function Ct(){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 ot(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&&H)return new Uint8Array(H);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,a){return hA=B.exports,j=hA.ba,Ee(),Ne=hA.ga,ii(hA),Et("wasm-instantiate"),hA}ot("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(H,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,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},ZA=!0,K=A=>Oe(A),O=()=>Xe(),mA=[],KA=0,yt=A=>{var e=new OA(A);return e.get_caught()||(e.set_caught(!0),KA--),e.set_rethrown(!1),mA.push(e),Ve(A),qe(A)},eA=0,Gt=()=>{L(0,0);var A=mA.pop();ze(A.excPtr),eA=0};class OA{constructor(e){this.excPtr=e,this.ptr=e-24}set_type(e){m[this.ptr+4>>2]=e}get_type(){return m[this.ptr+4>>2]}set_destructor(e){m[this.ptr+8>>2]=e}get_destructor(){return m[this.ptr+8>>2]}set_caught(e){e=e?1:0,S[this.ptr+12]=e}get_caught(){return S[this.ptr+12]!=0}set_rethrown(e){e=e?1:0,S[this.ptr+13]=e}get_rethrown(){return S[this.ptr+13]!=0}init(e,g){this.set_adjusted_ptr(0),this.set_type(e),this.set_destructor(g)}set_adjusted_ptr(e){m[this.ptr+16>>2]=e}get_adjusted_ptr(){return m[this.ptr+16>>2]}}var NA=A=>Ke(A),ue=A=>{var e=eA;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},Ft=()=>ue([]),mt=A=>ue([A]),Nt=()=>{var A=mA.pop();A||HA("no exception to throw");var e=A.excPtr;throw A.get_rethrown()||(mA.push(A),A.set_rethrown(!0),A.set_caught(!1),KA++),eA=e,eA},vt=(A,e,g)=>{var r=new OA(A);throw r.init(e,g),eA=A,KA++,eA},kt=A=>{throw eA||(eA=A),eA},Rt=()=>HA(""),vA={},kA=A=>{for(;A.length;){var e=A.pop(),g=A.pop();g(e)}};function uA(A){return this.fromWireType(m[A>>2])}var nA={},CA={},RA={},Yt=class extends Error{constructor(e){super(e),this.name="InternalError"}},YA=A=>{throw new Yt(A)},sA=(A,e,g)=>{A.forEach(Q=>RA[Q]=e);function r(Q){var I=g(Q);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=[],a=0;e.forEach((Q,I)=>{CA.hasOwnProperty(Q)?s[I]=CA[Q]:(B.push(Q),nA.hasOwnProperty(Q)||(nA[Q]=[]),nA[Q].push(()=>{s[I]=CA[Q],++a,a===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(a=>a.getterReturnType).concat(s.map(a=>a.setterArgumentType));sA([A],B,a=>{var Q={};return s.forEach((I,E)=>{var n=I.fieldName,u=a[E],w=a[E].optional,x=I.getter,P=I.getterContext,QA=a[E+s.length],EA=I.setter,AA=I.setterContext;Q[n]={read:iA=>u.fromWireType(x(P,iA)),write:(iA,T)=>{var JA=[];EA(AA,iA,QA.toWireType(JA,T)),kA(JA)},optional:w}}),[{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}]})},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 Ut(A,e,g={}){var r=e.name;if(A||f(`type "${r}" must have a positive integer typeid pointer`),CA.hasOwnProperty(A)){if(g.ignoreDuplicateRegistrations)return;f(`Cannot register type '${r}' twice`)}if(CA[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 Ut(A,e,g)}var de=(A,e,g)=>{switch(e){case 1:return g?r=>S[r]:r=>v[r];case 2:return g?r=>F[r>>1]:r=>G[r>>1];case 4:return g?r=>aA[r>>2]:r=>m[r>>2];case 8:return g?r=>Ie[r>>3]:r=>Ce[r>>3];default:throw new TypeError(`invalid integer width (${e}): ${A}`)}},St=(A,e,g,r,s)=>{e=M(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=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=UA.prototype;Object.assign(A,{isAliasOf(g){if(!(this instanceof UA)||!(g instanceof UA))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: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 UA(){}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,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 SA=(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=SA(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=SA(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=SA(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),a=pe[B];if(!a)return s.call(this);var Q;this.isConst?Q=a.constPointerType:Q=a.pointerType;var I=Ge(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=Kt,this.destructorFunction=null):(this.toWireType=Xt,this.destructorFunction=null):this.toWireType=Ot}var Fe=(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)},me=[],Ne,W=A=>{var e=me[A];return e||(me[A]=e=Ne.get(A)),e},b=(A,e,g=!1)=>{A=M(A);function r(){var B=W(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 gA(e),g},wA=(A,e)=>{var g=[],r={};function s(B){if(!r[B]&&!CA[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,a,Q,I,E,n,u,w)=>{n=M(n),B=b(s,B),Q&&=b(a,Q),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 QA,EA;r?(QA=P.registeredClass,EA=QA.instancePrototype):EA=UA.prototype;var AA=zA(n,function(...ge){if(Object.getPrototypeOf(this)!==iA)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)}),iA=Object.create(EA,{constructor:{value:AA}});AA.prototype=iA;var T=new Zt(n,AA,iA,w,QA,B,Q,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},Fe(x,AA),[JA,$e,At]})},ke=(A,e)=>{for(var g=[],r=0;r<A;r++)g.push(m[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,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}) {
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||i?"var rv = ":"")+`invoker(${Q});
5
+ `,u.push(`argType${I}`);if(E+=(g||r?"var rv = ":"")+`invoker(${Q});
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 Se(A,e,g,i,s,B){var a=e.length;a<2&&f("argTypes array size mismatch! Must at least get return value and 'this' types!");for(var Q=e[1]!==null&&g!==null,I=Ye(e),E=e[0].name!=="void",n=[A,f,i,s,RA,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 L=new Function(...y,H)(...n);return zA(A,L)}for(var gg=(A,e,g,i,s,B)=>{var a=Re(e,g);s=b(i,s),iA([],[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)},iA([],a,E=>(E.splice(1,0,null),Q.registeredClass.constructor_body[e-1]=Se(I,E,null,s,B),[])),[]})},Ge=(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`),kA(A.$$.ptr,A.$$.ptrType.registeredClass,e.registeredClass)),rg=(A,e,g,i,s,B,a,Q,I,E)=>{e=G(e),s=b(i,s),iA([],[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=>f(u+" is a read-only property"),Object.defineProperty(n.registeredClass.instancePrototype,e,y),iA([],I?[g,a]:[g],H=>{var L=H[0],BA={get(){var AA=Ge(this,n,u+" getter");return L.fromWireType(s(B,AA))},enumerable:!0};if(I){I=b(Q,I);var oA=H[1];BA.set=function(AA){var rA=Ge(this,n,u+" setter"),T=[];I(E,rA,oA.toWireType(T,AA)),RA(T)}}return Object.defineProperty(n.registeredClass.instancePrototype,e,BA),[]}),[]})},Me=[],CA=[0,1,,1,null,1,!0,1,!1,1],qA=A=>{A>9&&--CA[A+1]===0&&(CA[A]=void 0,Me.push(A))},R={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=Me.pop()||CA.length;return CA[e]=A,CA[e+1]=1,e}}}},ig={name:"emscripten::val",fromWireType:A=>{var e=R.toValue(A);return qA(A),e},toWireType:(A,e)=>R.toHandle(e),argPackAdvance:$,readValueFromPointer:uA,destructorFunction:null},sg=A=>q(A,ig),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=G(e),q(A,{name:e,fromWireType:i=>i,toWireType:(i,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,i,s,B,a,Q)=>{var I=Re(e,g);A=G(A),A=ag(A),s=b(i,s,a),Fe(A,function(){wA(`Cannot call ${A} due to unbound types`,I)},e-1),iA([],I,E=>{var n=[E[0],null].concat(E.slice(1));return me(A,Se(A,n,null,s,B,a),e-1),[]})},Cg=(A,e,g,i,s)=>{e=G(e);let B=i===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,i!==0),destructorFunction:null})},og=(A,e,g)=>{var i=[Int8Array,Uint8Array,Int16Array,Uint16Array,Int32Array,Uint32Array,Float32Array,Float64Array,BigInt64Array,BigUint64Array],s=i[e];function B(a){var Q=N[a>>2],I=N[a+4>>2];return new s(k.buffer,I,Q)}g=G(g),q(A,{name:g,fromWireType:B,argPackAdvance:$,readValueFromPointer:B},{ignoreDuplicateRegistrations:!0})},Eg=(A,e,g,i,s,B,a,Q,I,E,n,u)=>{g=G(g),B=b(s,B),Q=b(a,Q),E=b(I,E),u=b(n,u),iA([A],[e],y=>{y=y[0];var H=new fA(g,y.registeredClass,!1,!1,!0,y,i,B,Q,E,u);return[H]})},ng=(A,e,g,i)=>{if(!(i>0))return 0;for(var s=g,B=g+i-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,U,e,g),cg=A=>{for(var e=0,g=0;g<A.length;++g){var i=A.charCodeAt(g);i<=127?e++:i<=2047?e+=2:i>=55296&&i<=57343?(e+=4,++g):e+=3}return e},ke=typeof TextDecoder<"u"?new TextDecoder:void 0,be=(A,e=0,g=NaN)=>{for(var i=e+g,s=e;A[s]&&!(s>=i);)++s;if(s-e>16&&A.buffer&&ke)return ke.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(U,A,e):"",ug=(A,e)=>{e=G(e);var g=!0;q(A,{name:e,fromWireType(i){var s=N[i>>2],B=i+4,a;if(g)for(var Q=B,I=0;I<=s;++I){var E=B+I;if(I==s||U[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(U[B+I]);a=y.join("")}return gA(i),a},toWireType(i,s){s instanceof ArrayBuffer&&(s=new Uint8Array(s));var B,a=typeof s=="string";a||ArrayBuffer.isView(s)&&s.BYTES_PER_ELEMENT==1||f("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),f("String has UTF-16 code units that do not fit in 8 bits")),U[I+E]=n}else U.set(s,I);return i!==null&&i.push(gA,Q),Q},argPackAdvance:$,readValueFromPointer:uA,destructorFunction(i){gA(i)}})},He=typeof TextDecoder<"u"?new TextDecoder("utf-16le"):void 0,dg=(A,e)=>{for(var g=A>>1,i=g+e/2,s=g;!(s>=i)&&p[s];)++s;if(s-g>16&&He)return He.decode(p.subarray(g,s));for(var B="",a=g;!(a>=i);++a){var Q=p[a];if(Q==0)break;B+=String.fromCharCode(Q)}return B},Dg=(A,e,g)=>{if(g??=2147483647,g<2)return 0;g-=2;for(var i=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-i},fg=A=>A.length*2,wg=(A,e)=>{for(var g="",i=0;!(i>=e/4);i++){var s=QA[A+i*4>>2];if(!s)break;g+=String.fromCodePoint(s)}return g},yg=(A,e,g)=>{if(g??=2147483647,g<4)return 0;for(var i=e,s=i+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-i},Fg=A=>{for(var e=0,g=0;g<A.length;++g){var i=A.codePointAt(g);i>65535&&g++,e+=4}return e},pg=(A,e,g)=>{g=G(g);var i,s,B,a;e===2?(i=dg,s=Dg,a=fg,B=Q=>p[Q>>1]):e===4&&(i=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,L=i(n,H);E===void 0?E=L:(E+="\0",E+=L),n=y+e}}return gA(Q),E},toWireType:(Q,I)=>{typeof I!="string"&&f(`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,i,s,B)=>{UA[A]={name:G(e),rawConstructor:b(g,i),rawDestructor:b(s,B),fields:[]}},Ng=(A,e,g,i,s,B,a,Q,I,E)=>{UA[A].fields.push({fieldName:G(e),getterReturnType:g,getter:b(i,s),getterContext:B,setterArgumentType:a,setter:b(Q,I),setterContext:E})},vg=(A,e)=>{e=G(e),q(A,{isVoid:!0,name:e,argPackAdvance:0,fromWireType:()=>{},toWireType:(g,i)=>{}})},Je=0,Ug=()=>{KA=!1,Je=0},$A=(A,e)=>{var g=IA[A];return g===void 0&&f(`${e} has unknown type ${Ue(A)}`),g},Te=(A,e,g)=>{var i=[],s=A.toWireType(i,g);return i.length&&(N[e>>2]=R.toHandle(i)),s},Rg=(A,e,g)=>(A=R.toValue(A),e=$A(e,"emval::as"),Te(e,g,A)),HA=[],Yg=(A,e,g,i)=>(A=HA[A],e=R.toValue(e),A(null,e,g,i)),Sg={},Ae=A=>{var e=Sg[A];return e===void 0?G(A):e},Gg=(A,e,g,i,s)=>(A=HA[A],e=R.toValue(e),g=Ae(g),A(e,e[g],i,s)),xe=()=>globalThis,Mg=A=>A===0?R.toHandle(xe()):(A=Ae(A),R.toHandle(xe()[A])),kg=A=>{var e=HA.length;return HA.push(A),e},bg=(A,e)=>{for(var g=new Array(A),i=0;i<A;++i)g[i]=$A(N[e+i*4>>2],`parameter ${i}`);return g},Hg=(A,e,g)=>{var i=bg(A,e),s=i.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(i[n]),B+=` var arg${n} = argType${n}.readValueFromPointer(args${a?"+"+a:""});
13
- `,a+=i[n].argPackAdvance;var u=g===1?"new func":"func.call";B+=` var rv = ${u}(${Q.join(", ")});
11
+ `,[u,E]}function Ye(A,e,g,r,s,B){var a=e.length;a<2&&f("argTypes array size mismatch! Must at least get return value and 'this' types!");for(var Q=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<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[w,x]=tg(e,Q,E,B);var P=new Function(...w,x)(...n);return zA(A,P)}for(var gg=(A,e,g,r,s,B)=>{var a=ke(e,g);s=b(r,s),sA([],[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)},sA([],a,E=>(E.splice(1,0,null),Q.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`),SA(A.$$.ptr,A.$$.ptrType.registeredClass,e.registeredClass)),ig=(A,e,g,r,s,B,a,Q,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,a])},enumerable:!0,configurable:!0};return I?w.set=()=>wA(`Cannot access ${u} due to unbound types`,[g,a]):w.set=x=>f(u+" is a read-only property"),Object.defineProperty(n.registeredClass.instancePrototype,e,w),sA([],I?[g,a]:[g],x=>{var P=x[0],QA={get(){var AA=Me(this,n,u+" getter");return P.fromWireType(s(B,AA))},enumerable:!0};if(I){I=b(Q,I);var EA=x[1];QA.set=function(AA){var iA=Me(this,n,u+" setter"),T=[];I(E,iA,EA.toWireType(T,AA)),kA(T)}}return Object.defineProperty(n.registeredClass.instancePrototype,e,QA),[]}),[]})},Ue=[],oA=[0,1,,1,null,1,!0,1,!1,1],qA=A=>{A>9&&--oA[A+1]===0&&(oA[A]=void 0,Ue.push(A))},k={toValue:A=>(A||f(`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=Ue.pop()||oA.length;return oA[e]=A,oA[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(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=M(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=ke(e,g);A=M(A),A=ag(A),s=b(r,s,a),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 Fe(A,Ye(A,n,null,s,B,a),e-1),[]})},Cg=(A,e,g,r,s)=>{e=M(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})},og=(A,e,g)=>{var r=[Int8Array,Uint8Array,Int16Array,Uint16Array,Int32Array,Uint32Array,Float32Array,Float64Array,BigInt64Array,BigUint64Array],s=r[e];function B(a){var Q=m[a>>2],I=m[a+4>>2];return new s(S.buffer,I,Q)}g=M(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=M(g),B=b(s,B),Q=b(a,Q),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,Q,E,u);return[x]})},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,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},Se=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&&Se)return Se.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(v,A,e):"",ug=(A,e)=>{e=M(e);var g=!0;q(A,{name:e,fromWireType(r){var s=m[r>>2],B=r+4,a;if(g)for(var Q=B,I=0;I<=s;++I){var E=B+I;if(I==s||v[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 w=new Array(s),I=0;I<s;++I)w[I]=String.fromCharCode(v[B+I]);a=w.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||f("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(m[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),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(gA,Q),Q},argPackAdvance:$,readValueFromPointer:uA,destructorFunction(r){gA(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="",a=g;!(a>=r);++a){var Q=G[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);F[e>>1]=a,e+=2}return F[e>>1]=0,e-r},Dg=A=>A.length*2,wg=(A,e)=>{for(var g="",r=0;!(r>=e/4);r++){var s=aA[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 a=A.codePointAt(B);if(a>65535&&B++,aA[e>>2]=a,e+=4,e+4>s)break}return aA[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,a;e===2?(r=dg,s=fg,a=Dg,B=Q=>G[Q>>1]):e===4&&(r=wg,s=pg,a=yg,B=Q=>m[Q>>2]),q(A,{name:g,fromWireType:Q=>{for(var I=m[Q>>2],E,n=Q+4,u=0;u<=I;++u){var w=Q+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 gA(Q),E},toWireType:(Q,I)=>{typeof I!="string"&&f(`Cannot pass non-string to C++ string type ${g}`);var E=a(I),n=ee(4+E+e);return m[n>>2]=E/e,s(I,n+4,E+e),Q!==null&&Q.push(gA,n),n},argPackAdvance:$,readValueFromPointer:uA,destructorFunction(Q){gA(Q)}})},Fg=(A,e,g,r,s,B)=>{vA[A]={name:M(e),rawConstructor:b(g,r),rawDestructor:b(s,B),fields:[]}},mg=(A,e,g,r,s,B,a,Q,I,E)=>{vA[A].fields.push({fieldName:M(e),getterReturnType:g,getter:b(r,s),getterContext:B,setterArgumentType:a,setter:b(Q,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=CA[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&&(m[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,Ug=A=>A===0?k.toHandle(_e()):(A=Ae(A),k.toHandle(_e()[A])),Sg=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(m[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
+ `,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
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<(${i.map(L=>L.name).join(", ")}) => ${s.name}>`;return kg(zA(H,y))},Jg=(A,e)=>(A=R.toValue(A),e=R.toValue(e),R.toHandle(A[e])),Tg=A=>{A>9&&(CA[A+1]+=1)},xg=A=>R.toHandle(Ae(A)),_g=()=>R.toHandle({}),Lg=A=>{var e=R.toValue(A);RA(e),qA(A)},Pg=(A,e,g)=>{A=R.toValue(A),e=R.toValue(e),g=R.toValue(g),A[e]=g},Wg=(A,e)=>{A=$A(A,"_emval_take_value");var g=A.readValueFromPointer(e);return R.toHandle(g)},yA={},_e=A=>{if(A instanceof ne||A=="unwind")return M;d(1,A)},Le=()=>KA||Je>0,Pe=A=>{M=A,Le()||(r.onExit?.(A),Z=!0),d(A,new ne(A))},Kg=(A,e)=>{M=A,Pe(A)},Og=Kg,Zg=()=>{if(!Le())try{Og(M)}catch(A){_e(A)}},Xg=A=>{if(!Z)try{A(),Zg()}catch(e){_e(e)}},Vg=()=>performance.now(),zg=(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},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{}},Ar=A=>{var e=U.length;A>>>=0;var g=jg();if(A>g)return!1;for(var i=1;i<=4;i*=2){var s=e*(1+.2/i);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},er=[null,[],[]],tr=(A,e)=>{var g=er[A];e===0||e===10?((A===1?J:x)(be(g)),g.length=0):g.push(e)},gr=(A,e,g,i)=>{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++)tr(A,U[a+I]);s+=Q}return N[i>>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,xt(),$t(),r.noExitRuntime&&(KA=r.noExitRuntime),r.print&&(J=r.print),r.printErr&&(x=r.printErr),r.wasmBinary&&(P=r.wasmBinary),r.arguments&&(h=r.arguments),r.thisProgram&&(D=r.thisProgram);var We,ee,gA,Ke,_,Oe,Ze,Xe,Ve,ze,je,qe;function rr(A){We=A.da,ee=A.ea,gA=A.fa,Ke=A.ha,_=A.ia,Oe=A.ja,Ze=A.ka,Xe=A.la,Ve=A.ma,ze=A.na,je=A.oa,qe=A.pa}var ir={m:Ft,w:pt,a:mt,e:Nt,B:vt,o:Ut,h:Rt,H:Yt,W:Gt,t:kt,N:bt,aa:eg,Z:gg,g:rg,L:sg,s:Qg,u:Ig,i:Cg,c:og,$:Eg,M:ug,n:pg,Y:mg,X:Ng,O:vg,F:Ug,S:Rg,q:Yg,R:Gg,_:qA,V:Mg,p:Hg,U:Jg,K:Tg,T:xg,Q:_g,v:Lg,P:Pg,j:Wg,G:zg,I:Ar,J:gr,z:nr,A:Er,y:hr,x:lr,f:sr,d:ar,r:or,k:Ir,b:Qr,C:Cr,l:cr,D:Br,E:Pe},hA=await Dt();function sr(A,e){var g=O();try{return W(A)(e)}catch(i){if(K(g),i!==i+0)throw i;_(1,0)}}function Br(A,e,g,i,s,B,a,Q,I,E,n){var u=O();try{W(A)(e,g,i,s,B,a,Q,I,E,n)}catch(y){if(K(u),y!==y+0)throw y;_(1,0)}}function Qr(A,e){var g=O();try{W(A)(e)}catch(i){if(K(g),i!==i+0)throw i;_(1,0)}}function ar(A,e,g){var i=O();try{return W(A)(e,g)}catch(s){if(K(i),s!==s+0)throw s;_(1,0)}}function Ir(A){var e=O();try{W(A)()}catch(g){if(K(e),g!==g+0)throw g;_(1,0)}}function Cr(A,e,g){var i=O();try{W(A)(e,g)}catch(s){if(K(i),s!==s+0)throw s;_(1,0)}}function or(A,e,g,i){var s=O();try{return W(A)(e,g,i)}catch(B){if(K(s),B!==B+0)throw B;_(1,0)}}function Er(A,e,g,i,s){var B=O();try{return W(A)(e,g,i,s)}catch(a){if(K(B),a!==a+0)throw a;_(1,0)}}function nr(A,e,g,i){var s=O();try{return W(A)(e,g,i)}catch(B){if(K(s),B!==B+0)throw B;_(1,0)}}function hr(A,e,g,i,s,B){var a=O();try{return W(A)(e,g,i,s,B)}catch(Q){if(K(a),Q!==Q+0)throw Q;_(1,0)}}function cr(A,e,g,i){var s=O();try{W(A)(e,g,i)}catch(B){if(K(s),B!==B+0)throw B;_(1,0)}}function lr(A){var e=O();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(){r.calledRun=!0,!Z&&(It(),X?.(r),r.onRuntimeInitialized?.(),Ct())}r.setStatus?(r.setStatus("Running..."),setTimeout(()=>{setTimeout(()=>r.setStatus(""),1),A()},1)):A()}function ur(){if(r.preInit)for(typeof r.preInit=="function"&&(r.preInit=[r.preInit]);r.preInit.length>0;)r.preInit.shift()()}return ur(),te(),oe?t=r:t=new Promise((A,e)=>{X=A,V=e}),t}),tt=dr;var TA=tt(),xA=navigator.gpu?.requestAdapter({powerPreference:"high-performance"}),re=xA?.then(async Y=>{if(!Y)return null;let t=Y.limits,r=Y.features,C=await Y.requestDevice({requiredFeatures:r.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(!xA||!re)throw new Error("WebGPU supported, but failed to create adapter or device!");import{mat4 as Bt,vec3 as ie}from"gl-matrix";var FA=class{constructor(t,r){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.
16
+ `;var w=new Function(...I,B)(...E),x=`methodCaller<(${r.map(P=>P.name).join(", ")}) => ${s.name}>`;return Sg(zA(x,w))},Jg=(A,e)=>(A=k.toValue(A),e=k.toValue(e),k.toHandle(A[e])),Tg=A=>{A>9&&(oA[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 U;d(1,A)},Pe=()=>ZA||Je>0,He=A=>{U=A,Pe()||(i.onExit?.(A),X=!0),d(A,new ne(A))},Zg=(A,e)=>{U=A,He(A)},Kg=Zg,Og=()=>{if(!Pe())try{Kg(U)}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)),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:_)(be(g)),g.length=0):g.push(e)},gi=(A,e,g,r)=>{for(var s=0,B=0;B<g;B++){var a=m[e>>2],Q=m[e+4>>2];e+=8;for(var I=0;I<Q;I++)ti(A,v[a+I]);s+=Q}return m[r>>2]=s,0},tA=new Uint8Array(123),BA=25;BA>=0;--BA)tA[48+BA]=52+BA,tA[65+BA]=BA,tA[97+BA]=26+BA;tA[43]=62,tA[47]=63,_t(),$t(),i.noExitRuntime&&(ZA=i.noExitRuntime),i.print&&(J=i.print),i.printErr&&(_=i.printErr),i.wasmBinary&&(H=i.wasmBinary),i.arguments&&(h=i.arguments),i.thisProgram&&(D=i.thisProgram);var We,ee,gA,Ze,L,Ke,Oe,Xe,Ve,ze,je,qe;function ii(A){We=A.da,ee=A.ea,gA=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:Ft,f:mt,B:Nt,o:vt,h:kt,H:Rt,W:Mt,t:St,N:bt,aa:eg,Z:gg,d:ig,L:sg,s:Qg,u:Ig,i:Cg,c:og,$:Eg,M:ug,n:Gg,Y:Fg,X:mg,O:Ng,F:vg,S:kg,q:Rg,R:Mg,_:qA,V:Ug,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:ai,r:oi,k:Ii,b:Qi,C:Ci,l:ci,D:Bi,E:He},hA=await ft();function si(A,e){var g=O();try{return W(A)(e)}catch(r){if(K(g),r!==r+0)throw r;L(1,0)}}function Bi(A,e,g,r,s,B,a,Q,I,E,n){var u=O();try{W(A)(e,g,r,s,B,a,Q,I,E,n)}catch(w){if(K(u),w!==w+0)throw w;L(1,0)}}function Qi(A,e){var g=O();try{W(A)(e)}catch(r){if(K(g),r!==r+0)throw r;L(1,0)}}function ai(A,e,g){var r=O();try{return W(A)(e,g)}catch(s){if(K(r),s!==s+0)throw s;L(1,0)}}function Ii(A){var e=O();try{W(A)()}catch(g){if(K(e),g!==g+0)throw g;L(1,0)}}function Ci(A,e,g){var r=O();try{W(A)(e,g)}catch(s){if(K(r),s!==s+0)throw s;L(1,0)}}function oi(A,e,g,r){var s=O();try{return W(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 W(A)(e,g,r,s)}catch(a){if(K(B),a!==a+0)throw a;L(1,0)}}function ni(A,e,g,r){var s=O();try{return W(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 a=O();try{return W(A)(e,g,r,s,B)}catch(Q){if(K(a),Q!==Q+0)throw Q;L(1,0)}}function ci(A,e,g,r){var s=O();try{W(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 W(A)()}catch(g){if(K(e),g!==g+0)throw g;L(1,0)}}function te(){if(IA>0){lA=te;return}if(at(),IA>0){lA=te;return}function A(){i.calledRun=!0,!X&&(It(),V?.(i),i.onRuntimeInitialized?.(),Ct())}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(),oe?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,o=await R.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(!_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 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.
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(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 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(o,t.means.byteLength+t.velocities.byteLength,l.data.count);r(v,l.data.duration)},this.#t.postMessage({type:"init",count:t.length,dynamic:!!t.dynamic,sab:o,meansOffset:h,velocitiesOffset:d,indicesOffset:F})}sort(t,r,C){this.#t.postMessage({type:"sort",view:t.slice(),proj:r.slice(),time:C})}#t=null};var gt=`/* gaussian_preprocess.wgsl
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 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(C,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:C,meansOffset:h,velocitiesOffset:d,indicesOffset:y})}sort(t,i,o){this.#r.postMessage({type:"sort",view:t.slice(),proj:i.slice(),time:o})}#r=null};var gt=`/* gaussian_preprocess.wgsl
21
21
  *
22
22
  * performs gaussian culling + preprocessing
23
23
  */
@@ -65,6 +65,8 @@ struct Params
65
65
  focalLengths: vec2f,
66
66
  viewPort: vec2f,
67
67
 
68
+ scaleMin: f32,
69
+ scaleMax: f32,
68
70
  colorMin: f32,
69
71
  colorMax: f32,
70
72
  shMin: f32,
@@ -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
  //---------------
@@ -191,13 +237,7 @@ fn preprocess(@builtin(global_invocation_id) GID: vec3u, @builtin(local_invocati
191
237
 
192
238
  //evalate sh:
193
239
  //---------------
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;
240
+ let dc = read_vec3_unorm16(&u_colors, idx) * (u_params.colorMax - u_params.colorMin) + u_params.colorMin;
201
241
  let dir = normalize(mean.xyz - u_params.camPos);
202
242
 
203
243
  var color = SH_C0 * dc;
@@ -206,9 +246,9 @@ fn preprocess(@builtin(global_invocation_id) GID: vec3u, @builtin(local_invocati
206
246
  let x = dir.x;
207
247
  let y = dir.y;
208
248
  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);
249
+ color += -SH_C1 * y * read_sh_coeffs(idx, 1) +
250
+ SH_C1 * z * read_sh_coeffs(idx, 2) -
251
+ SH_C1 * x * read_sh_coeffs(idx, 3);
212
252
 
213
253
  if(u_params.shDegree > 1)
214
254
  {
@@ -219,21 +259,21 @@ fn preprocess(@builtin(global_invocation_id) GID: vec3u, @builtin(local_invocati
219
259
  let yz = dir.y * dir.z;
220
260
  let xz = dir.x * dir.z;
221
261
 
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);
262
+ color += SH_C2[0] * xy * read_sh_coeffs(idx, 4) +
263
+ SH_C2[1] * yz * read_sh_coeffs(idx, 5) +
264
+ SH_C2[2] * (2.0 * zz - xx - yy) * read_sh_coeffs(idx, 6) +
265
+ SH_C2[3] * xz * read_sh_coeffs(idx, 7) +
266
+ SH_C2[4] * (xx - yy) * read_sh_coeffs(idx, 8);
227
267
 
228
268
  if(u_params.shDegree > 2)
229
269
  {
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);
270
+ color += SH_C3[0] * y * (3.0 * xx - yy) * read_sh_coeffs(idx, 9) +
271
+ SH_C3[1] * xy * z * read_sh_coeffs(idx, 10) +
272
+ SH_C3[2] * y * (4.0 * zz - xx - yy) * read_sh_coeffs(idx, 11) +
273
+ SH_C3[3] * z * (2.0 * zz - 3.0 * xx - 3.0 * yy) * read_sh_coeffs(idx, 12) +
274
+ SH_C3[4] * x * (4.0 * zz - xx - yy) * read_sh_coeffs(idx, 13) +
275
+ SH_C3[5] * z * (xx - yy) * read_sh_coeffs(idx, 14) +
276
+ SH_C3[6] * x * (xx - 3.0 * yy) * read_sh_coeffs(idx, 15);
237
277
  }
238
278
  }
239
279
  }
@@ -268,7 +308,7 @@ fn preprocess(@builtin(global_invocation_id) GID: vec3u, @builtin(local_invocati
268
308
  u_renderedGaussians[writeIdx].color = rgba;
269
309
  u_renderedGaussians[writeIdx].center = clipPos.xy / clipPos.w;
270
310
  }
271
- `;var rt=`/* gaussian_rasterize.wgsl
311
+ `;var it=`/* gaussian_rasterize.wgsl
272
312
  *
273
313
  * contains vertex and fragment shaders for rendering a single gaussian
274
314
  */
@@ -344,7 +384,7 @@ fn fs(in: VertexOutput) -> @location(0) vec4f
344
384
  let b = exp(a) * in.color.a;
345
385
  return vec4f(in.color.rgb * b, b);
346
386
  }
347
- `;var it=` struct VSOut {
387
+ `;var rt=` struct VSOut {
348
388
  @builtin(position) pos : vec4<f32>,
349
389
  @location(0) uv : vec2<f32>,
350
390
  };
@@ -370,7 +410,7 @@ fn fs(in: VertexOutput) -> @location(0) vec4f
370
410
  let c = textureSample(colorTex, colorSampler, in.uv);
371
411
  // output premultiplied-like color: rgb in src, alpha = src.a
372
412
  return vec4<f32>(c.rgb, c.a);
373
- }`;var z=Float32Array.BYTES_PER_ELEMENT,EA=Uint32Array.BYTES_PER_ELEMENT,st=64,pA=4,yr=.001,Fr=.001,pr=0,se=class{constructor(t){this.#g=t}async initialize(){this.#t=await TA,this.#A=await re,this.#o=await xA,this.#d=this.#p(),this.#c=this.#m(),this.#D=this.#y(),this.#f=this.#N(),this.#u=this.#v(),this.#s=this.#F(),this.#I=this.#S(),this.#o.features.has("timestamp-query")&&(this.#r=this.#U())}resize(){this.#c=this.#m()}setGaussians(t){this.#B=this.#a?this.#t.combine(t,this.#a):t,this.#e=this.#G(this.#B);let r=new FA(this.#B,(C,o)=>{this.#i=!1,this.#E==r&&(this.#H(C),this.#n=!0,this.#h.lastSortTime=o)});this.#n=!1,this.#C=null,this.#E=r}setScene(t){this.#a=t}draw(t,r,C,o={},h=!1){if(!this.#B||(this.#r==null&&(h=!1),!this.#i&&this.#b(t,C)&&(this.#i=!0,this.#E.sort(t,r,C),this.#C={view:t.slice(),time:C}),!this.#n))return;let D=performance.now();var d=0;this.#w&&(d=D-this.#w),this.#w=D;let w=ie.transformMat4(ie.create(),ie.fromValues(0,0,0),Bt.invert(Bt.create(),t)),F=[r[0]*(this.#g.width/2),r[5]*(this.#g.height/2)],l=[this.#g.width,this.#g.height];this.#M(t,r,w,F,l,C);let v=this.#k(),J=null,x=null;h&&(J=this.#A.createBuffer({size:pA*8,usage:GPUBufferUsage.QUERY_RESOLVE|GPUBufferUsage.COPY_SRC}),x=this.#A.createBuffer({size:pA*8,usage:GPUBufferUsage.COPY_DST|GPUBufferUsage.MAP_READ}));let P=this.#A.createCommandEncoder(),Z=P.beginComputePass({timestampWrites:h?{querySet:this.#r.querySet,beginningOfPassWriteIndex:0,endOfPassWriteIndex:1}:void 0});Z.setPipeline(this.#D),Z.setBindGroup(0,v.preprocess),this.#Q>0&&Z.dispatchWorkgroups(Math.ceil(this.#Q/st)),Z.end();let M=P.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.#r.querySet,beginningOfPassWriteIndex:2,endOfPassWriteIndex:3}:void 0});M.setPipeline(this.#f),M.setVertexBuffer(0,this.#s.vertex),M.setIndexBuffer(this.#s.index,"uint16"),M.setBindGroup(0,v.rasterize),this.#Q>0&&M.drawIndexed(6,this.#Q),M.end();let X=o.backgroundColor??[0,0,0],V=P.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&&(P.resolveQuerySet(this.#r.querySet,0,pA,J,0),P.copyBufferToBuffer(J,0,x,0,pA*8)),this.#A.queue.submit([P.finish()]),h&&x.mapAsync(GPUMapMode.READ).then(()=>{let j=x.getMappedRange(),k=new BigUint64Array(j);if(this.#r.accumFrames++,this.#r.accumTime+=d,this.#r.accumPreprocessTime+=Number(k[1]-k[0]),this.#r.accumRasterTime+=Number(k[3]-k[2]),x.unmap(),this.#r.accumTime>=1e3){let U=this.#r.accumPreprocessTime/1e6/this.#r.accumFrames,m=this.#r.accumRasterTime/1e6/this.#r.accumFrames,p=U+m;this.#h.preprocessTime=U,this.#h.rasterTime=m,this.#h.totalTime=p,this.#r.accumFrames=0,this.#r.accumTime=0,this.#r.accumPreprocessTime=0,this.#r.accumRasterTime=0}})}getPerformanceProfile(){return this.#h}#t=null;#A=null;#o=null;#g=null;#d=null;#c=null;#D=null;#f=null;#u=null;#r=null;#a=null;#B=null;#e=null;#s=null;#I=null;#Q=0;#E=null;#n=!1;#i=!1;#C=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,r=this.#g.height|0;if(t==0||r==0)return;let C=navigator.gpu.getPreferredCanvasFormat(),o=this.#A.createTexture({size:[t,r,1],format:C,usage:GPUTextureUsage.RENDER_ATTACHMENT|GPUTextureUsage.TEXTURE_BINDING});return{tex:o,view:o.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:rt});return this.#A.createRenderPipeline({label:"gaussian",layout:"auto",vertex:{module:t,entryPoint:"vs",buffers:[{stepMode:"vertex",arrayStride:2*z,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:it});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"}})}#U(){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]),r=this.#A.createBuffer({label:"quad vertices",size:t.byteLength,usage:GPUBufferUsage.VERTEX|GPUBufferUsage.COPY_DST});this.#A.queue.writeBuffer(r,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:r,index:o}}#S(){let t=0;return t+=16*z,t+=16*z,t+=3*z,t+=1*EA,t+=2*z,t+=2*z,t+=2*z,t+=2*z,t+=1*EA,t+=1*z,t+=2*EA,this.#A.createBuffer({label:"params",size:t,usage:GPUBufferUsage.UNIFORM|GPUBufferUsage.COPY_DST})}#G(t){let r=12*z,C=this.#l(this.#e?.means,{label:"means",size:t.means.byteLength,usage:GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_DST});this.#A.queue.writeBuffer(C,0,t.means);let o=this.#l(this.#e?.covariances,{label:"covariances",size:t.covariances.byteLength,usage:GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_DST});this.#A.queue.writeBuffer(o,0,t.covariances);let h=this.#l(this.#e?.opacities,{label:"opacities",size:this.#Y(t.opacities.byteLength,EA),usage:GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_DST});this.#R(h,t.opacities);let D=this.#l(this.#e?.colors,{label:"colors",size:this.#Y(t.colors.byteLength,EA),usage:GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_DST});this.#R(D,t.colors);let d=this.#l(this.#e?.shs,{label:"spherical harmomics",size:this.#Y(t.shs.byteLength,EA),usage:GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_DST});this.#R(d,t.shs);let w=this.#l(this.#e?.velocities,{label:"velocities",size:Math.max(t.velocities.byteLength,4*z),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*r,usage:GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_DST|GPUBufferUsage.INDIRECT});return{means:C,covariances:o,opacities:h,colors:D,shs:d,velocities:w,sortedIndices:F,rendered:l}}#M(t,r,C,o,h,D){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(r,l),l+=16,w.set(C,l),l+=3,F.set([this.#B.shDegree],l),l+=1,w.set(o,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([D],l),l+=1,F.set([this.#Q],l),l+=1,this.#A.queue.writeBuffer(this.#I,0,d)}#k(){let t=this.#A.createBindGroup({label:"gaussian preprocess",layout:this.#D.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}}]}),r=this.#A.createBindGroup({label:"gaussian rasterize",layout:this.#f.getBindGroupLayout(0),entries:[{binding:0,resource:{buffer:this.#I}},{binding:1,resource:{buffer:this.#e.rendered}}]}),C=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:r,composite:C}}#b(t,r){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]],w=1-(o[0]*D[0]+o[1]*D[1]+o[2]*D[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(r-this.#C.time);return w>yr||F>Fr||l>pr}#H(t){this.#Q=t.length,this.#A.queue.writeBuffer(this.#e.sortedIndices,0,t)}#l(t,r){return t==null||t.size<r.size?(t?.destroy(),this.#A.createBuffer(r)):t}#R(t,r){let C,o,h;r instanceof ArrayBuffer?(C=r,o=0,h=r.byteLength):(C=r.buffer,o=r.byteOffset,h=r.byteLength);let D=h&-4;D>0&&this.#A.queue.writeBuffer(t,0,C,o,D);let d=h-D;if(d>0){let w=new Uint8Array(4);w.set(new Uint8Array(C,o+D,d)),this.#A.queue.writeBuffer(t,D,w,0,4)}}#Y(t,r){return t==0?r:t+r-1&~(r-1)}},Qt=se;import{mat4 as S,vec3 as c}from"gl-matrix";var mA=class Y{constructor(){if(new.target===Y)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 r=this.fov||80;return S.perspective(S.create(),r*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=r=>this.onMouseDown(r),this._onMouseUp=r=>this.onMouseUp(r),this._onMouseMove=r=>this.onMouseMove(r),this._onMouseLeave=r=>this.onMouseUp(r),this._onDoubleClick=r=>this.onDoubleClick(r),this._onWheel=r=>{this.onScroll!==Y.prototype.onScroll&&r.preventDefault(),this.onScroll(r.deltaY)},this._onTouchStart=r=>{this.onTouchStart!=Y.prototype.onTouchStart&&r.preventDefault(),this.onTouchStart(r)},this._onTouchMove=r=>{this.onTouchMove!=Y.prototype.onTouchMove&&r.preventDefault(),this.onTouchMove(r)},this._onTouchEnd=r=>{this.onTouchEnd!=Y.prototype.onTouchEnd&&r.preventDefault(),this.onTouchEnd(r)},this._onKeyDown=r=>{this._editingSomething()||(r.code==="Space"&&r.preventDefault(),this.onKeyDown(r))},this._onKeyUp=r=>{this._editingSomething()||(r.code==="Space"&&r.preventDefault(),this.onKeyUp(r))},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 S.lookAt(S.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 r=t.clientX-this.mouseX,C=t.clientY-this.mouseY;this.targetTheta+=r*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 r=t.touches[0],C=t.touches[1];this.pinchStartDistance=Math.hypot(C.clientX-r.clientX,C.clientY-r.clientY)}}onTouchMove(t){if(t.touches.length===1&&this.dragging){let r=t.touches[0],C=r.clientX-this.mouseX,o=r.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=r.clientX,this.mouseY=r.clientY}else if(t.touches.length===2){let r=t.touches[0],C=t.touches[1],o=Math.hypot(C.clientX-r.clientX,C.clientY-r.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 r=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),r)),this.radius+=(this.targetRadius-this.radius)*r,this.theta+=(this.targetTheta-this.theta)*r,this.phi+=(this.targetPhi-this.phi)*r,this.keysPressed.size>0&&this.handleKeyboardMovement(t)}handleKeyboardMovement(t){let r=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,w=0,F=0;this.keysPressed.has("KeyW")&&(d+=h,F+=D),this.keysPressed.has("KeyS")&&(d-=h,F-=D),this.keysPressed.has("KeyA")&&(d+=C,F+=o),this.keysPressed.has("KeyD")&&(d-=C,F-=o),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)),r))}},_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),r=this.targetY+this.radius*Math.sin(this.phi),C=this.targetZ+this.radius*Math.cos(this.theta)*Math.cos(this.phi);return S.lookAt(S.create(),c.fromValues(t,r,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 r=t.clientX-this.mouseX,C=t.clientY-this.mouseY,o=this.targetTheta-this.baseTheta,h=this.targetPhi-this.basePhi,D=this.#t(o,h,this.resistance);this.targetTheta+=r*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 r=t.touches[0];this.rotating=!0,this.mouseX=r.clientX,this.mouseY=r.clientY}else if(t.touches.length===2){this.rotating=!1;let r=t.touches[0],C=t.touches[1];this.pinchStartDistance=Math.hypot(C.clientX-r.clientX,C.clientY-r.clientY)}}onTouchMove(t){if(t.touches.length===1&&this.rotating){let r=t.touches[0],C=r.clientX-this.mouseX,o=r.clientY-this.mouseY,h=this.targetTheta-this.baseTheta,D=this.targetPhi-this.basePhi,d=this.#t(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=r.clientX,this.mouseY=r.clientY}else if(t.touches.length===2){let r=t.touches[0],C=t.touches[1],o=Math.hypot(C.clientX-r.clientX,C.clientY-r.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 r=t.touches[0];this.mouseX=r.clientX,this.mouseY=r.clientY}}update(t){super.update(t);let r=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)*r,this.targetPhi+=(o.phi-this.targetPhi)*r,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))}}#t(t,r,C){let h=Math.hypot(t,r)/(1-C);return 1/(1+h*h)}#A(t,r,C,o,h){let D=t-C,d=r-o,w=Math.hypot(D,d);if(w<=h)return{theta:t,phi:r};{let F=h/w;return{theta:C+D*F,phi:o+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}}},LA=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=S.invert(S.create(),S.lookAt(S.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 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),w=c.transformMat4(c.create(),c.fromValues(-o,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,D),J=c.sub(c.create(),w,D),x=c.sub(c.create(),D,l),P=c.sub(c.create(),d,l),Z=c.sub(c.create(),w,l);v=c.normalize(c.create(),v),J=c.normalize(c.create(),J);let M=c.scale(c.create(),c.cross(c.create(),v,J),1),X=-c.dot(x,M),V=c.dot(v,x)*.01/X,j=c.dot(v,P)*.01/X,k=c.dot(J,x)*.01/X,U=c.dot(J,Z)*.01/X,m=S.create();m[0]=2*.01/(j-V),m[4]=0,m[8]=(j+V)/(j-V),m[12]=0,m[1]=0,m[5]=2*.01/(U-k),m[9]=(U+k)/(U-k),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=S.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]=M[0],p[6]=M[1],p[10]=M[2],p[14]=0,p[3]=0,p[7]=0,p[11]=0,p[15]=1;let QA=S.translate(S.create(),S.identity(S.create()),c.scale(c.create(),l,-1));return{view:S.mul(S.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"});TA.then(C=>{this.#t=C,this.#v()});let r=document.createElement("div");r.style.position="relative",r.style.width="100%",r.style.height="100%",r.style.overflow="hidden",t.appendChild(r),this.#A=document.createElement("canvas"),Object.assign(this.#A.style,{width:"100%",height:"100%",display:"block"}),r.appendChild(this.#A),this.#C=document.createElement("div"),Object.assign(this.#C.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"}),r.appendChild(this.#C),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"}),r.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.#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.#I=!1,this.#i.addEventListener("input",()=>{this.#s=parseFloat(this.#i.value)}),this.#i.addEventListener("pointerdown",()=>{this.#I=!0}),this.#i.addEventListener("pointerup",()=>{this.#I=!1}),this.#E.appendChild(this.#i)}connectedCallback(){this.#o=new Qt(this.#A),this.#g=new cA,this.#g.attachToCanvas(this.#A),this.#d=new ResizeObserver(t=>{let r=t[0],C=Math.round(r.contentBoxSize[0].inlineSize*window.devicePixelRatio),o=Math.round(r.contentBoxSize[0].blockSize*window.devicePixelRatio),h=r.target;h.width=C,h.height=o,this.#o.resize()}),this.clear(),this.#o.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,r,C){if(r!==C)switch(t){case"src":{C==null?this.#h(null):this.#m(C).then(o=>{this.#F(()=>{C.endsWith(".ply")?this.#h(this.#t.loadPly(o)):this.#h(this.#t.decode(o))})});break}case"scene":{C==null?this.#p(null):this.#m(C).then(o=>{this.#F(()=>{C.endsWith(".ply")?this.#p(this.#t.loadPly(o)):this.#p(this.#t.decode(o)),this.#B=!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.#r.backgroundColor=o)}catch{}break}case"loop":this.#c=this.hasAttribute("loop");break;case"autoplay":this.#D=this.hasAttribute("autoplay");break;case"controls":this.#f=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,r){this.#g.detachFromCanvas(),t==="default"?this.#g=new cA(r):t==="snap"?this.#g=new _A(r):t==="window"?this.#g=new LA(r):(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 r=this.#a[0].metadata.duration;if(t<0||t>r){console.warn("Setting out-of-bounds currentTime");return}this.#s=t}get currentSegment(){return this.#a[0]}#t=null;#A=null;#o=null;#g=null;#d=null;#c=!1;#D=!1;#f=!1;#u=!1;#r={};#a=[];#B=!1;#e=null;#s=0;#I=!1;#Q=!1;#E=null;#n=null;#i=null;#C=null;#w(t){t/=1e3;var r=0;this.#e&&(r=t-this.#e),this.#Q&&!this.#I&&(this.#s+=r);let C=this.#a[0],o=C.metadata.duration,h=!1;for(;this.#s>=o&&this.#a.length>1;)o>0&&this.onSegmentEnd?.(!1),this.#s-=o,this.#a.shift(),C=this.#a[0],o=C.metadata.duration,h=!0;(h||this.#B)&&(this.#o.setGaussians(C.gaussians),this.#B=!1),this.#c?this.#s%=o>0?o:1:this.#s>o&&(o>0&&this.onSegmentEnd?.(!0),this.#s=o,this.#Q=!1);let D=this.#f&&o>0;Object.assign(this.#E.style,{display:D?"flex":"none"}),this.#n.textContent=this.#Q?"\u23F8\uFE0F":"\u25B6\uFE0F",this.#i.max=o,!this.#I&&this.#i&&(this.#i.value=this.#s),this.#e=t,this.#g.update(r*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/(o>0?o:1);this.#o.draw(d,w,F,this.#r,this.#u);let l=this.#o.getPerformanceProfile();Object.assign(this.#C.style,{display:this.#u?"flex":"none"}),this.#C.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.#D,this.#B=!0}#p(t){this.#o.setScene(t.gaussians)}async#m(t){let r=await fetch(t);if(!r.ok)throw new Error("Failed to fetch buffer at "+t);return await r.arrayBuffer()}#y(t){return(t?.toFixed(2)??"N/A")+" ms"}#N=Promise.resolve();#v=null;#U=new Promise(t=>this.#v=t);#F(t){return this.#N=this.#N.then(async()=>(await this.#U,await t()),r=>{throw console.error("Enqueuing call failed: ",r),r}),this.#N}};customElements.define("dgs-player",Be);export{Be as DGSPlayer};
413
+ }`;var Z=Float32Array.BYTES_PER_ELEMENT,rA=Uint32Array.BYTES_PER_ELEMENT,st=64,GA=4,pi=.001,yi=.001,Gi=0,se=class{constructor(t){this.#e=t}async initialize(){this.#r=await TA,this.#A=await ie,this.#o=await _A,this.#u=this.#G(),this.#c=this.#w(),this.#d=this.#m(),this.#f=this.#N(),this.#l=this.#p(),this.#B=this.#v(),this.#I=this.#k(),this.#o.features.has("timestamp-query")&&(this.#t=this.#F())}resize(){this.#c=this.#w()}setGaussians(t){this.#s=this.#a?this.#r.combine(t,this.#a):t,this.#g=this.#y(this.#s);let i=new yA(this.#s,(o,C)=>{this.#i=!1,this.#E==i&&(this.#S(o),this.#n=!0,this.#h.lastSortTime=C)});this.#n=!1,this.#C=null,this.#E=i}setScene(t){this.#a=t}draw(t,i,o,C={},h=!1){if(!this.#s||(this.#t==null&&(h=!1),!this.#i&&this.#U(t,o)&&(this.#i=!0,this.#E.sort(t,i,o),this.#C={view:t.slice(),time:o}),!this.#n))return;let D=performance.now();var d=0;this.#D&&(d=D-this.#D),this.#D=D;let p=re.transformMat4(re.create(),re.fromValues(0,0,0),Bt.invert(Bt.create(),t)),y=[i[0]*(this.#e.width/2),i[5]*(this.#e.height/2)],l=[this.#e.width,this.#e.height];this.#Y(t,i,p,y,l,o);let N=this.#M(),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 H=this.#A.createCommandEncoder(),X=H.beginComputePass({timestampWrites:h?{querySet:this.#t.querySet,beginningOfPassWriteIndex:0,endOfPassWriteIndex:1}:void 0});X.setPipeline(this.#d),X.setBindGroup(0,N.preprocess),this.#Q>0&&X.dispatchWorkgroups(Math.ceil(this.#Q/st)),X.end();let U=H.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.#t.querySet,beginningOfPassWriteIndex:2,endOfPassWriteIndex:3}:void 0});U.setPipeline(this.#f),U.setVertexBuffer(0,this.#B.vertex),U.setIndexBuffer(this.#B.index,"uint16"),U.setBindGroup(0,N.rasterize),this.#Q>0&&U.drawIndexed(6,this.#Q),U.end();let V=C.backgroundColor??[0,0,0],z=H.beginRenderPass({label:"composite",colorAttachments:[{view:this.#u.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&&(H.resolveQuerySet(this.#t.querySet,0,GA,J,0),H.copyBufferToBuffer(J,0,_,0,GA*8)),this.#A.queue.submit([H.finish()]),h&&_.mapAsync(GPUMapMode.READ).then(()=>{let j=_.getMappedRange(),S=new BigUint64Array(j);if(this.#t.accumFrames++,this.#t.accumTime+=d,this.#t.accumPreprocessTime+=Number(S[1]-S[0]),this.#t.accumRasterTime+=Number(S[3]-S[2]),_.unmap(),this.#t.accumTime>=1e3){let v=this.#t.accumPreprocessTime/1e6/this.#t.accumFrames,F=this.#t.accumRasterTime/1e6/this.#t.accumFrames,G=v+F;this.#h.preprocessTime=v,this.#h.rasterTime=F,this.#h.totalTime=G,this.#t.accumFrames=0,this.#t.accumTime=0,this.#t.accumPreprocessTime=0,this.#t.accumRasterTime=0}})}getPerformanceProfile(){return this.#h}#r=null;#A=null;#o=null;#e=null;#u=null;#c=null;#d=null;#f=null;#l=null;#t=null;#a=null;#s=null;#g=null;#B=null;#I=null;#Q=0;#E=null;#n=!1;#i=!1;#C=null;#D=null;#h={};#G(){let t=this.#e.getContext("webgpu");return t.configure({device:this.#A,format:navigator.gpu.getPreferredCanvasFormat(),alphaMode:"opaque"}),t}#w(){let t=this.#e.width|0,i=this.#e.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"})}}#m(){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*Z,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"}})}#p(){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"}})}#F(){return{querySet:this.#A.createQuerySet({type:"timestamp",count:GA}),accumFrames:0,accumTime:0,accumRasterTime:0,accumPreprocessTime:0}}#v(){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}}#k(){let t=0;return t+=16*Z,t+=16*Z,t+=3*Z,t+=1*rA,t+=2*Z,t+=2*Z,t+=2*Z,t+=2*Z,t+=2*Z,t+=1*rA,t+=1*Z,t+=4*rA,this.#A.createBuffer({label:"params",size:t,usage:GPUBufferUsage.UNIFORM|GPUBufferUsage.COPY_DST})}#y(t){let i={};return[{name:"means",alignment:4*Z},{name:"scales",alignment:rA},{name:"rotations",alignment:rA},{name:"opacities",alignment:rA},{name:"colors",alignment:rA},{name:"shs",alignment:rA},{name:"velocities",alignment:4*Z}].forEach(C=>{i[C.name]=this.#R(this.#g?.[C.name],{label:C.name,size:this.#x(t[C.name].byteLength,C.alignment),usage:GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_DST}),this.#b(i[C.name],t[C.name])}),i.sortedIndices=this.#R(this.#g?.sortedIndices,{label:"sorted indices",size:Math.max(t.length,1)*rA,usage:GPUBufferUsage.COPY_DST|GPUBufferUsage.STORAGE}),i.rendered=this.#R(this.#g?.rendered,{label:"rendered gaussians",size:Math.max(t.length,1)*12*Z,usage:GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_DST|GPUBufferUsage.INDIRECT}),i}#Y(t,i,o,C,h,D){let d=new ArrayBuffer(this.#I.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(o,l),l+=3,y.set([this.#s.shDegree],l),l+=1,p.set(C,l),l+=2,p.set(h,l),l+=2,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,y.set([Number(this.#s.dynamic)],l),l+=1,p.set([D],l),l+=1,y.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.#d.getBindGroupLayout(0),entries:[{binding:0,resource:{buffer:this.#I}},{binding:1,resource:{buffer:this.#g.means}},{binding:2,resource:{buffer:this.#g.scales}},{binding:3,resource:{buffer:this.#g.rotations}},{binding:4,resource:{buffer:this.#g.opacities}},{binding:5,resource:{buffer:this.#g.colors}},{binding:6,resource:{buffer:this.#g.shs}},{binding:7,resource:{buffer:this.#g.velocities}},{binding:8,resource:{buffer:this.#g.sortedIndices}},{binding:9,resource:{buffer:this.#g.rendered}}]}),i=this.#A.createBindGroup({label:"gaussian rasterize",layout:this.#f.getBindGroupLayout(0),entries:[{binding:0,resource:{buffer:this.#I}},{binding:1,resource:{buffer:this.#g.rendered}}]}),o=this.#A.createBindGroup({label:"composite",layout:this.#l.getBindGroupLayout(0),entries:[{binding:0,resource:this.#c.view},{binding:1,resource:this.#c.sampler}]});return{preprocess:t,rasterize:i,composite:o}}#U(t,i){if(this.#C==null)return!0;let o=this.#C.view,C=[t[2],t[6],t[10]],h=[t[12],t[13],t[14]],D=[o[2],o[6],o[10]],d=[o[12],o[13],o[14]],p=1-(C[0]*D[0]+C[1]*D[1]+C[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}#S(t){this.#Q=t.length,this.#A.queue.writeBuffer(this.#g.sortedIndices,0,t)}#R(t,i){return t==null||t.size<i.size?(t?.destroy(),this.#A.createBuffer(i)):t}#b(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 D=h&-4;D>0&&this.#A.queue.writeBuffer(t,0,o,C,D);let d=h-D;if(d>0){let p=new Uint8Array(4);p.set(new Uint8Array(o,C+D,d)),this.#A.queue.writeBuffer(t,D,p,0,4)}}#x(t,i){return t==0?i:t+i-1&~(i-1)}},Qt=se;import{mat4 as Y,vec3 as c}from"gl-matrix";var FA=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 FA{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,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),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+=o,y+=C),this.keysPressed.has("KeyD")&&(d-=o,y-=C),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 FA{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 Y.lookAt(Y.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,D=this.#r(C,h,this.resistance);this.targetTheta+=i*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=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,D=this.targetPhi-this.basePhi,d=this.#r(h,D,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))}}#r(t,i,o){let h=Math.hypot(t,i)/(1-o);return 1/(1+h*h)}#A(t,i,o,C,h){let D=t-o,d=i-C,p=Math.hypot(D,d);if(p<=h)return{theta:t,phi:i};{let y=h/p;return{theta:o+D*y,phi:C+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 FA{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 C=t>1?1:t,h=t>1?1/t:1;C*=this.screenScale,h*=this.screenScale;let D=c.transformMat4(c.create(),c.fromValues(-C,-h,0),this.screenTransform),d=c.transformMat4(c.create(),c.fromValues(C,-h,0),this.screenTransform),p=c.transformMat4(c.create(),c.fromValues(-C,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),H=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 U=c.scale(c.create(),c.cross(c.create(),N,J),1),V=-c.dot(_,U),z=c.dot(N,_)*.01/V,j=c.dot(N,H)*.01/V,S=c.dot(J,_)*.01/V,v=c.dot(J,X)*.01/V,F=Y.create();F[0]=2*.01/(j-z),F[4]=0,F[8]=(j+z)/(j-z),F[12]=0,F[1]=0,F[5]=2*.01/(v-S),F[9]=(v+S)/(v-S),F[13]=0,F[2]=0,F[6]=0,F[10]=(100+.01)/(.01-100),F[14]=200*.01/(.01-100),F[3]=0,F[7]=0,F[11]=-1,F[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]=U[0],G[6]=U[1],G[10]=U[2],G[14]=0,G[3]=0,G[7]=0,G[11]=0,G[15]=1;let aA=Y.translate(Y.create(),Y.identity(Y.create()),c.scale(c.create(),l,-1));return{view:Y.mul(Y.create(),G,aA),proj:F}}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(o=>{this.#r=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.#C=document.createElement("div"),Object.assign(this.#C.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.#C),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.#B>=this.#a[0].metadata.duration&&(this.#B=0)}),this.#E.appendChild(this.#n),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.#I=!1,this.#i.addEventListener("input",()=>{this.#B=parseFloat(this.#i.value)}),this.#i.addEventListener("pointerdown",()=>{this.#I=!0}),this.#i.addEventListener("pointerup",()=>{this.#I=!1}),this.#E.appendChild(this.#i)}connectedCallback(){this.#o=new Qt(this.#A),this.#e=new cA,this.#e.attachToCanvas(this.#A),this.#u=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.#o.resize()}),this.clear(),this.#o.initialize().then(()=>{this.#u.observe(this.#A),requestAnimationFrame(t=>{this.#D(t)})})}disconnectedCallback(){this.#e.detachFromCanvas(),this.#u.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.#N(o).then(C=>{this.#y(()=>{o.endsWith(".ply")?this.#h(this.#m(C)):this.#h(this.#w(C))})});break}case"scene":{o==null?this.#G(null):this.#N(o).then(C=>{this.#y(()=>{o.endsWith(".ply")?this.#G(this.#m(C)):this.#G(this.#w(C)),this.#s=!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.#t.backgroundColor=C)}catch{}break}case"loop":this.#c=this.hasAttribute("loop");break;case"autoplay":this.#d=this.hasAttribute("autoplay");break;case"controls":this.#f=this.hasAttribute("controls");break;case"debug":this.#l=this.hasAttribute("debug");break;default:break}}play(){this.#Q=!0}pause(){this.#Q=!1}enqueue(t){this.#y(()=>{this.#a.push(this.#w(t))})}clear(){this.#y(()=>{this.#a=[{gaussians:new this.#r.Gaussians,metadata:{duration:0}}],this.#s=!0})}setCamera(t,i){this.#e.detachFromCanvas(),t==="default"?this.#e=new cA(i):t==="snap"?this.#e=new LA(i):t==="window"?this.#e=new PA(i):(console.warn("Invalid camera provided, defaulting to 'default'"),this.#e=new cA),this.#e.attachToCanvas(this.#A)}get paused(){return!this.#Q}get currentTime(){return this.#B}set currentTime(t){let i=this.#a[0].metadata.duration;if(t<0||t>i){console.warn("Setting out-of-bounds currentTime");return}this.#B=t}get currentSegment(){return this.#a[0]}#r=null;#A=null;#o=null;#e=null;#u=null;#c=!1;#d=!1;#f=!1;#l=!1;#t={};#a=[];#s=!1;#g=null;#B=0;#I=!1;#Q=!1;#E=null;#n=null;#i=null;#C=null;#D(t){t/=1e3;var i=0;this.#g&&(i=t-this.#g),this.#Q&&!this.#I&&(this.#B+=i);let o=this.#a[0],C=o.metadata.duration,h=!1;for(;this.#B>=C&&this.#a.length>1;)C>0&&this.onSegmentEnd?.(!1),this.#B-=C,this.#a.shift(),o=this.#a[0],C=o.metadata.duration,h=!0;(h||this.#s)&&(this.#o.setGaussians(o.gaussians),this.#s=!1),this.#c?this.#B%=C>0?C:1:this.#B>C&&(C>0&&this.onSegmentEnd?.(!0),this.#B=C,this.#Q=!1);let D=this.#f&&C>0;Object.assign(this.#E.style,{display:D?"flex":"none"}),this.#n.textContent=this.#Q?"\u23F8\uFE0F":"\u25B6\uFE0F",this.#i.max=C,!this.#I&&this.#i&&(this.#i.value=this.#B),this.#g=t,this.#e.update(i*1e3);let d=this.#e.getViewMatrix(this.#A.width/this.#A.height),p=this.#e.getProjMatrix(this.#A.width/this.#A.height),y=this.#B/(C>0?C:1);this.#o.draw(d,p,y,this.#t,this.#l);let l=this.#o.getPerformanceProfile();Object.assign(this.#C.style,{display:this.#l?"flex":"none"}),this.#C.textContent=`Frame Time: ${this.#p(l.totalTime)}
414
+ - Preprocess: ${this.#p(l.preprocessTime)}
415
+ - Raster: ${this.#p(l.rasterTime)}
416
+ Last Sort Time: ${this.#p(l.lastSortTime)}`,requestAnimationFrame(N=>{this.#D(N)})}#h(t){this.#a=[t],this.#B=0,this.#Q=this.#d,this.#s=!0}#G(t){this.#o.setScene(t.gaussians)}#w(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.5",
3
+ "version": "1.1.0",
4
4
  "main": "dist/index.js",
5
5
  "files": [
6
6
  "dist/**/*"