rayzee 5.10.2 → 6.0.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 (43) hide show
  1. package/README.md +82 -22
  2. package/dist/assets/AIUpscalerWorker-AXN-lKWN.js +2 -0
  3. package/dist/assets/AIUpscalerWorker-AXN-lKWN.js.map +1 -0
  4. package/dist/rayzee.es.js +1299 -1843
  5. package/dist/rayzee.es.js.map +1 -1
  6. package/dist/rayzee.umd.js +50 -74
  7. package/dist/rayzee.umd.js.map +1 -1
  8. package/package.json +1 -4
  9. package/src/AssetConfig.js +56 -0
  10. package/src/EngineDefaults.js +5 -3
  11. package/src/EngineEvents.js +1 -0
  12. package/src/Passes/AIUpscaler.js +44 -22
  13. package/src/Passes/OIDNDenoiser.js +4 -104
  14. package/src/PathTracerApp.js +59 -63
  15. package/src/Processor/AssetLoader.js +5 -2
  16. package/src/Processor/TextureCreator.js +42 -15
  17. package/src/Processor/Workers/AIUpscalerWorker.js +21 -6
  18. package/src/Stages/ASVGF.js +6 -27
  19. package/src/Stages/AdaptiveSampling.js +10 -26
  20. package/src/Stages/PathTracer.js +4 -5
  21. package/src/TSL/BVHTraversal.js +2 -18
  22. package/src/TSL/Clearcoat.js +1 -2
  23. package/src/TSL/Common.js +0 -13
  24. package/src/TSL/EmissiveSampling.js +0 -16
  25. package/src/TSL/Environment.js +0 -7
  26. package/src/TSL/LightsDirect.js +3 -379
  27. package/src/TSL/LightsSampling.js +0 -171
  28. package/src/TSL/MaterialEvaluation.js +3 -103
  29. package/src/TSL/MaterialProperties.js +1 -56
  30. package/src/TSL/MaterialSampling.js +2 -284
  31. package/src/TSL/MaterialTransmission.js +0 -93
  32. package/src/TSL/Random.js +0 -23
  33. package/src/TSL/Struct.js +0 -21
  34. package/src/TSL/TextureSampling.js +0 -69
  35. package/src/index.js +5 -2
  36. package/src/managers/DenoisingManager.js +13 -5
  37. package/src/managers/OverlayManager.js +14 -2
  38. package/src/managers/VideoRenderManager.js +4 -4
  39. package/dist/assets/AIUpscalerWorker-D58dcMrY.js +0 -2
  40. package/dist/assets/AIUpscalerWorker-D58dcMrY.js.map +0 -1
  41. package/src/Processor/createRenderTargetHelper.js +0 -521
  42. package/src/TSL/RayIntersection.js +0 -162
  43. package/src/managers/helpers/StatsHelper.js +0 -45
@@ -1,4 +1,4 @@
1
- (function(e,t){typeof exports==`object`&&typeof module<`u`?t(exports,require(`three/webgpu`),require(`three/tsl`),require(`three`),require(`three/addons/lights/RectAreaLightTexturesLib.js`),require(`three/addons/helpers/RectAreaLightHelper.js`),require(`stats-gl`),require(`three/addons/loaders/GLTFLoader.js`),require(`three/addons/loaders/HDRLoader.js`),require(`three/addons/loaders/DRACOLoader.js`),require(`three/addons/loaders/KTX2Loader.js`),require(`three/addons/loaders/EXRLoader.js`),require(`three/addons/utils/SceneUtils.js`),require(`three/addons/libs/meshopt_decoder.module.js`),require(`three/addons/libs/fflate.module.js`),require(`three/addons/controls/OrbitControls.js`),require(`three/addons/tsl/display/OutlineNode.js`),require(`three/addons/controls/TransformControls.js`)):typeof define==`function`&&define.amd?define([`exports`,`three/webgpu`,`three/tsl`,`three`,`three/addons/lights/RectAreaLightTexturesLib.js`,`three/addons/helpers/RectAreaLightHelper.js`,`stats-gl`,`three/addons/loaders/GLTFLoader.js`,`three/addons/loaders/HDRLoader.js`,`three/addons/loaders/DRACOLoader.js`,`three/addons/loaders/KTX2Loader.js`,`three/addons/loaders/EXRLoader.js`,`three/addons/utils/SceneUtils.js`,`three/addons/libs/meshopt_decoder.module.js`,`three/addons/libs/fflate.module.js`,`three/addons/controls/OrbitControls.js`,`three/addons/tsl/display/OutlineNode.js`,`three/addons/controls/TransformControls.js`],t):(e=typeof globalThis<`u`?globalThis:e||self,t(e.Rayzee={},e.THREE,e.THREE,e.THREE,e.THREE,e.THREE,e.Stats,e.THREE,e.THREE,e.THREE,e.THREE,e.THREE,e.THREE,e.THREE,e.THREE,e.THREE,e.THREE,e.THREE))})(this,function(e,t,n,r,i,a,o,s,c,l,u,d,f,p,m,h,g,_){Object.defineProperty(e,Symbol.toStringTag,{value:`Module`});var v=Object.create,y=Object.defineProperty,b=Object.getOwnPropertyDescriptor,x=Object.getOwnPropertyNames,S=Object.getPrototypeOf,C=Object.prototype.hasOwnProperty,w=(e,t,n,r)=>{if(t&&typeof t==`object`||typeof t==`function`)for(var i=x(t),a=0,o=i.length,s;a<o;a++)s=i[a],!C.call(e,s)&&s!==n&&y(e,s,{get:(e=>t[e]).bind(null,s),enumerable:!(r=b(t,s))||r.enumerable});return e};o=((e,t,n)=>(n=e==null?{}:v(S(e)),w(t||!e||!e.__esModule?y(n,`default`,{value:e,enumerable:!0}):n,e)))(o,1);var T=t.WebGPUBackend.prototype.createNodeBuilder;t.WebGPUBackend.prototype.createNodeBuilder=function(e,t){let n=T.call(this,e,t);return Object.defineProperty(n,`allowGlobalVariables`,{get(){return this.material!==null},set(){},configurable:!0}),n};function E(e,t){return new Proxy(e,{get(e,n,r){if(typeof n==`string`&&t.has(n))return e.get(n);let i=Reflect.get(e,n,r);return n===`toVar`&&typeof i==`function`?(...n)=>E(i.apply(e,n),t):i}})}function D(e,t=null){let r=(0,n.struct)(e,t),i=new Set(Object.keys(e)),a=(...e)=>E(r(...e),i);return a.layout=r.layout,a.isStruct=!0,a.wrap=e=>E(e,i),a}var O=class{constructor(){this.scene=new r.Scene,this._helpers=new Map,this.visible=!1}add(e){if(this._helpers.has(e.uuid))return this._helpers.get(e.uuid);let t=this._createHelper(e);return t?(this._helpers.set(e.uuid,t),this.scene.add(t),t):null}remove(e){let t=this._helpers.get(e.uuid);t&&(t.dispose(),this.scene.remove(t),this._helpers.delete(e.uuid))}has(e){return this._helpers.has(e.uuid)}update(){for(let e of this._helpers.values())e.update?.()}sync(e){let t=new Set(e.map(e=>e.uuid));for(let[e,n]of this._helpers)t.has(e)||(n.dispose(),this.scene.remove(n),this._helpers.delete(e));for(let t of e)this.add(t)}clear(){for(let e of this._helpers.values())e.dispose(),this.scene.remove(e);this._helpers.clear()}render(e,t){if(!this.visible||this._helpers.size===0)return;let n=e.autoClear;e.autoClear=!1,e.clearDepth(),e.setRenderTarget(null),e.render(this.scene,t),e.autoClear=n}dispose(){this.clear()}_createHelper(e){return e.isRectAreaLight?new a.RectAreaLightHelper(e):e.isPointLight?new r.PointLightHelper(e,.5):e.isSpotLight?new r.SpotLightHelper(e):e.isDirectionalLight?new r.DirectionalLightHelper(e,.5):null}};function k(e,t){let n=new o.default({horizontal:!0,trackGPU:!0});n.dom.style.position=`absolute`,n.dom.style.top=`unset`,n.dom.style.bottom=`48px`,n.init(e),(t||document.body).appendChild(n.dom);let r=`#ffffff`,i=`#1e293b`,a=n.fpsPanel.context.createLinearGradient(0,n.fpsPanel.GRAPH_Y,0,n.fpsPanel.GRAPH_Y+n.fpsPanel.GRAPH_HEIGHT);return a.addColorStop(0,r),n.fpsPanel.fg=n.msPanel.fg=r,n.fpsPanel.bg=n.msPanel.bg=i,n.fpsPanel.gradient=n.msPanel.gradient=a,n.gpuPanel&&(n.gpuPanel.fg=r,n.gpuPanel.bg=i,n.gpuPanel.gradient=a),n.dom.style.display=``,n}var A=(0,n.uniform)(0,`int`),j=A,M=new r.DataTexture(new Float32Array([.5,.5,.5,1]),1,1);M.type=r.FloatType,M.needsUpdate=!0;var N=new r.DataTexture(new Float32Array([.5,.5,0,1]),1,1);N.type=r.FloatType,N.needsUpdate=!0;var ee=(0,n.texture)(M);ee.setUpdateMatrix(!1);var te=(0,n.texture)(N);te.setUpdateMatrix(!1);var ne=(0,n.float)(.7548776662466927),re=(0,n.float)(.5698402909980532),ie=(0,n.wgslFn)(`
1
+ (function(e,t){typeof exports==`object`&&typeof module<`u`?t(exports,require(`three/webgpu`),require(`three/tsl`),require(`three`),require(`three/addons/lights/RectAreaLightTexturesLib.js`),require(`three/addons/helpers/RectAreaLightHelper.js`),require(`three/addons/loaders/GLTFLoader.js`),require(`three/addons/loaders/HDRLoader.js`),require(`three/addons/loaders/DRACOLoader.js`),require(`three/addons/loaders/KTX2Loader.js`),require(`three/addons/loaders/EXRLoader.js`),require(`three/addons/utils/SceneUtils.js`),require(`three/addons/libs/meshopt_decoder.module.js`),require(`three/addons/libs/fflate.module.js`),require(`three/addons/controls/OrbitControls.js`),require(`three/addons/tsl/display/OutlineNode.js`),require(`three/addons/controls/TransformControls.js`)):typeof define==`function`&&define.amd?define([`exports`,`three/webgpu`,`three/tsl`,`three`,`three/addons/lights/RectAreaLightTexturesLib.js`,`three/addons/helpers/RectAreaLightHelper.js`,`three/addons/loaders/GLTFLoader.js`,`three/addons/loaders/HDRLoader.js`,`three/addons/loaders/DRACOLoader.js`,`three/addons/loaders/KTX2Loader.js`,`three/addons/loaders/EXRLoader.js`,`three/addons/utils/SceneUtils.js`,`three/addons/libs/meshopt_decoder.module.js`,`three/addons/libs/fflate.module.js`,`three/addons/controls/OrbitControls.js`,`three/addons/tsl/display/OutlineNode.js`,`three/addons/controls/TransformControls.js`],t):(e=typeof globalThis<`u`?globalThis:e||self,t(e.Rayzee={},e.THREE,e.THREE,e.THREE,e.THREE,e.THREE,e.THREE,e.THREE,e.THREE,e.THREE,e.THREE,e.THREE,e.THREE,e.THREE,e.THREE,e.THREE,e.THREE))})(this,function(e,t,n,r,i,a,o,s,c,l,u,d,f,p,m,h,g){Object.defineProperty(e,Symbol.toStringTag,{value:`Module`});var _=t.WebGPUBackend.prototype.createNodeBuilder;t.WebGPUBackend.prototype.createNodeBuilder=function(e,t){let n=_.call(this,e,t);return Object.defineProperty(n,`allowGlobalVariables`,{get(){return this.material!==null},set(){},configurable:!0}),n};function v(e,t){return new Proxy(e,{get(e,n,r){if(typeof n==`string`&&t.has(n))return e.get(n);let i=Reflect.get(e,n,r);return n===`toVar`&&typeof i==`function`?(...n)=>v(i.apply(e,n),t):i}})}function y(e,t=null){let r=(0,n.struct)(e,t),i=new Set(Object.keys(e)),a=(...e)=>v(r(...e),i);return a.layout=r.layout,a.isStruct=!0,a.wrap=e=>v(e,i),a}var b=class{constructor(){this.scene=new r.Scene,this._helpers=new Map,this.visible=!1}add(e){if(this._helpers.has(e.uuid))return this._helpers.get(e.uuid);let t=this._createHelper(e);return t?(this._helpers.set(e.uuid,t),this.scene.add(t),t):null}remove(e){let t=this._helpers.get(e.uuid);t&&(t.dispose(),this.scene.remove(t),this._helpers.delete(e.uuid))}has(e){return this._helpers.has(e.uuid)}update(){for(let e of this._helpers.values())e.update?.()}sync(e){let t=new Set(e.map(e=>e.uuid));for(let[e,n]of this._helpers)t.has(e)||(n.dispose(),this.scene.remove(n),this._helpers.delete(e));for(let t of e)this.add(t)}clear(){for(let e of this._helpers.values())e.dispose(),this.scene.remove(e);this._helpers.clear()}render(e,t){if(!this.visible||this._helpers.size===0)return;let n=e.autoClear;e.autoClear=!1,e.clearDepth(),e.setRenderTarget(null),e.render(this.scene,t),e.autoClear=n}dispose(){this.clear()}_createHelper(e){return e.isRectAreaLight?new a.RectAreaLightHelper(e):e.isPointLight?new r.PointLightHelper(e,.5):e.isSpotLight?new r.SpotLightHelper(e):e.isDirectionalLight?new r.DirectionalLightHelper(e,.5):null}},x=(0,n.uniform)(0,`int`),S=x,C=new r.DataTexture(new Float32Array([.5,.5,.5,1]),1,1);C.type=r.FloatType,C.needsUpdate=!0;var w=new r.DataTexture(new Float32Array([.5,.5,0,1]),1,1);w.type=r.FloatType,w.needsUpdate=!0;var T=(0,n.texture)(C);T.setUpdateMatrix(!1);var E=(0,n.texture)(w);E.setUpdateMatrix(!1);var D=(0,n.float)(.7548776662466927),O=(0,n.float)(.5698402909980532),k=(0,n.wgslFn)(`
2
2
  fn getSobolDirectionVector( index: i32 ) -> u32 {
3
3
 
4
4
  switch ( index ) {
@@ -37,7 +37,7 @@
37
37
  }
38
38
 
39
39
  }
40
- `),ae=(0,n.wgslFn)(`
40
+ `),A=(0,n.wgslFn)(`
41
41
  fn pcgHash( state: u32 ) -> u32 {
42
42
 
43
43
  var s = state;
@@ -47,7 +47,7 @@
47
47
  return s;
48
48
 
49
49
  }
50
- `),oe=(0,n.wgslFn)(`
50
+ `),j=(0,n.wgslFn)(`
51
51
  fn wang_hash( seed: u32 ) -> u32 {
52
52
 
53
53
  var s = seed;
@@ -59,7 +59,7 @@
59
59
  return s;
60
60
 
61
61
  }
62
- `),se=e=>(e.assign(e.mul(1664525).add(1013904223)),(0,n.float)(e.shiftRight(8)).mul(1/16777216)),P=e=>(e.assign(ae({state:e})),(0,n.float)(e.shiftRight(8)).mul(1/16777216)),ce=e=>{let t=se(e).mul(n.TWO_PI).toVar();return(0,n.vec2)((0,n.cos)(t),(0,n.sin)(t)).mul((0,n.sqrt)(se(e)))},le=(e,t,r,i)=>{let a=(0,n.uint)(i).bitAnd((0,n.uint)(63)),o=(0,n.float)(r).add((0,n.float)(t).mul(7)),s=(0,n.int)((0,n.fract)(o.mul(ne).add(.5)).mul(128)),c=(0,n.int)((0,n.fract)(o.mul(re).add(.5)).mul(128)),l=(0,n.int)(e.x).add(s).bitAnd((0,n.int)(127)),u=(0,n.int)(e.y).add(c).bitAnd((0,n.int)(127)),d=(0,n.int)(a).bitAnd((0,n.int)(7)),f=(0,n.int)(a).shiftRight((0,n.int)(3));return(0,n.ivec2)(d.mul((0,n.int)(128)).add(l),f.mul((0,n.int)(128)).add(u))},ue=(e,t,n,r)=>{let i=le(e,t,n,r);return te.load(i).xy},de=(0,n.wgslFn)(`
62
+ `),M=e=>(e.assign(e.mul(1664525).add(1013904223)),(0,n.float)(e.shiftRight(8)).mul(1/16777216)),N=e=>(e.assign(A({state:e})),(0,n.float)(e.shiftRight(8)).mul(1/16777216)),P=e=>{let t=M(e).mul(n.TWO_PI).toVar();return(0,n.vec2)((0,n.cos)(t),(0,n.sin)(t)).mul((0,n.sqrt)(M(e)))},ee=(e,t,r,i)=>{let a=(0,n.uint)(i).bitAnd((0,n.uint)(63)),o=(0,n.float)(r).add((0,n.float)(t).mul(7)),s=(0,n.int)((0,n.fract)(o.mul(D).add(.5)).mul(128)),c=(0,n.int)((0,n.fract)(o.mul(O).add(.5)).mul(128)),l=(0,n.int)(e.x).add(s).bitAnd((0,n.int)(127)),u=(0,n.int)(e.y).add(c).bitAnd((0,n.int)(127)),d=(0,n.int)(a).bitAnd((0,n.int)(7)),f=(0,n.int)(a).shiftRight((0,n.int)(3));return(0,n.ivec2)(d.mul((0,n.int)(128)).add(l),f.mul((0,n.int)(128)).add(u))},F=(e,t,n,r)=>{let i=ee(e,t,n,r);return E.load(i).xy},I=(0,n.wgslFn)(`
63
63
  fn haltonScrambled( index: i32, base: i32, scramble: u32 ) -> f32 {
64
64
 
65
65
  var result = 0.0f;
@@ -88,7 +88,7 @@
88
88
  return result;
89
89
 
90
90
  }
91
- `),fe=(0,n.wgslFn)(`
91
+ `),te=(0,n.wgslFn)(`
92
92
  fn owen_scramble( x: u32, seed: u32 ) -> u32 {
93
93
 
94
94
  var v = x;
@@ -103,7 +103,7 @@
103
103
  return v;
104
104
 
105
105
  }
106
- `),pe=(0,n.wgslFn)(`
106
+ `),ne=(0,n.wgslFn)(`
107
107
  fn owen_scrambled_sobol( index: u32, dimension: u32, seed: u32 ) -> f32 {
108
108
 
109
109
  var result = 0u;
@@ -125,7 +125,7 @@
125
125
  return f32( result ) / 4294967296.0f;
126
126
 
127
127
  }
128
- `,[ie,fe]),me=(e,t,r,i,a,o,s,c)=>{let l=(0,n.select)(o.notEqual((0,n.int)(-1)),o,j),u=(0,n.vec4)(0).toVar();return(0,n.If)(l.equal((0,n.int)(0)),()=>{(0,n.If)(a.greaterThan((0,n.int)(2)),()=>{u.x.assign(se(i)),(0,n.If)(a.greaterThan((0,n.int)(1)),()=>{u.y.assign(se(i))}),(0,n.If)(a.greaterThan((0,n.int)(2)),()=>{u.z.assign(se(i))}),(0,n.If)(a.greaterThan((0,n.int)(3)),()=>{u.w.assign(se(i))})}).Else(()=>{u.x.assign(P(i)),(0,n.If)(a.greaterThan((0,n.int)(1)),()=>{u.y.assign(P(i))}),(0,n.If)(a.greaterThan((0,n.int)(2)),()=>{u.z.assign(P(i))}),(0,n.If)(a.greaterThan((0,n.int)(3)),()=>{u.w.assign(P(i))})})}).ElseIf(l.equal((0,n.int)(1)),()=>{let i=ae({state:(0,n.uint)(e.x).add((0,n.uint)(e.y).mul((0,n.uint)(s.x))).bitXor(c.mul((0,n.uint)(2654435769))).bitXor((0,n.uint)(r).mul((0,n.uint)(1367130551)))}).toVar();u.x.assign(de({index:t,base:(0,n.int)(2),scramble:i})),(0,n.If)(a.greaterThan((0,n.int)(1)),()=>{u.y.assign(de({index:t,base:(0,n.int)(3),scramble:i}))}),(0,n.If)(a.greaterThan((0,n.int)(2)),()=>{u.z.assign(de({index:t,base:(0,n.int)(5),scramble:i}))}),(0,n.If)(a.greaterThan((0,n.int)(3)),()=>{u.w.assign(de({index:t,base:(0,n.int)(7),scramble:i}))})}).ElseIf(l.equal((0,n.int)(2)),()=>{let i=ae({state:(0,n.uint)(e.x).add((0,n.uint)(e.y).mul((0,n.uint)(s.x))).bitXor(c.mul((0,n.uint)(2654435769))).bitXor((0,n.uint)(r).mul((0,n.uint)(1367130551)))}).toVar();u.x.assign(pe({index:(0,n.uint)(t),dimension:(0,n.uint)(0),seed:i})),(0,n.If)(a.greaterThan((0,n.int)(1)),()=>{u.y.assign(pe({index:(0,n.uint)(t),dimension:(0,n.uint)(1),seed:i}))}),(0,n.If)(a.greaterThan((0,n.int)(2)),()=>{u.z.assign(pe({index:(0,n.uint)(t),dimension:(0,n.uint)(2),seed:i}))}),(0,n.If)(a.greaterThan((0,n.int)(3)),()=>{u.w.assign(pe({index:(0,n.uint)(t),dimension:(0,n.uint)(3),seed:i}))})}).Else(()=>{let i=r.mul((0,n.int)(4));(0,n.If)(a.lessThanEqual((0,n.int)(2)),()=>{let n=ue(e,t,i,c);u.x.assign(n.x),u.y.assign(n.y)}).Else(()=>{let r=ue(e,t,i,c),a=ue(e,t,i.add((0,n.int)(1)),c);u.assign((0,n.vec4)(r,a))})}),u},he=(e,t,r,i,a,o,s)=>me(e,t,r,i,(0,n.int)(2),a,o,s).xy,ge=(e,t,r,i,a,o)=>{let s=(0,n.vec2)(0).toVar();return(0,n.If)(r.lessThanEqual((0,n.int)(1)),()=>{s.assign(he(e,t,(0,n.int)(0),i,(0,n.int)(-1),a,o))}).Else(()=>{let a=(0,n.int)((0,n.sqrt)((0,n.float)(r))),c=r.add(a).sub(1).div(a),l=(0,n.mod)(t,a.mul(c)),u=(0,n.mod)(l,a),d=l.div(a),f=(0,n.vec2)((0,n.float)(u),(0,n.float)(d)).div((0,n.vec2)((0,n.float)(a),(0,n.float)(c))),p=(0,n.vec2)(0).toVar();(0,n.If)(j.greaterThanEqual((0,n.int)(3)),()=>{p.assign(ue(e,t,(0,n.int)(0),o))}).Else(()=>{let a=se(i).toVar(),s=se(i).toVar();p.assign((0,n.vec2)(a,s)),(0,n.If)(r.greaterThan((0,n.int)(4)),()=>{let r=ue(e,t,(0,n.int)(0),o).mul(.1);p.assign((0,n.mix)(p,r,.2))})}),p.divAssign((0,n.vec2)((0,n.float)(a),(0,n.float)(c))),s.assign(f.add(p))}),s},_e=(0,n.wgslFn)(`
128
+ `,[k,te]),re=(e,t,r,i,a,o,s,c)=>{let l=(0,n.select)(o.notEqual((0,n.int)(-1)),o,S),u=(0,n.vec4)(0).toVar();return(0,n.If)(l.equal((0,n.int)(0)),()=>{(0,n.If)(a.greaterThan((0,n.int)(2)),()=>{u.x.assign(M(i)),(0,n.If)(a.greaterThan((0,n.int)(1)),()=>{u.y.assign(M(i))}),(0,n.If)(a.greaterThan((0,n.int)(2)),()=>{u.z.assign(M(i))}),(0,n.If)(a.greaterThan((0,n.int)(3)),()=>{u.w.assign(M(i))})}).Else(()=>{u.x.assign(N(i)),(0,n.If)(a.greaterThan((0,n.int)(1)),()=>{u.y.assign(N(i))}),(0,n.If)(a.greaterThan((0,n.int)(2)),()=>{u.z.assign(N(i))}),(0,n.If)(a.greaterThan((0,n.int)(3)),()=>{u.w.assign(N(i))})})}).ElseIf(l.equal((0,n.int)(1)),()=>{let i=A({state:(0,n.uint)(e.x).add((0,n.uint)(e.y).mul((0,n.uint)(s.x))).bitXor(c.mul((0,n.uint)(2654435769))).bitXor((0,n.uint)(r).mul((0,n.uint)(1367130551)))}).toVar();u.x.assign(I({index:t,base:(0,n.int)(2),scramble:i})),(0,n.If)(a.greaterThan((0,n.int)(1)),()=>{u.y.assign(I({index:t,base:(0,n.int)(3),scramble:i}))}),(0,n.If)(a.greaterThan((0,n.int)(2)),()=>{u.z.assign(I({index:t,base:(0,n.int)(5),scramble:i}))}),(0,n.If)(a.greaterThan((0,n.int)(3)),()=>{u.w.assign(I({index:t,base:(0,n.int)(7),scramble:i}))})}).ElseIf(l.equal((0,n.int)(2)),()=>{let i=A({state:(0,n.uint)(e.x).add((0,n.uint)(e.y).mul((0,n.uint)(s.x))).bitXor(c.mul((0,n.uint)(2654435769))).bitXor((0,n.uint)(r).mul((0,n.uint)(1367130551)))}).toVar();u.x.assign(ne({index:(0,n.uint)(t),dimension:(0,n.uint)(0),seed:i})),(0,n.If)(a.greaterThan((0,n.int)(1)),()=>{u.y.assign(ne({index:(0,n.uint)(t),dimension:(0,n.uint)(1),seed:i}))}),(0,n.If)(a.greaterThan((0,n.int)(2)),()=>{u.z.assign(ne({index:(0,n.uint)(t),dimension:(0,n.uint)(2),seed:i}))}),(0,n.If)(a.greaterThan((0,n.int)(3)),()=>{u.w.assign(ne({index:(0,n.uint)(t),dimension:(0,n.uint)(3),seed:i}))})}).Else(()=>{let i=r.mul((0,n.int)(4));(0,n.If)(a.lessThanEqual((0,n.int)(2)),()=>{let n=F(e,t,i,c);u.x.assign(n.x),u.y.assign(n.y)}).Else(()=>{let r=F(e,t,i,c),a=F(e,t,i.add((0,n.int)(1)),c);u.assign((0,n.vec4)(r,a))})}),u},ie=(e,t,r,i,a,o,s)=>re(e,t,r,i,(0,n.int)(2),a,o,s).xy,ae=(e,t,r,i,a,o)=>{let s=(0,n.vec2)(0).toVar();return(0,n.If)(r.lessThanEqual((0,n.int)(1)),()=>{s.assign(ie(e,t,(0,n.int)(0),i,(0,n.int)(-1),a,o))}).Else(()=>{let a=(0,n.int)((0,n.sqrt)((0,n.float)(r))),c=r.add(a).sub(1).div(a),l=(0,n.mod)(t,a.mul(c)),u=(0,n.mod)(l,a),d=l.div(a),f=(0,n.vec2)((0,n.float)(u),(0,n.float)(d)).div((0,n.vec2)((0,n.float)(a),(0,n.float)(c))),p=(0,n.vec2)(0).toVar();(0,n.If)(S.greaterThanEqual((0,n.int)(3)),()=>{p.assign(F(e,t,(0,n.int)(0),o))}).Else(()=>{let a=M(i).toVar(),s=M(i).toVar();p.assign((0,n.vec2)(a,s)),(0,n.If)(r.greaterThan((0,n.int)(4)),()=>{let r=F(e,t,(0,n.int)(0),o).mul(.1);p.assign((0,n.mix)(p,r,.2))})}),p.divAssign((0,n.vec2)((0,n.float)(a),(0,n.float)(c))),s.assign(f.add(p))}),s},oe=(0,n.wgslFn)(`
129
129
  fn getDecorrelatedSeed( pixelCoord: vec2f, rayIndex: i32, frame: u32 ) -> u32 {
130
130
 
131
131
  // Use multiple primes for better decorrelation
@@ -140,7 +140,7 @@
140
140
  return seed;
141
141
 
142
142
  }
143
- `,[oe,ae]),F={ALWAYS:`always`,PER_CYCLE:`per_cycle`,PER_TILE:`per_tile`,CONDITIONAL:`conditional`},I=class{constructor(e,t={}){this.name=e,this.enabled=t.enabled!==!1,this.executionMode=t.executionMode||F.ALWAYS,this.context=null,this.eventBus=null}initialize(e,t){this.context=e,this.eventBus=t,this.setupEventListeners()}setupEventListeners(){}shouldExecuteThisFrame(e){if(!this.enabled)return!1;let t=e.getState(`renderMode`)||0,n=e.getState(`tileRenderingComplete`);switch(this.executionMode){case F.ALWAYS:return!0;case F.PER_CYCLE:return t===0?!0:n===!0;case F.PER_TILE:return!0;case F.CONDITIONAL:return this.shouldExecute(e);default:return this.warn(`Unknown execution mode: ${this.executionMode}`),!0}}shouldExecute(e){return!0}render(e,t){throw Error(`render() must be implemented in ${this.name}`)}reset(){}setSize(e,t){}dispose(){}emit(e,t){this.eventBus&&this.eventBus.emit(e,t)}on(e,t){this.eventBus&&this.eventBus.on(e,t)}once(e,t){this.eventBus&&this.eventBus.once(e,t)}off(e,t){this.eventBus&&this.eventBus.off(e,t)}enable(){this.enabled||(this.enabled=!0,this.emit(`stage:enabled`,{stage:this.name}))}disable(){this.enabled&&(this.enabled=!1,this.emit(`stage:disabled`,{stage:this.name}))}toggle(){this.enabled?this.disable():this.enable()}isEnabled(){return this.enabled}log(...e){console.log(`[${this.name}]`,...e)}warn(...e){console.warn(`[${this.name}]`,...e)}error(...e){console.error(`[${this.name}]`,...e)}},ve=class{constructor(e,t,n){this.width=e,this.height=t,this.tiles=n,this.tileIndex=0,this.tileBoundsCache=new Map,this.totalTilesCache=n*n,this.currentTileBounds=null,this.spiralOrder=this.generateSpiralOrder(n)}calculateTileBounds(e,t,n,r){let i=`${e}-${t}-${n}-${r}`;if(this.tileBoundsCache.has(i))return this.tileBoundsCache.get(i);let a=Math.ceil(n/t),o=Math.ceil(r/t),s=e%t,c=Math.floor(e/t),l=s*a,u=c*o,d={x:l,y:u,width:Math.min(a,n-l),height:Math.min(o,r-u)};return this.tileBoundsCache.set(i,d),d}generateSpiralOrder(e){let t=e*e,n=[];for(let r=0;r<t;r++){let t=r%e,i=Math.floor(r/e),a=(e-1)/2,o=t-a,s=i-a,c=Math.abs(o)+Math.abs(s),l=Math.sqrt(o*o+s*s),u=Math.atan(s,o);u<0&&(u+=2*Math.PI);let d=(t+i*e)*.001;n.push({index:r,x:t,y:i,manhattanDistance:c,euclideanDistance:l,angle:u,positionOffset:d})}return n.sort((e,t)=>{let n=e.manhattanDistance-t.manhattanDistance;if(Math.abs(n)>.01)return n;let r=e.euclideanDistance-t.euclideanDistance;if(Math.abs(r)>.01)return r;let i=e.angle-t.angle;return Math.abs(i)>.01?i:e.positionOffset-t.positionOffset}),n.map(e=>e.index)}handleTileRendering(e,t,n){let r=!0,i=-1,a=null,o=!0;if(t===1)if(n===0)i=-1,o=!0;else{let e=(n-1)%this.totalTilesCache;i=this.spiralOrder[e],a=this.calculateTileBounds(i,this.tiles,this.width,this.height),o=e===this.totalTilesCache-1,r=o}else i=-1,o=!0;return this.tileIndex=i,{tileIndex:i,tileBounds:a,shouldSwapTargets:r,isCompleteCycle:o}}setTileCount(e){if(e<1&&(console.warn(`TileManager: Tile count must be at least 1, clamping to 1`),e=1),e>10&&console.warn(`TileManager: Tile count > 10 may cause performance issues`),e>6){let t=e*e;console.warn(`TileManager: ${e}x${e} = ${t} tiles may impact performance and memory usage`)}this.tiles=e,this.totalTilesCache=e*e,this.tileIndex=0,this.spiralOrder=this.generateSpiralOrder(e),this.tileBoundsCache.clear()}setSize(e,t){this.width=e,this.height=t,this.tileBoundsCache.clear()}calculateCompletionThreshold(e){return this.totalTilesCache*e}getCurrentTileInfo(){return{tileIndex:this.tileIndex,tiles:this.tiles,totalTiles:this.totalTilesCache,currentBounds:this.currentTileBounds}}dispose(){this.tileBoundsCache.clear(),this.currentTileBounds=null}},ye=class{constructor(e,t,n={}){this.renderer=e,this.material=t,this.interactionModeEnabled=n.enabled===void 0?!0:n.enabled,this.interactionDelay=n.delay||100,this.interactionMode=!1,this.interactionTimeout=null,this.originalValues={},this.wasAccumulationEnabled=!0,this.interactionQualitySettings={maxBounceCount:1,numRaysPerPixel:1,useAdaptiveSampling:!1,useEnvMapIS:!1,enableAccumulation:!1,...n.qualitySettings},this.onEnterCallback=n.onEnter||null,this.onExitCallback=n.onExit||null,this.onResetCallback=n.onReset||null}enterInteractionMode(){this.interactionModeEnabled&&(this.interactionMode?clearTimeout(this.interactionTimeout):(this.interactionMode=!0,this.originalValues={},this.material.uniforms.enableAccumulation&&(this.wasAccumulationEnabled=this.material.uniforms.enableAccumulation.value),Object.keys(this.interactionQualitySettings).forEach(e=>{e===`pixelRatio`?(this.originalValues.dpr=this.renderer.getPixelRatio(),this.renderer.setPixelRatio(this.interactionQualitySettings.pixelRatio)):e===`enableAccumulation`||this.material.uniforms[e]&&(this.originalValues[e]=this.material.uniforms[e].value,this.material.uniforms[e].value=this.interactionQualitySettings[e])}),this.material.uniforms.enableAccumulation&&(this.originalValues.enableAccumulation=this.material.uniforms.enableAccumulation.value,this.material.uniforms.enableAccumulation.value=!1),this.material.uniforms.cameraIsMoving&&(this.originalValues.cameraIsMoving=this.material.uniforms.cameraIsMoving.value,this.material.uniforms.cameraIsMoving.value=!0),this.onEnterCallback&&this.onEnterCallback()),this.interactionTimeout=setTimeout(()=>{this.exitInteractionMode()},this.interactionDelay))}exitInteractionMode(){this.interactionMode&&(Object.keys(this.originalValues).forEach(e=>{e===`dpr`?this.renderer.setPixelRatio(this.originalValues.dpr):this.material.uniforms[e]&&(this.material.uniforms[e].value=this.originalValues[e])}),this.interactionMode=!1,this.originalValues={},this.onExitCallback&&this.onExitCallback(),this.onResetCallback&&this.onResetCallback())}updateInteractionMode(e){e&&this.enterInteractionMode()}setInteractionModeEnabled(e){this.interactionModeEnabled=e,!e&&this.interactionMode&&(clearTimeout(this.interactionTimeout),this.exitInteractionMode())}updateQualitySettings(e){Object.assign(this.interactionQualitySettings,e),this.interactionMode&&Object.keys(e).forEach(t=>{t===`pixelRatio`?this.renderer.setPixelRatio(e.pixelRatio):this.material.uniforms[t]&&(this.material.uniforms[t].value=e[t])})}setInteractionDelay(e){this.interactionDelay=e}getState(){return{interactionMode:this.interactionMode,interactionModeEnabled:this.interactionModeEnabled,interactionDelay:this.interactionDelay,hasTimeout:this.interactionTimeout!==null,qualitySettings:{...this.interactionQualitySettings},originalValues:{...this.originalValues},wasAccumulationEnabled:this.wasAccumulationEnabled}}forceExitInteractionMode(){this.interactionTimeout&&=(clearTimeout(this.interactionTimeout),null),this.exitInteractionMode()}isInInteractionMode(){return this.interactionMode}setCallbacks(e){e.onEnter&&(this.onEnterCallback=e.onEnter),e.onExit&&(this.onExitCallback=e.onExit),e.onReset&&(this.onResetCallback=e.onReset)}static createQualityPreset(e){let t={"ultra-low":{maxBounceCount:1,numRaysPerPixel:1,useAdaptiveSampling:!1,useEnvMapIS:!1,pixelRatio:.125,enableAccumulation:!1},low:{maxBounceCount:1,numRaysPerPixel:1,useAdaptiveSampling:!1,useEnvMapIS:!1,pixelRatio:.25,enableAccumulation:!1},medium:{maxBounceCount:2,numRaysPerPixel:1,useAdaptiveSampling:!1,useEnvMapIS:!0,pixelRatio:.5,enableAccumulation:!1},high:{maxBounceCount:3,numRaysPerPixel:1,useAdaptiveSampling:!0,useEnvMapIS:!0,pixelRatio:.75,enableAccumulation:!0}};return t[e]||t.low}dispose(){this.interactionTimeout&&=(clearTimeout(this.interactionTimeout),null),this.interactionMode&&this.forceExitInteractionMode(),this.onEnterCallback=null,this.onExitCallback=null,this.onResetCallback=null}},L={RENDER_COMPLETE:`engine:renderComplete`,RENDER_RESET:`engine:renderReset`,DENOISING_START:`engine:denoisingStart`,DENOISING_END:`engine:denoisingEnd`,UPSCALING_START:`engine:upscalingStart`,UPSCALING_PROGRESS:`engine:upscalingProgress`,UPSCALING_END:`engine:upscalingEnd`,LOADING_UPDATE:`engine:loadingUpdate`,LOADING_RESET:`engine:loadingReset`,STATS_UPDATE:`engine:statsUpdate`,OBJECT_SELECTED:`engine:objectSelected`,OBJECT_DESELECTED:`engine:objectDeselected`,OBJECT_DOUBLE_CLICKED:`engine:objectDoubleClicked`,SELECT_MODE_CHANGED:`engine:selectModeChanged`,OBJECT_TRANSFORM_START:`engine:objectTransformStart`,OBJECT_TRANSFORM_END:`engine:objectTransformEnd`,TRANSFORM_MODE_CHANGED:`engine:transformModeChanged`,AUTO_FOCUS_UPDATED:`engine:autoFocusUpdated`,AUTO_EXPOSURE_UPDATED:`engine:autoExposureUpdated`,AF_POINT_PLACED:`engine:afPointPlaced`,SETTING_CHANGED:`engine:settingChanged`,ANIMATION_STARTED:`engine:animationStarted`,ANIMATION_PAUSED:`engine:animationPaused`,ANIMATION_STOPPED:`engine:animationStopped`,ANIMATION_FINISHED:`engine:animationFinished`,VIDEO_RENDER_PROGRESS:`engine:videoRenderProgress`,VIDEO_RENDER_COMPLETE:`engine:videoRenderComplete`,DISPOSE:`engine:dispose`},be=null;function xe(e){be=e}var Se=()=>be?.({type:L.LOADING_RESET}),R=e=>{be?.({type:L.LOADING_UPDATE,...e})},Ce=e=>{be?.({type:L.STATS_UPDATE,...e})};function we(e){let t=e.frameCount||0;if(e.renderMode?.value===1&&t>0){let n=e.tileManager?.totalTilesCache||1;return 1+Math.floor((t-1)/n)}return t}function Te(e){if(Array.isArray(e))e.forEach(e=>{e.userData&&e.userData.isFallback||(Ee(e),e.dispose())});else{if(e.userData&&e.userData.isFallback)return;Ee(e),e.dispose()}}function Ee(e){e&&[`alphaMap`,`aoMap`,`bumpMap`,`clearcoatMap`,`clearcoatNormalMap`,`clearcoatRoughnessMap`,`displacementMap`,`emissiveMap`,`envMap`,`gradientMap`,`lightMap`,`map`,`metalnessMap`,`normalMap`,`roughnessMap`,`specularMap`,`sheenColorMap`,`sheenRoughnessMap`,`specularIntensityMap`,`specularColorMap`,`thicknessMap`,`transmissionMap`].forEach(t=>{e[t]&&(e[t].dispose(),e[t]=null)})}function De({material:e,geometry:t,children:n}){if(e&&Te(e),t&&t.dispose(),n.length>0)for(let e of n)De(e)}function Oe(e,t=[]){if(e&&!(t.includes(e.name)||e.isScene)){if(e.isMaterial){Te(e);return}for(;e.children.length>0;)for(let t of e.children)Oe(t);De(e),e.removeFromParent(),e.clear()}}function ke(e,t,n){return e===1?n*t:t}function Ae(e,t,n,r=!1){return r?1:t===0?1/(e+1):e===0?1:1/(1+Math.floor((e-1)/n)+1)}function je(){let e=0,t=0,n=0,r=0;return{start(){e=performance.now()},end(){t=performance.now();let i=t-e;return r+=i,n++,i},getAverageFrameTime(){return n>0?r/n:0},getFPS(){let e=this.getAverageFrameTime();return e>0?1e3/e:0},reset(){n=0,r=0}}}function Me(e,n){let i=new t.StorageTexture(e,n);return i.type=r.FloatType,i.format=r.RGBAFormat,i.minFilter=r.LinearFilter,i.magFilter=r.LinearFilter,i}var Ne=class{constructor(e,t){this.writeColor=null,this.writeNormalDepth=null,this.writeAlbedo=null,this.readTarget=null,this.currentTarget=0,this.renderWidth=0,this.renderHeight=0,e>0&&t>0&&this.create(e,t)}create(e,n){this.dispose(),this.renderWidth=e,this.renderHeight=n,this.writeColor=Me(e,n),this.writeNormalDepth=Me(e,n),this.writeAlbedo=Me(e,n),this.readTarget=new t.RenderTarget(e,n,{type:r.FloatType,format:r.RGBAFormat,minFilter:r.NearestFilter,magFilter:r.NearestFilter,depthBuffer:!1,stencilBuffer:!1,count:3}),this.readTarget.textures[0].name=`gColor`,this.readTarget.textures[1].name=`gNormalDepth`,this.readTarget.textures[2].name=`gAlbedo`,console.log(`StorageTexturePool: Created ${e}x${n} (3 write StorageTextures + 1 MRT RenderTarget)`)}ensureSize(e,t){return this.renderWidth!==e||this.renderHeight!==t||!this.writeColor?(this.create(e,t),!0):!1}getReadTextures(){return{color:this.readTarget.textures[0],normalDepth:this.readTarget.textures[1],albedo:this.readTarget.textures[2]}}getWriteTextures(){return{color:this.writeColor,normalDepth:this.writeNormalDepth,albedo:this.writeAlbedo}}copyToReadTargets(e){e.copyTextureToTexture(this.writeColor,this.readTarget.textures[0]),e.copyTextureToTexture(this.writeNormalDepth,this.readTarget.textures[1]),e.copyTextureToTexture(this.writeAlbedo,this.readTarget.textures[2])}clear(e){if(!this.readTarget||!e)return;let t=e.getRenderTarget();e.setRenderTarget(this.readTarget),e.clear(!0,!1,!1),e.setRenderTarget(t)}swap(){this.currentTarget=1-this.currentTarget}setSize(e,t){if(this.renderWidth=e,this.renderHeight=t,this.writeColor?.setSize(e,t),this.writeNormalDepth?.setSize(e,t),this.writeAlbedo?.setSize(e,t),this.readTarget){this.readTarget.setSize(e,t);for(let e of this.readTarget.textures)e.needsUpdate=!0}}dispose(){this.writeColor?.dispose(),this.writeNormalDepth?.dispose(),this.writeAlbedo?.dispose(),this.readTarget?.dispose(),this.writeColor=null,this.writeNormalDepth=null,this.writeAlbedo=null,this.readTarget=null}},z={resolution:512,canvasWidth:512,canvasHeight:512,toneMapping:4,exposure:1,saturation:1.2,enableEnvironment:!0,showBackground:!0,transparentBackground:!1,useImportanceSampledEnvironment:!0,environmentIntensity:1,backgroundIntensity:1,environmentRotation:270,globalIlluminationIntensity:1,environmentMode:`hdri`,gradientZenithColor:`#0077BE`,gradientHorizonColor:`#87CEEB`,gradientGroundColor:`#654321`,solidSkyColor:`#87CEEB`,skySunAzimuth:90,skySunElevation:20,skySunIntensity:15,skyRayleighDensity:.9,skyTurbidity:.8,skyMieAnisotropy:.76,skyPreset:`clearMorning`,enableDOF:!1,fov:55,focusDistance:.8,aperture:5.6,focalLength:50,apertureScale:1,anamorphicRatio:1,autoFocusMode:`auto`,afScreenPoint:{x:.5,y:.5},afSmoothingFactor:.15,enablePathTracer:!0,enableAccumulation:!0,pauseRendering:!1,maxSamples:60,bounces:3,samplesPerPixel:1,transmissiveBounces:5,samplingTechnique:3,enableEmissiveTriangleSampling:!1,emissiveBoost:1,adaptiveSampling:!1,adaptiveSamplingMin:1,adaptiveSamplingMax:8,adaptiveSamplingVarianceThreshold:.1,temporalVarianceWeight:.6,enableEarlyTermination:!0,earlyTerminationThreshold:.002,showAdaptiveSamplingHelper:!1,performanceModeAdaptive:`medium`,fireflyThreshold:3,renderLimitMode:`frames`,renderTimeLimit:30,renderMode:0,enableAlphaShadows:!1,tiles:3,tilesHelper:!1,showLightHelper:!1,directionalLightIntensity:0,directionalLightColor:`#ffffff`,directionalLightPosition:[1,1,1],directionalLightAngle:0,filterStrength:.75,strengthDecaySpeed:.05,edgeThreshold:1,enableOIDN:!1,oidnQuality:`fast`,debugGbufferMaps:!1,enableUpscaler:!1,upscalerScale:2,upscalerQuality:`fast`,upscalerHdr:!0,debugMode:0,debugThreshold:100,debugModel:0,enableBloom:!1,bloomStrength:.2,bloomRadius:.15,bloomThreshold:.85,interactionModeEnabled:!0,debugVisScale:100,denoiserStrategy:`none`,enableASVGF:!1,asvgfTemporalAlpha:.1,asvgfAtrousIterations:8,asvgfPhiColor:10,asvgfPhiNormal:128,asvgfPhiDepth:1,asvgfVarianceBoost:1,asvgfMaxAccumFrames:32,asvgfDebugMode:0,asvgfQualityPreset:`medium`,showAsvgfHeatmap:!1,ssrcTemporalAlpha:.1,ssrcSpatialRadius:4,ssrcSpatialWeight:.4,autoExposure:!1,autoExposureKeyValue:.18,autoExposureMinExposure:.1,autoExposureMaxExposure:20,autoExposureAdaptSpeedBright:3,autoExposureAdaptSpeedDark:.5},Pe={low:{temporalAlpha:.3,atrousIterations:1,phiColor:30,phiNormal:64,phiDepth:2,phiLuminance:6,maxAccumFrames:8,varianceBoost:.5},medium:{temporalAlpha:.1,atrousIterations:3,phiColor:20,phiNormal:128,phiDepth:1,phiLuminance:2,maxAccumFrames:32,varianceBoost:1},high:{temporalAlpha:.05,atrousIterations:8,phiColor:5,phiNormal:256,phiDepth:.5,phiLuminance:2,maxAccumFrames:64,varianceBoost:1.5}},Fe={fov:{min:10,max:90,default:z.fov},focusDistance:{min:.3,max:100,default:z.focusDistance},aperture:{options:[1.4,2,2.8,4,5.6,8,11,16],default:z.aperture},focalLength:{min:0,max:200,default:z.focalLength}},Ie={clearMorning:{name:`Clear Morning`,sunAzimuth:90,sunElevation:20,sunIntensity:15,rayleighDensity:.9,turbidity:.8},clearNoon:{name:`Clear Noon`,sunAzimuth:0,sunElevation:75,sunIntensity:20,rayleighDensity:1,turbidity:.3},overcast:{name:`Overcast`,sunAzimuth:0,sunElevation:45,sunIntensity:6,rayleighDensity:.6,turbidity:4},goldenHour:{name:`Golden Hour`,sunAzimuth:270,sunElevation:10,sunIntensity:19,rayleighDensity:.8,turbidity:1.2},sunset:{name:`Sunset`,sunAzimuth:270,sunElevation:2,sunIntensity:18,rayleighDensity:.7,turbidity:2},dusk:{name:`Dusk`,sunAzimuth:270,sunElevation:-8,sunIntensity:8,rayleighDensity:.5,turbidity:1.5}},Le={portrait:{name:`Portrait`,description:`Shallow depth of field, background blur`,fov:45,focusDistance:1.5,aperture:1.4,focalLength:135,apertureScale:1.5},landscape:{name:`Landscape`,description:`Maximum depth of field, everything in focus`,fov:65,focusDistance:10,aperture:16,focalLength:24,apertureScale:.5},macro:{name:`Macro`,description:`Extreme close-up with thin focus plane`,fov:40,focusDistance:.3,aperture:2,focalLength:100,apertureScale:2},product:{name:`Product`,description:`Sharp detail with subtle background separation`,fov:50,focusDistance:.8,aperture:2.8,focalLength:85,apertureScale:1},architectural:{name:`Architectural`,description:`Wide view with deep focus`,fov:75,focusDistance:5,aperture:11,focalLength:16,apertureScale:.5},cinematic:{name:`Cinematic`,description:`Dramatic depth separation with anamorphic bokeh`,fov:35,focusDistance:3,aperture:1.4,focalLength:200,apertureScale:1.8,anamorphicRatio:1.5}},Re={MANUAL:`manual`,AUTO:`auto`},ze={SMOOTHING_FACTOR:.15,RESET_THRESHOLD:.05,FALLBACK_DISTANCE:10,SNAP_THRESHOLD:.5},B={FLOATS_PER_TRIANGLE:32,POSITION_A_OFFSET:0,POSITION_B_OFFSET:4,POSITION_C_OFFSET:8,NORMAL_A_OFFSET:12,NORMAL_B_OFFSET:16,NORMAL_C_OFFSET:20,UV_AB_OFFSET:24,UV_C_MAT_OFFSET:28},V={SLOTS_PER_MATERIAL:27,FLOATS_PER_MATERIAL:108,IOR:0,TRANSMISSION:1,THICKNESS:2,EMISSIVE_INTENSITY:3,ATTENUATION_COLOR:4,ATTENUATION_DISTANCE:7,OPACITY:8,SIDE:9,TRANSPARENT:10,ALPHA_TEST:11,ALPHA_MODE:12,DEPTH_WRITE:13,NORMAL_SCALE:14,COLOR:16,METALNESS:19,EMISSIVE:20,ROUGHNESS:23,ALBEDO_MAP_INDEX:24,NORMAL_MAP_INDEX:25,ROUGHNESS_MAP_INDEX:26,METALNESS_MAP_INDEX:27,EMISSIVE_MAP_INDEX:28,BUMP_MAP_INDEX:29,CLEARCOAT:30,CLEARCOAT_ROUGHNESS:31,DISPERSION:32,VISIBLE:33,SHEEN:34,SHEEN_ROUGHNESS:35,SHEEN_COLOR:36,SPECULAR_INTENSITY:40,SPECULAR_COLOR:41,IRIDESCENCE:44,IRIDESCENCE_IOR:45,IRIDESCENCE_THICKNESS_RANGE:46,BUMP_SCALE:48,DISPLACEMENT_SCALE:49,DISPLACEMENT_MAP_INDEX:50,ALBEDO_TRANSFORM:52,NORMAL_TRANSFORM:60,ROUGHNESS_TRANSFORM:68,METALNESS_TRANSFORM:76,EMISSIVE_TRANSFORM:84,BUMP_TRANSFORM:92,DISPLACEMENT_TRANSFORM:100,SLOT:{IOR_TRANSMISSION:0,ATTENUATION:1,OPACITY_ALPHA:2,ALPHA_MODE:3,COLOR_METALNESS:4,EMISSIVE_ROUGHNESS:5,MAP_INDICES_A:6,MAP_INDICES_B:7,DISPERSION_SHEEN:8,SHEEN_COLOR:9,SPECULAR:10,IRIDESCENCE:11,BUMP_DISPLACEMENT:12,ALBEDO_TRANSFORM_A:13,ALBEDO_TRANSFORM_B:14,NORMAL_TRANSFORM_A:15,NORMAL_TRANSFORM_B:16,ROUGHNESS_TRANSFORM_A:17,ROUGHNESS_TRANSFORM_B:18,METALNESS_TRANSFORM_A:19,METALNESS_TRANSFORM_B:20,EMISSIVE_TRANSFORM_A:21,EMISSIVE_TRANSFORM_B:22,BUMP_TRANSFORM_A:23,BUMP_TRANSFORM_B:24,DISPLACEMENT_TRANSFORM_A:25,DISPLACEMENT_TRANSFORM_B:26}},H={TRIANGLE_LEAF:-1,BLAS_POINTER_LEAF:-2},U={PIXELS_PER_MATERIAL:27,RGBA_COMPONENTS:4,VEC4_PER_TRIANGLE:8,VEC4_PER_BVH_NODE:4,FLOATS_PER_VEC4:4,MIN_TEXTURE_WIDTH:4,MAX_CONCURRENT_WORKERS:Math.min(typeof navigator<`u`&&navigator.hardwareConcurrency||4,6),BUFFER_POOL_SIZE:20,CANVAS_POOL_SIZE:12,CACHE_SIZE_LIMIT:50,MAX_TEXTURE_SIZE:8192},Be=[0,0,1,1,0,0,0,1],Ve={maxSamples:30,bounces:20,transmissiveBounces:8,samplesPerPixel:1,renderMode:1,enableAlphaShadows:!0,tiles:3,tilesHelper:!0,enableOIDN:!0,oidnQuality:`balance`,interactionModeEnabled:!1},He={maxSamples:z.maxSamples,bounces:z.bounces,samplesPerPixel:z.samplesPerPixel,renderMode:z.renderMode,enableAlphaShadows:z.enableAlphaShadows,transmissiveBounces:z.transmissiveBounces,tiles:z.tiles,tilesHelper:z.tilesHelper,enableOIDN:!1,oidnQuality:`fast`,interactionModeEnabled:!0},W={MAX_BUFFER_MEMORY:1024*1024*1024,MAX_TEXTURE_MEMORY:2048*1024*1024,CLEANUP_THRESHOLD:.8,CHUNK_SIZE_THRESHOLD:64*1024*1024,STREAM_BATCH_SIZE:4},Ue={cameraViewMatrix:`ptCameraViewMatrix`,cameraProjectionMatrix:`ptCameraProjectionMatrix`},We=class{constructor(e=1920,t=1080){this._uniforms=new Map,this._booleans=new Set,this._lightBuffers={},this._initUniforms(e,t),this._nameAll()}get(e){return this._uniforms.get(e)}set(e,t){let n=this._uniforms.get(e);if(!n){console.warn(`UniformManager: Unknown uniform "${e}"`);return}this._booleans.has(e)?n.value=+!!t:typeof t==`object`&&t&&typeof n.value?.copy==`function`?n.value.copy(t):n.value=t}has(e){return this._uniforms.has(e)}keys(){return this._uniforms.keys()}getLightBufferNodes(){return this._lightBuffers}updateMany(e){let t=!1;for(let[n,r]of Object.entries(e)){let e=this._uniforms.get(n);e&&e.value!==r&&(e.value=r,t=!0)}return t}_initUniforms(e,t){let i=(e,t,r)=>{let i=(0,n.uniform)(t,r);return this._uniforms.set(e,i),i},a=(e,t)=>(this._booleans.add(e),i(e,+!!t,`int`));i(`frame`,0,`uint`),i(`maxBounces`,z.bounces,`int`),i(`samplesPerPixel`,z.samplesPerPixel,`int`),i(`maxSamples`,z.maxSamples,`int`),i(`transmissiveBounces`,z.transmissiveBounces,`int`),i(`visMode`,z.debugMode,`int`),i(`debugVisScale`,z.debugVisScale,`float`),a(`enableAccumulation`,!0),i(`accumulationAlpha`,0,`float`),a(`cameraIsMoving`,!1),a(`hasPreviousAccumulated`,!1),i(`environmentIntensity`,z.environmentIntensity,`float`),i(`backgroundIntensity`,z.backgroundIntensity,`float`),a(`showBackground`,z.showBackground),a(`transparentBackground`,z.transparentBackground),a(`enableEnvironment`,z.enableEnvironment),i(`environmentMatrix`,new r.Matrix4,`mat4`),a(`useEnvMapIS`,z.useImportanceSampledEnvironment),i(`envTotalSum`,0,`float`),i(`envCompensationDelta`,0,`float`),i(`envResolution`,new r.Vector2(1,1),`vec2`),i(`sunDirection`,new r.Vector3(0,1,0),`vec3`),i(`sunAngularSize`,.0087,`float`),a(`hasSun`,!1),i(`globalIlluminationIntensity`,z.globalIlluminationIntensity,`float`),i(`exposure`,z.exposure,`float`),i(`numDirectionalLights`,0,`int`),i(`numAreaLights`,0,`int`),i(`numPointLights`,0,`int`),i(`numSpotLights`,0,`int`),this._lightBuffers={directional:(0,n.uniformArray)(new Float32Array(128),`float`),area:(0,n.uniformArray)(new Float32Array(208),`float`),point:(0,n.uniformArray)(new Float32Array(144),`float`),spot:(0,n.uniformArray)(new Float32Array(224),`float`)},i(`cameraWorldMatrix`,new r.Matrix4,`mat4`),i(`cameraProjectionMatrixInverse`,new r.Matrix4,`mat4`),i(`cameraViewMatrix`,new r.Matrix4,`mat4`),i(`cameraProjectionMatrix`,new r.Matrix4,`mat4`),a(`enableDOF`,z.enableDOF),i(`focusDistance`,z.focusDistance,`float`),i(`focalLength`,z.focalLength,`float`),i(`aperture`,z.aperture,`float`),i(`apertureScale`,1,`float`),i(`anamorphicRatio`,z.anamorphicRatio??1,`float`),i(`sceneScale`,1,`float`),this._uniforms.set(`samplingTechnique`,A),A.value=z.samplingTechnique,a(`useAdaptiveSampling`,z.adaptiveSampling),i(`adaptiveSamplingMin`,z.adaptiveSamplingMin??1,`int`),i(`adaptiveSamplingMax`,z.adaptiveSamplingMax,`int`),i(`fireflyThreshold`,z.fireflyThreshold,`float`),a(`enableEmissiveTriangleSampling`,z.enableEmissiveTriangleSampling),i(`emissiveBoost`,z.emissiveBoost,`float`),i(`emissiveTriangleCount`,0,`int`),i(`emissiveTotalPower`,0,`float`),i(`lightBVHNodeCount`,0,`int`),i(`emissiveVec4Offset`,0,`int`),i(`renderMode`,z.renderMode,`int`),a(`enableAlphaShadows`,z.enableAlphaShadows),i(`resolution`,new r.Vector2(e,t),`vec2`),i(`totalTriangleCount`,0,`int`)}_nameAll(){for(let[e,t]of this._uniforms)t.name=Ue[e]||e}dispose(){this._disposed||(this._disposed=!0,this._uniforms.clear(),this._booleans.clear(),this._lightBuffers={})}},Ge=V.SLOTS_PER_MATERIAL,Ke=B.UV_C_MAT_OFFSET+2,qe=B.NORMAL_C_OFFSET+3,Je=B.NORMAL_A_OFFSET+3,Ye=new Set([`transmission`,`transparent`,`opacity`,`alphaMode`]),Xe=class{constructor(e){this.sdfs=e,this.materialStorageAttr=null,this.materialStorageNode=null,this.materialCount=0,this.albedoMaps=null,this.emissiveMaps=null,this.normalMaps=null,this.bumpMaps=null,this.roughnessMaps=null,this.metalnessMaps=null,this.displacementMaps=null,this.compiledFeatures=null,this.callbacks={}}setMaterialData(e){if(!e)return;let r=e.length/4;this.materialStorageNode?(this.materialStorageAttr=new t.StorageInstancedBufferAttribute(e,4),this.materialStorageNode.value=this.materialStorageAttr,this.materialStorageNode.bufferCount=r):(this.materialStorageAttr=new t.StorageInstancedBufferAttribute(e,4),this.materialStorageNode=(0,n.storage)(this.materialStorageAttr,`vec4`,r).toReadOnly()),this.materialCount=Math.floor(r/Ge),console.log(`MaterialDataManager: ${this.materialCount} materials (storage buffer)`)}getStorageAttr(){return this.materialStorageAttr}getStorageNode(){return this.materialStorageNode}setMaterialTextures(e){e.albedoMaps&&(this.albedoMaps=e.albedoMaps),e.emissiveMaps&&(this.emissiveMaps=e.emissiveMaps),e.normalMaps&&(this.normalMaps=e.normalMaps),e.bumpMaps&&(this.bumpMaps=e.bumpMaps),e.roughnessMaps&&(this.roughnessMaps=e.roughnessMaps),e.metalnessMaps&&(this.metalnessMaps=e.metalnessMaps),e.displacementMaps&&(this.displacementMaps=e.displacementMaps)}loadTexturesFromSdfs(){this.albedoMaps=this.sdfs.albedoTextures,this.emissiveMaps=this.sdfs.emissiveTextures,this.normalMaps=this.sdfs.normalTextures,this.bumpMaps=this.sdfs.bumpTextures,this.roughnessMaps=this.sdfs.roughnessTextures,this.metalnessMaps=this.sdfs.metalnessTextures,this.displacementMaps=this.sdfs.displacementTextures}getTextureArrays(){return{albedoMaps:this.albedoMaps,emissiveMaps:this.emissiveMaps,normalMaps:this.normalMaps,bumpMaps:this.bumpMaps,roughnessMaps:this.roughnessMaps,metalnessMaps:this.metalnessMaps,displacementMaps:this.displacementMaps}}updateMaterialProperty(e,t,n){if(!this.materialStorageAttr){console.warn(`Material storage buffer not available`);return}let r=this.materialStorageAttr.array,i=e*V.FLOATS_PER_MATERIAL;switch(t){case`color`:n.r===void 0?Array.isArray(n)&&(r[i+V.COLOR]=n[0],r[i+V.COLOR+1]=n[1],r[i+V.COLOR+2]=n[2]):(r[i+V.COLOR]=n.r,r[i+V.COLOR+1]=n.g,r[i+V.COLOR+2]=n.b);break;case`metalness`:r[i+V.METALNESS]=n;break;case`emissive`:n.r===void 0?Array.isArray(n)&&(r[i+V.EMISSIVE]=n[0],r[i+V.EMISSIVE+1]=n[1],r[i+V.EMISSIVE+2]=n[2]):(r[i+V.EMISSIVE]=n.r,r[i+V.EMISSIVE+1]=n.g,r[i+V.EMISSIVE+2]=n.b);break;case`roughness`:r[i+V.ROUGHNESS]=n;break;case`ior`:r[i+V.IOR]=n;break;case`transmission`:r[i+V.TRANSMISSION]=n;break;case`thickness`:r[i+V.THICKNESS]=n;break;case`emissiveIntensity`:r[i+V.EMISSIVE_INTENSITY]=n;break;case`attenuationColor`:n.r===void 0?Array.isArray(n)&&(r[i+V.ATTENUATION_COLOR]=n[0],r[i+V.ATTENUATION_COLOR+1]=n[1],r[i+V.ATTENUATION_COLOR+2]=n[2]):(r[i+V.ATTENUATION_COLOR]=n.r,r[i+V.ATTENUATION_COLOR+1]=n.g,r[i+V.ATTENUATION_COLOR+2]=n.b);break;case`attenuationDistance`:r[i+V.ATTENUATION_DISTANCE]=n;break;case`dispersion`:r[i+V.DISPERSION]=n;break;case`sheen`:r[i+V.SHEEN]=n;break;case`sheenRoughness`:r[i+V.SHEEN_ROUGHNESS]=n;break;case`sheenColor`:n.r===void 0?Array.isArray(n)&&(r[i+V.SHEEN_COLOR]=n[0],r[i+V.SHEEN_COLOR+1]=n[1],r[i+V.SHEEN_COLOR+2]=n[2]):(r[i+V.SHEEN_COLOR]=n.r,r[i+V.SHEEN_COLOR+1]=n.g,r[i+V.SHEEN_COLOR+2]=n.b);break;case`specularIntensity`:r[i+V.SPECULAR_INTENSITY]=n;break;case`specularColor`:n.r===void 0?Array.isArray(n)&&(r[i+V.SPECULAR_COLOR]=n[0],r[i+V.SPECULAR_COLOR+1]=n[1],r[i+V.SPECULAR_COLOR+2]=n[2]):(r[i+V.SPECULAR_COLOR]=n.r,r[i+V.SPECULAR_COLOR+1]=n.g,r[i+V.SPECULAR_COLOR+2]=n.b);break;case`iridescence`:r[i+V.IRIDESCENCE]=n;break;case`iridescenceIOR`:r[i+V.IRIDESCENCE_IOR]=n;break;case`iridescenceThicknessRange`:Array.isArray(n)&&(r[i+V.IRIDESCENCE_THICKNESS_RANGE]=n[0],r[i+V.IRIDESCENCE_THICKNESS_RANGE+1]=n[1]);break;case`clearcoat`:r[i+V.CLEARCOAT]=n;break;case`clearcoatRoughness`:r[i+V.CLEARCOAT_ROUGHNESS]=n;break;case`opacity`:r[i+V.OPACITY]=n;break;case`side`:r[i+V.SIDE]=n,this._patchTriangleSideForMaterial(e,n);break;case`transparent`:r[i+V.TRANSPARENT]=n;break;case`alphaTest`:r[i+V.ALPHA_TEST]=n;break;case`alphaMode`:r[i+V.ALPHA_MODE]=n;break;case`depthWrite`:r[i+V.DEPTH_WRITE]=n;break;case`normalScale`:n.x===void 0?typeof n==`number`&&(r[i+V.NORMAL_SCALE]=n,r[i+V.NORMAL_SCALE+1]=n):(r[i+V.NORMAL_SCALE]=n.x,r[i+V.NORMAL_SCALE+1]=n.y);break;case`bumpScale`:r[i+V.BUMP_SCALE]=n;break;case`displacementScale`:r[i+V.DISPLACEMENT_SCALE]=n;break;default:console.warn(`Unknown material property: ${t}`);return}this.materialStorageAttr.needsUpdate=!0,Ye.has(t)&&this._recomputeOpaqueBlockerForMaterial(e),[`transmission`,`clearcoat`,`sheen`,`iridescence`,`dispersion`,`transparent`,`opacity`,`alphaTest`].includes(t)&&this.rescanMaterialFeatures()&&this._notifyFeaturesChanged(),this._notifyReset()}updateMaterialDataFromObject(e,t){if(!this.materialStorageAttr){console.warn(`Material storage buffer not available`);return}let n=this.materialStorageAttr.array,r=e*V.FLOATS_PER_MATERIAL;t.color&&(n[r+V.COLOR]=t.color.r??t.color[0]??1,n[r+V.COLOR+1]=t.color.g??t.color[1]??1,n[r+V.COLOR+2]=t.color.b??t.color[2]??1),n[r+V.METALNESS]=t.metalness??0,t.emissive&&(n[r+V.EMISSIVE]=t.emissive.r??t.emissive[0]??0,n[r+V.EMISSIVE+1]=t.emissive.g??t.emissive[1]??0,n[r+V.EMISSIVE+2]=t.emissive.b??t.emissive[2]??0),n[r+V.ROUGHNESS]=t.roughness??1,n[r+V.IOR]=t.ior??1.5,n[r+V.TRANSMISSION]=t.transmission??0,n[r+V.THICKNESS]=t.thickness??.1,n[r+V.EMISSIVE_INTENSITY]=t.emissiveIntensity??1,t.attenuationColor&&(n[r+V.ATTENUATION_COLOR]=t.attenuationColor.r??t.attenuationColor[0]??1,n[r+V.ATTENUATION_COLOR+1]=t.attenuationColor.g??t.attenuationColor[1]??1,n[r+V.ATTENUATION_COLOR+2]=t.attenuationColor.b??t.attenuationColor[2]??1),n[r+V.ATTENUATION_DISTANCE]=t.attenuationDistance??1/0,n[r+V.DISPERSION]=t.dispersion??0,n[r+V.VISIBLE]=1,n[r+V.SHEEN]=t.sheen??0,n[r+V.SHEEN_ROUGHNESS]=t.sheenRoughness??1,t.sheenColor&&(n[r+V.SHEEN_COLOR]=t.sheenColor.r??t.sheenColor[0]??0,n[r+V.SHEEN_COLOR+1]=t.sheenColor.g??t.sheenColor[1]??0,n[r+V.SHEEN_COLOR+2]=t.sheenColor.b??t.sheenColor[2]??0),n[r+V.SPECULAR_INTENSITY]=t.specularIntensity??1,t.specularColor&&(n[r+V.SPECULAR_COLOR]=t.specularColor.r??t.specularColor[0]??1,n[r+V.SPECULAR_COLOR+1]=t.specularColor.g??t.specularColor[1]??1,n[r+V.SPECULAR_COLOR+2]=t.specularColor.b??t.specularColor[2]??1),n[r+V.IRIDESCENCE]=t.iridescence??0,n[r+V.IRIDESCENCE_IOR]=t.iridescenceIOR??1.3,t.iridescenceThicknessRange&&(n[r+V.IRIDESCENCE_THICKNESS_RANGE]=t.iridescenceThicknessRange[0]??100,n[r+V.IRIDESCENCE_THICKNESS_RANGE+1]=t.iridescenceThicknessRange[1]??400),n[r+V.ALBEDO_MAP_INDEX]=t.map??-1,n[r+V.NORMAL_MAP_INDEX]=t.normalMap??-1,n[r+V.ROUGHNESS_MAP_INDEX]=t.roughnessMap??-1,n[r+V.METALNESS_MAP_INDEX]=t.metalnessMap??-1,n[r+V.EMISSIVE_MAP_INDEX]=t.emissiveMap??-1,n[r+V.BUMP_MAP_INDEX]=t.bumpMap??-1,n[r+V.CLEARCOAT]=t.clearcoat??0,n[r+V.CLEARCOAT_ROUGHNESS]=t.clearcoatRoughness??0,n[r+V.OPACITY]=t.opacity??1,n[r+V.SIDE]=t.side??0,this._patchTriangleSideForMaterial(e,t.side??0),this._recomputeOpaqueBlockerForMaterial(e),n[r+V.TRANSPARENT]=t.transparent??0,n[r+V.ALPHA_TEST]=t.alphaTest??0,n[r+V.ALPHA_MODE]=t.alphaMode??0,n[r+V.DEPTH_WRITE]=t.depthWrite??1,n[r+V.NORMAL_SCALE]=t.normalScale?.x??(typeof t.normalScale==`number`?t.normalScale:1),n[r+V.NORMAL_SCALE+1]=t.normalScale?.y??(typeof t.normalScale==`number`?t.normalScale:1),n[r+V.BUMP_SCALE]=t.bumpScale??1,n[r+V.DISPLACEMENT_SCALE]=t.displacementScale??1,n[r+V.DISPLACEMENT_MAP_INDEX]=t.displacementMap??-1;let i=[1,0,0,0,1,0,0,0,1],a=[{key:`mapMatrix`,offset:V.ALBEDO_TRANSFORM},{key:`normalMapMatrices`,offset:V.NORMAL_TRANSFORM},{key:`roughnessMapMatrices`,offset:V.ROUGHNESS_TRANSFORM},{key:`metalnessMapMatrices`,offset:V.METALNESS_TRANSFORM},{key:`emissiveMapMatrices`,offset:V.EMISSIVE_TRANSFORM},{key:`bumpMapMatrices`,offset:V.BUMP_TRANSFORM},{key:`displacementMapMatrices`,offset:V.DISPLACEMENT_TRANSFORM}];for(let{key:e,offset:o}of a){let a=t[e]??i;for(let e=0;e<9;e++)r+o+e<n.length&&(n[r+o+e]=a[e])}this.materialStorageAttr.needsUpdate=!0,this.rescanMaterialFeatures()&&this._notifyFeaturesChanged(),this._notifyReset()}updateMaterial(e,t){let n=this.sdfs.geometryExtractor.createMaterialObject(t);this.updateMaterialDataFromObject(e,n)}updateTextureTransform(e,t,n){if(!this.materialStorageAttr){console.warn(`Material storage buffer not available`);return}let r=this.materialStorageAttr.array,i=e*V.FLOATS_PER_MATERIAL,a={map:V.ALBEDO_TRANSFORM,normalMap:V.NORMAL_TRANSFORM,roughnessMap:V.ROUGHNESS_TRANSFORM,metalnessMap:V.METALNESS_TRANSFORM,emissiveMap:V.EMISSIVE_TRANSFORM,bumpMap:V.BUMP_TRANSFORM,displacementMap:V.DISPLACEMENT_TRANSFORM}[t];if(a===void 0){console.warn(`Unknown texture name for transform update: ${t}`);return}for(let e=0;e<9;e++)i+a+e<r.length&&(r[i+a+e]=n[e]);this.materialStorageAttr.needsUpdate=!0,this._notifyReset()}rescanMaterialFeatures(){if(!this.materialStorageAttr?.array)return console.warn(`[MaterialDataManager] Material storage buffer not available for feature scanning`),!1;let e=this.materialStorageAttr.array,t=this.sdfs.materialCount||1,n={hasClearcoat:!1,hasTransmission:!1,hasDispersion:!1,hasIridescence:!1,hasSheen:!1,hasTransparency:!1,hasMultiLobeMaterials:!1,hasMRTOutputs:!0};for(let r=0;r<t;r++){let t=r*V.FLOATS_PER_MATERIAL,i=e[t+V.TRANSMISSION],a=e[t+V.DISPERSION],o=e[t+V.SHEEN],s=e[t+V.IRIDESCENCE],c=e[t+V.CLEARCOAT],l=e[t+V.OPACITY],u=e[t+V.TRANSPARENT],d=e[t+V.ALPHA_TEST];c>0&&(n.hasClearcoat=!0),i>0&&(n.hasTransmission=!0),a>0&&(n.hasDispersion=!0),s>0&&(n.hasIridescence=!0),o>0&&(n.hasSheen=!0),(u>0||l<1||d>0)&&(n.hasTransparency=!0),[c>0,i>0,s>0,o>0].filter(Boolean).length>=2&&(n.hasMultiLobeMaterials=!0)}let r=JSON.stringify(this.sdfs.sceneFeatures)!==JSON.stringify(n);return r&&(this.sdfs.sceneFeatures=n),r}injectMaterialFeatureDefines(){let e=this.sdfs.sceneFeatures;if(!e){console.warn(`[MaterialDataManager] No sceneFeatures detected, skipping define injection`);return}let t=JSON.stringify(e);(!this.compiledFeatures||this.compiledFeatures!==t)&&(console.log(`[MaterialDataManager] Material features:`,e),this.compiledFeatures=t)}_notifyReset(){this.callbacks.onReset&&this.callbacks.onReset()}_notifyFeaturesChanged(){this.injectMaterialFeatureDefines()}_recomputeOpaqueBlockerForMaterial(e){let t=this.materialStorageAttr?.array;if(!t)return;let n=e*V.FLOATS_PER_MATERIAL,r=t[n+V.ALPHA_MODE]|0,i=t[n+V.TRANSPARENT]|0,a=t[n+V.TRANSMISSION]||0,o=t[n+V.OPACITY]??1,s=+(r===0&&i===0&&a===0&&o>=1);this._patchTriangleFlagForMaterial(e,Je,s)}_patchTriangleFlagForMaterial(e,t,n){let r=this.callbacks.getTriangleData?.(),i=r?.array,a=r?.count|0;if(!i||a===0)return;let o=B.FLOATS_PER_TRIANGLE,s=0;for(let r=0;r<a;r++){let a=r*o;i[a+Ke]===e&&(i[a+t]=n,s++)}s>0&&this.callbacks.onTriangleDataChanged&&this.callbacks.onTriangleDataChanged()}_patchTriangleSideForMaterial(e,t){this._patchTriangleFlagForMaterial(e,qe,t)}dispose(){this.materialStorageAttr=null,this.materialStorageNode=null,this.materialCount=0,this.albedoMaps=null,this.emissiveMaps=null,this.normalMaps=null,this.bumpMaps=null,this.roughnessMaps=null,this.metalnessMaps=null,this.displacementMaps=null,this.compiledFeatures=null}};async function Ze(e){let t=e instanceof URL?e.href:e,n=await fetch(t);if(!n.ok)throw Error(`Failed to fetch worker script: ${n.status}`);let r=new Blob([await n.text()],{type:`application/javascript`});return new Worker(URL.createObjectURL(r),{type:`module`})}var Qe=``+(typeof document>`u`&&typeof location>`u`?require(`url`).pathToFileURL(__dirname+`/assets/CDFWorker-BFQUr3By.js`).href:new URL(`assets/CDFWorker-BFQUr3By.js`,typeof document>`u`?location.href:document.currentScript&&document.currentScript.tagName.toUpperCase()===`SCRIPT`&&document.currentScript.src||document.baseURI).href);function $e(e,t,n=0,r=e.length){let i=n,a=n+r-1;for(;i<a;){let n=i+a>>1;e[n]<t?i=n+1:a=n}return i-n}function et(e,t,n){return .2126*e+.7152*t+.0722*n}function tt(e){return e<=.04045?e/12.92:((e+.055)/1.055)**2.4}function nt(e){let{width:t,height:n}=e.image,i=e.image.data,a=!1;if(!i){let r=new OffscreenCanvas(t,n).getContext(`2d`);r.drawImage(e.image,0,0,t,n),i=r.getImageData(0,0,t,n).data,a=!0}let o;if(e.type===r.FloatType&&i instanceof Float32Array)o=new Float32Array(i);else if(e.type===r.HalfFloatType){o=new Float32Array(i.length);for(let e=0,t=i.length;e<t;e++)o[e]=r.DataUtils.fromHalfFloat(i[e])}else{let e;e=i instanceof Int8Array||i instanceof Int16Array||i instanceof Int32Array?2**(8*i.BYTES_PER_ELEMENT-1)-1:2**(8*i.BYTES_PER_ELEMENT)-1,o=new Float32Array(i.length);for(let t=0,n=i.length;t<n;t++)o[t]=i[t]/e}if(!a&&e.colorSpace===r.SRGBColorSpace&&(a=!0),a)for(let e=0,t=o.length;e<t;e+=4)o[e]=tt(o[e]),o[e+1]=tt(o[e+1]),o[e+2]=tt(o[e+2]);if(e.flipY){let e=new Float32Array(o.length);for(let r=0;r<n;r++){let i=n-r-1,a=r*t*4,s=i*t*4;e.set(o.subarray(a,a+t*4),s)}o=e}return{floatData:o,width:t,height:n}}var rt=class e{constructor(){this.marginalData=new Float32Array([0,1]),this.conditionalData=new Float32Array([0,0,1,1]),this.totalSum=0,this.compensationDelta=0,this.width=0,this.height=0,this._worker=null}dispose(){this.marginalData=null,this.conditionalData=null,this._worker&&=(this._worker.terminate(),null)}updateFrom(t){let{floatData:n,width:r,height:i}=nt(t),a=e.computeCDF(n,r,i);this.marginalData=a.marginalData,this.conditionalData=a.conditionalData,this.totalSum=a.totalSum,this.compensationDelta=a.compensationDelta,this.width=r,this.height=i}async updateFromAsync(e){let{floatData:t,width:n,height:r}=nt(e);try{this._worker=new Worker(Qe,{type:`module`})}catch(e){if(e.name!==`SecurityError`)throw e;this._worker=await Ze(Qe)}try{let e=await new Promise((e,i)=>{this._worker.onmessage=t=>{t.data.error?i(Error(t.data.error)):e(t.data)},this._worker.onerror=i,this._worker.postMessage({floatData:t,width:n,height:r},[t.buffer])});this.marginalData=e.marginalData,this.conditionalData=e.conditionalData,this.totalSum=e.totalSum,this.compensationDelta=e.compensationDelta,this.width=e.width,this.height=e.height}finally{this._worker&&=(this._worker.terminate(),null)}}static computeCDF(e,t,n){let r=t*n,i=new Float32Array(r),a=0;for(let r=0;r<n;r++){let o=Math.sin(Math.PI*(r+.5)/n);for(let n=0;n<t;n++){let s=r*t+n,c=et(e[4*s],e[4*s+1],e[4*s+2])*o;i[s]=c,a+=c}}let o=a/r,s=0;for(let e=0;e<r;e++)i[e]=Math.max(0,i[e]-o),s+=i[e];let c=s>0,l=c?s:a,u=c?o:0;if(!c)for(let r=0;r<n;r++){let a=Math.sin(Math.PI*(r+.5)/n);for(let n=0;n<t;n++){let o=r*t+n;i[o]=et(e[4*o],e[4*o+1],e[4*o+2])*a}}let d=new Float32Array(r),f=new Float32Array(n),p=0;for(let e=0;e<n;e++){let n=0;for(let r=0;r<t;r++){let a=e*t+r;n+=i[a],d[a]=n}if(n!==0)for(let r=e*t,i=e*t+t;r<i;r++)d[r]/=n;p+=n,f[e]=p}if(p!==0)for(let e=0,t=f.length;e<t;e++)f[e]/=p;let m=new Float32Array(n),h=new Float32Array(r);for(let e=0;e<n;e++)m[e]=($e(f,(e+1)/n)+.5)/n;for(let e=0;e<n;e++)for(let n=0;n<t;n++){let r=e*t+n;h[r]=($e(d,(n+1)/t,e*t,t)+.5)/t}return{marginalData:m,conditionalData:h,totalSum:l,compensationDelta:u}}},it=Math.PI,at=Math.PI*2,ot=Math.E,st=[5804542996261093e-21,13562911419845635e-21,30265902468824876e-21],ct=[183999185144339.78,277980239196605.28,407904795438610.94],lt=1.6110731556870734,ut=1.5,dt=1e3,ft=8400,pt=1250,mt=.9999566769464484,ht=.05968310365946075,gt=.07957747154594767;function _t(e){return dt*Math.max(0,1-ot**+(-(lt-Math.acos(Math.max(-1,Math.min(1,e))))/ut))}function vt(e){let t=.2*e*1e-17;return[.434*t*ct[0],.434*t*ct[1],.434*t*ct[2]]}function yt(e){return ht*(1+e**2)}function bt(e,t){let n=t*t;return gt*((1-n)/(1-2*t*e+n)**1.5)}function xt(e,t){return e[0]*t[0]+e[1]*t[1]+e[2]*t[2]}function St(e){let t=Math.sqrt(e[0]*e[0]+e[1]*e[1]+e[2]*e[2]);return t===0?[0,0,0]:[e[0]/t,e[1]/t,e[2]/t]}function Ct(e,t,n,r,i,a,o,s){let c=(1-t)*it,l=(e-.5)*at,u=Math.sin(c),d=St([u*Math.sin(l),Math.cos(c),u*Math.cos(l)]),f=St(n),p=_t(f[1])*r,m=i-1*(1-(1-Math.max(0,Math.min(1,1-Math.exp(f[1]/45e4))))),h=[st[0]*m,st[1]*m,st[2]*m],g=vt(s),_=[g[0]*a,g[1]*a,g[2]*a],v=Math.acos(Math.max(0,d[1])),y=Math.cos(v)+.15*(93.885-180/it*v)**-1.253,b=ft/y,x=pt/y,S=[Math.exp(-(h[0]*b+_[0]*x)),Math.exp(-(h[1]*b+_[1]*x)),Math.exp(-(h[2]*b+_[2]*x))],C=xt(d,f),w=yt(C*.5+.5),T=[h[0]*w,h[1]*w,h[2]*w],E=bt(C,o),D=[_[0]*E,_[1]*E,_[2]*E],O=[T[0]+D[0],T[1]+D[1],T[2]+D[2]],k=[h[0]+_[0],h[1]+_[1],h[2]+_[2]],A=[(p*(O[0]/k[0])*(1-S[0]))**1.5,(p*(O[1]/k[1])*(1-S[1]))**1.5,(p*(O[2]/k[2])*(1-S[2]))**1.5],j=Math.max(0,Math.min(1,1-(1-f[1])**5)),M=[Math.sqrt(p*(O[0]/k[0])*S[0]),Math.sqrt(p*(O[1]/k[1])*S[1]),Math.sqrt(p*(O[2]/k[2])*S[2])],N=1-j;for(let e=0;e<3;e++){let t=1*(1-N)+M[e]*N;A[e]*=t}let ee=[.1*S[0],.1*S[1],.1*S[2]],te=wt(mt,mt+2e-5,C);for(let e=0;e<3;e++)ee[e]+=p*19e3*S[e]*te;let ne=65504;return[Math.min((A[0]+ee[0])*.04,ne),Math.min((A[1]+ee[1])*.04+3e-4,ne),Math.min((A[2]+ee[2])*.04+75e-5,ne),1]}function wt(e,t,n){let r=Math.max(0,Math.min(1,(n-e)/(t-e)));return r*r*(3-2*r)}var Tt=class{constructor(e=512,t=256){this.width=e,this.height=t,this.lastRenderTime=0,this._pixels=new Float32Array(e*t*4),this._texture=new r.DataTexture(this._pixels,e,t,r.RGBAFormat,r.FloatType),this._texture.mapping=r.EquirectangularReflectionMapping,this._texture.colorSpace=r.LinearSRGBColorSpace,this._texture.minFilter=r.LinearFilter,this._texture.magFilter=r.LinearFilter,this._texture.wrapS=r.RepeatWrapping,this._texture.wrapT=r.ClampToEdgeWrapping,this._texture.generateMipmaps=!1}render(e){let t=performance.now(),n=[e.sunDirection.x,e.sunDirection.y,e.sunDirection.z],r=e.sunIntensity||1,i=e.rayleighDensity||2,a=e.mieDensity||.005,o=e.mieAnisotropy||.8,s=e.turbidity||2,{width:c,height:l}=this,u=this._pixels;for(let e=0;e<l;e++){let t=(e+.5)/l;for(let l=0;l<c;l++){let d=Ct((l+.5)/c,t,n,r,i,a,o,s),f=(e*c+l)*4;u[f]=d[0],u[f+1]=d[1],u[f+2]=d[2],u[f+3]=d[3]}}return this._texture.needsUpdate=!0,this.lastRenderTime=performance.now()-t,this._texture}setResolution(e,t){this.width===e&&this.height===t||(this.width=e,this.height=t,this._pixels=new Float32Array(e*t*4),this._texture.dispose(),this._texture=new r.DataTexture(this._pixels,e,t,r.RGBAFormat,r.FloatType),this._texture.mapping=r.EquirectangularReflectionMapping,this._texture.colorSpace=r.LinearSRGBColorSpace,this._texture.minFilter=r.LinearFilter,this._texture.magFilter=r.LinearFilter,this._texture.wrapS=r.RepeatWrapping,this._texture.wrapT=r.ClampToEdgeWrapping,this._texture.generateMipmaps=!1)}getLastRenderTime(){return this.lastRenderTime}dispose(){this._texture.dispose()}},Et=class{constructor(e=512,t=256){this.width=e,this.height=t,this.lastRenderTime=0,this._pixels=new Float32Array(e*t*4),this._texture=new r.DataTexture(this._pixels,e,t,r.RGBAFormat,r.FloatType),this._texture.mapping=r.EquirectangularReflectionMapping,this._texture.colorSpace=r.LinearSRGBColorSpace,this._texture.minFilter=r.LinearFilter,this._texture.magFilter=r.LinearFilter,this._texture.wrapS=r.RepeatWrapping,this._texture.wrapT=r.ClampToEdgeWrapping,this._texture.generateMipmaps=!1}renderGradient(e){let t=performance.now(),{width:n,height:r}=this,i=this._pixels,a=e.zenithColor.r,o=e.zenithColor.g,s=e.zenithColor.b,c=e.horizonColor.r,l=e.horizonColor.g,u=e.horizonColor.b,d=e.groundColor.r,f=e.groundColor.g,p=e.groundColor.b;for(let e=0;e<r;e++){let t=(e+.5)/r,m,h,g;if(t>.5){let e=(t-.5)*2;m=c+(a-c)*e,h=l+(o-l)*e,g=u+(s-u)*e}else{let e=t*2;m=d+(c-d)*e,h=f+(l-f)*e,g=p+(u-p)*e}for(let t=0;t<n;t++){let r=(e*n+t)*4;i[r]=m,i[r+1]=h,i[r+2]=g,i[r+3]=1}}return this._texture.needsUpdate=!0,this.lastRenderTime=performance.now()-t,this._texture}renderSolid(e){let t=performance.now(),{width:n,height:r}=this,i=this._pixels,a=e.color.r,o=e.color.g,s=e.color.b;for(let e=0;e<r;e++)for(let t=0;t<n;t++){let r=(e*n+t)*4;i[r]=a,i[r+1]=o,i[r+2]=s,i[r+3]=1}return this._texture.needsUpdate=!0,this.lastRenderTime=performance.now()-t,this._texture}setResolution(e,t){this.width===e&&this.height===t||(this.width=e,this.height=t,this._pixels=new Float32Array(e*t*4),this._texture.dispose(),this._texture=new r.DataTexture(this._pixels,e,t,r.RGBAFormat,r.FloatType),this._texture.mapping=r.EquirectangularReflectionMapping,this._texture.colorSpace=r.LinearSRGBColorSpace,this._texture.minFilter=r.LinearFilter,this._texture.magFilter=r.LinearFilter,this._texture.wrapS=r.RepeatWrapping,this._texture.wrapT=r.ClampToEdgeWrapping,this._texture.generateMipmaps=!1)}getLastRenderTime(){return this.lastRenderTime}dispose(){this._texture.dispose()}},Dt=class{constructor(e,t){this.scene=e,this.uniforms=t,this.equirectHdrInfo=new rt,this.proceduralSkyRenderer=null,this.simpleSkyRenderer=null,this._envPlaceholder=new r.DataTexture(new Float32Array([0,0,0,1]),1,1,r.RGBAFormat,r.FloatType),this._envPlaceholder.needsUpdate=!0,this.environmentTexture=this._envPlaceholder,this.envTexSize=new r.Vector2,this.envCDFStorageAttr=null,this.envCDFStorageNode=null,this._initCDFStorageBuffers(),this.environmentRotationMatrix=new r.Matrix4,this.cdfBuildTime=0,this.envParams={mode:`hdri`,gradientZenithColor:new r.Color(z.gradientZenithColor),gradientHorizonColor:new r.Color(z.gradientHorizonColor),gradientGroundColor:new r.Color(z.gradientGroundColor),solidSkyColor:new r.Color(z.solidSkyColor),skySunDirection:this._calculateInitialSunDirection(),skySunIntensity:z.skySunIntensity,skyRayleighDensity:z.skyRayleighDensity,skyTurbidity:z.skyTurbidity,skyMieAnisotropy:z.skyMieAnisotropy},this.callbacks={},this._previousHDRI=null}async setMode(e){let t=this.envParams.mode;this.envParams.mode=e,e!==`hdri`&&t===`hdri`&&(this._previousHDRI=this.environmentTexture),e===`gradient`?await this.generateGradientTexture():e===`color`?await this.generateSolidColorTexture():e===`procedural`?await this.generateProceduralSkyTexture():e===`hdri`&&this._previousHDRI&&(await this.setEnvironmentMap(this._previousHDRI),this._previousHDRI=null),this.markDirty(),this.callbacks.onAutoExposureReset?.(),this._notifyReset()}markDirty(){this.environmentTexture&&(this.environmentTexture.needsUpdate=!0)}get params(){return this.envParams}get texture(){return this.environmentTexture}generateGradient(){return this.generateGradientTexture()}generateSolid(){return this.generateSolidColorTexture()}generateProcedural(){return this.generateProceduralSkyTexture()}_initCDFStorageBuffers(){let e=new Float32Array([0,1,0,0,1,1]);this.envCDFStorageAttr=new t.StorageInstancedBufferAttribute(e,1),this.envCDFStorageNode=(0,n.storage)(this.envCDFStorageAttr,`float`,e.length).toReadOnly()}_updateCDFStorageBuffers(){let e=this.equirectHdrInfo.marginalData,n=this.equirectHdrInfo.conditionalData;if(!e||!n)return;let r=new Float32Array(e.length+n.length);r.set(e,0),r.set(n,e.length),this.envCDFStorageAttr=new t.StorageInstancedBufferAttribute(r,1),this.envCDFStorageNode.value=this.envCDFStorageAttr,this.envCDFStorageNode.bufferCount=r.length}getCDFStorageNodes(){return{cdfNode:this.envCDFStorageNode}}setEnvironmentTexture(e){e&&(this.environmentTexture=e,this.envTexSize.set(e.image.width,e.image.height),console.log(`EnvironmentManager: Environment map ${e.image.width}x${e.image.height}`))}getEnvironmentTexture(){return this.environmentTexture}setEnvironmentRotation(e){let t=Math.PI/180*e;this.environmentRotationMatrix.makeRotationY(t),this.uniforms.get(`environmentMatrix`).value.copy(this.environmentRotationMatrix)}async buildEnvironmentCDF({useWorker:e=!0}={}){if(!this.scene.environment){this._updateCDFStorageBuffers(),this.uniforms.set(`envTotalSum`,0),this.uniforms.set(`envCompensationDelta`,0),this.uniforms.set(`useEnvMapIS`,0);return}try{let t=performance.now(),n=this.scene.environment;if(!n.image){this._updateCDFStorageBuffers(),this.uniforms.set(`envTotalSum`,0),this.uniforms.set(`envCompensationDelta`,0),this.uniforms.set(`useEnvMapIS`,0);return}e?await this.equirectHdrInfo.updateFromAsync(n):this.equirectHdrInfo.updateFrom(n),this.cdfBuildTime=performance.now()-t,this._updateCDFStorageBuffers(),this.uniforms.set(`envTotalSum`,this.equirectHdrInfo.totalSum),this.uniforms.set(`envCompensationDelta`,this.equirectHdrInfo.compensationDelta),this.uniforms.set(`useEnvMapIS`,1);let{width:r,height:i}=this.equirectHdrInfo;r&&i&&this.uniforms.get(`envResolution`).value.set(r,i),console.log(`Environment CDF built in ${this.cdfBuildTime.toFixed(2)}ms (worker: ${e})`)}catch(e){console.error(`Error building environment CDF:`,e),this.uniforms.set(`useEnvMapIS`,0),this.uniforms.set(`envTotalSum`,0),this.uniforms.set(`envCompensationDelta`,0)}}applyCDFResults(){let e=this.scene.environment,t=this.callbacks.getSceneTextureNodes?.();t&&e&&t.envTex&&(t.envTex.value=e),e&&!e._isGeneratedProcedural&&this.uniforms.set(`hasSun`,0)}async setEnvironmentMap(e){this.scene.environment=e,this.setEnvironmentTexture(e),e?await this.buildEnvironmentCDF():(this._updateCDFStorageBuffers(),this.uniforms.set(`envTotalSum`,0),this.uniforms.set(`envCompensationDelta`,0),this.uniforms.set(`useEnvMapIS`,0));let t=this.callbacks.getSceneTextureNodes?.();t&&e&&t.envTex&&(t.envTex.value=e),e&&!e._isGeneratedProcedural&&this.uniforms.set(`hasSun`,0),this._notifyReset()}async generateGradientTexture(){this.simpleSkyRenderer||=new Et(512,256);let e={zenithColor:this.envParams.gradientZenithColor,horizonColor:this.envParams.gradientHorizonColor,groundColor:this.envParams.gradientGroundColor};try{let t=this.simpleSkyRenderer.renderGradient(e);t._isGeneratedProcedural=!0,await this.setEnvironmentMap(t),this.uniforms.set(`hasSun`,0)}catch(e){console.error(`Error generating gradient sky:`,e)}}async generateSolidColorTexture(){this.simpleSkyRenderer||=new Et(512,256);let e={color:this.envParams.solidSkyColor};try{let t=this.simpleSkyRenderer.renderSolid(e);t._isGeneratedProcedural=!0,await this.setEnvironmentMap(t),this.uniforms.set(`hasSun`,0)}catch(e){console.error(`Error generating solid color sky:`,e)}}async generateProceduralSkyTexture(){this.proceduralSkyRenderer||=new Tt(512,256);let e={sunDirection:this.envParams.skySunDirection.clone(),sunIntensity:this.envParams.skySunIntensity*.05,rayleighDensity:this.envParams.skyRayleighDensity*2,mieDensity:this.envParams.skyTurbidity*.005,mieAnisotropy:this.envParams.skyMieAnisotropy,turbidity:this.envParams.skyTurbidity*2};try{let t=this.proceduralSkyRenderer.render(e);t._isGeneratedProcedural=!0,await this.setEnvironmentMap(t),this.uniforms.get(`sunDirection`).value.copy(this.envParams.skySunDirection),this.uniforms.set(`sunAngularSize`,.0087),this.uniforms.set(`hasSun`,1),console.log(`Sun parameters synced: dir=${this.envParams.skySunDirection.toArray().map(e=>e.toFixed(2)).join(`,`)}`)}catch(e){console.error(`Error generating procedural sky:`,e)}}_calculateInitialSunDirection(){let e=z.skySunAzimuth*(Math.PI/180),t=z.skySunElevation*(Math.PI/180);return new r.Vector3(Math.cos(t)*Math.sin(e),Math.sin(t),Math.cos(t)*Math.cos(e)).normalize()}_notifyReset(){this.callbacks.onReset&&this.callbacks.onReset()}dispose(){this.proceduralSkyRenderer=null,this.simpleSkyRenderer=null,this.envCDFStorageAttr?.dispose?.(),this.envCDFStorageAttr=null,this.envCDFStorageNode=null,this.environmentTexture&&this.environmentTexture!==this._envPlaceholder&&this.environmentTexture.dispose?.(),this._envPlaceholder?.dispose(),this._envPlaceholder=null,this.environmentTexture=null,this._previousHDRI=null}},Ot=D({origin:`vec3`,direction:`vec3`}),kt=D({color:`vec4`,emissive:`vec3`,emissiveIntensity:`float`,roughness:`float`,metalness:`float`,ior:`float`,transmission:`float`,thickness:`float`,clearcoat:`float`,clearcoatRoughness:`float`,opacity:`float`,transparent:`bool`,attenuationColor:`vec3`,attenuationDistance:`float`,dispersion:`float`,sheen:`float`,sheenRoughness:`float`,sheenColor:`vec3`,specularIntensity:`float`,specularColor:`vec3`,alphaTest:`float`,alphaMode:`int`,side:`int`,depthWrite:`int`,albedoMapIndex:`int`,emissiveMapIndex:`int`,normalMapIndex:`int`,bumpMapIndex:`int`,bumpScale:`float`,displacementScale:`float`,metalnessMapIndex:`int`,roughnessMapIndex:`int`,displacementMapIndex:`int`,normalScale:`vec2`,albedoTransform:`mat3`,emissiveTransform:`mat3`,normalTransform:`mat3`,bumpTransform:`mat3`,metalnessTransform:`mat3`,roughnessTransform:`mat3`,displacementTransform:`mat3`,iridescence:`float`,iridescenceIOR:`float`,iridescenceThicknessRange:`vec2`}),At=D({color:`vec4`,ior:`float`,transmission:`float`,attenuationColor:`vec3`,attenuationDistance:`float`,albedoMapIndex:`int`,opacity:`float`,transparent:`bool`,alphaTest:`float`,alphaMode:`int`,albedoTransform:`mat3`});D({position:`vec3`,radius:`float`,material:kt});var jt=D({didHit:`bool`,dst:`float`,hitPoint:`vec3`,normal:`vec3`,uv:`vec2`,materialIndex:`int`,meshIndex:`int`,triangleIndex:`int`,boxTests:`int`,triTests:`int`});D({posA:`vec3`,posB:`vec3`,posC:`vec3`,uvA:`vec2`,uvB:`vec2`,uvC:`vec2`,normalA:`vec3`,normalB:`vec3`,normalC:`vec3`,material:kt,materialIndex:`int`,meshIndex:`int`}),D({color:`vec4`,samples:`int`});var Mt=D({direction:`vec3`,value:`vec3`,pdf:`float`}),Nt=D({specular:`float`,diffuse:`float`,sheen:`float`,clearcoat:`float`,transmission:`float`,iridescence:`float`}),Pt=D({diffuseImportance:`float`,specularImportance:`float`,transmissionImportance:`float`,clearcoatImportance:`float`,envmapImportance:`float`}),Ft=D({NoL:`float`,NoV:`float`,NoH:`float`,VoH:`float`,LoH:`float`}),It=D({albedo:`vec4`,emissive:`vec3`,metalness:`float`,roughness:`float`,normal:`vec3`,hasTextures:`bool`}),Lt=D({isMetallic:`bool`,isRough:`bool`,isSmooth:`bool`,isTransmissive:`bool`,hasClearcoat:`bool`,isEmissive:`bool`,complexityScore:`float`}),Rt=D({albedoUV:`vec2`,normalUV:`vec2`,metalnessUV:`vec2`,emissiveUV:`vec2`,bumpUV:`vec2`,roughnessUV:`vec2`,normalBumpSameUV:`bool`,metalRoughSameUV:`bool`,albedoEmissiveSameUV:`bool`,allSameUV:`bool`}),zt=D({F0:`vec3`,NoV:`float`,diffuseColor:`vec3`,isPurelyDiffuse:`bool`,alpha:`float`,k:`float`,alpha2:`float`,invRoughness:`float`,metalFactor:`float`,iorFactor:`float`,maxSheenColor:`float`}),Bt=D({envWeight:`float`,specularWeight:`float`,diffuseWeight:`float`,transmissionWeight:`float`,clearcoatWeight:`float`,totalWeight:`float`,useEnv:`bool`,useSpecular:`bool`,useDiffuse:`bool`,useTransmission:`bool`,useClearcoat:`bool`}),Vt=D({brdfWeight:`float`,lightWeight:`float`,envWeight:`float`,useBRDFSampling:`bool`,useLightSampling:`bool`,useEnvSampling:`bool`}),Ht=D({diffuse:`float`,specular:`float`,clearcoat:`float`,transmission:`float`,sheen:`float`,iridescence:`float`,totalWeight:`float`});D({traversals:`int`,transmissiveTraversals:`int`,rayType:`int`,isPrimaryRay:`bool`,actualBounceDepth:`int`}),D({gColor:`vec4`,gNormalDepth:`vec4`,gAlbedo:`vec4`});var G=3.14159,Ut=1/G,Wt=2*G,K=1e-6,Gt=.05,Kt=.089,q=.001,qt=(0,n.vec3)(.2126,.7152,.0722),J=V.SLOTS_PER_MATERIAL,Jt=V.SLOT,Y=Jt,Yt=(0,n.mat3)(3.2404542,-.969266,.0556434,-1.5371385,1.8760108,-.2040259,-.4985314,.041556,1.0572252);(0,n.wgslFn)(`
143
+ `,[j,A]),L={ALWAYS:`always`,PER_CYCLE:`per_cycle`,PER_TILE:`per_tile`,CONDITIONAL:`conditional`},R=class{constructor(e,t={}){this.name=e,this.enabled=t.enabled!==!1,this.executionMode=t.executionMode||L.ALWAYS,this.context=null,this.eventBus=null}initialize(e,t){this.context=e,this.eventBus=t,this.setupEventListeners()}setupEventListeners(){}shouldExecuteThisFrame(e){if(!this.enabled)return!1;let t=e.getState(`renderMode`)||0,n=e.getState(`tileRenderingComplete`);switch(this.executionMode){case L.ALWAYS:return!0;case L.PER_CYCLE:return t===0?!0:n===!0;case L.PER_TILE:return!0;case L.CONDITIONAL:return this.shouldExecute(e);default:return this.warn(`Unknown execution mode: ${this.executionMode}`),!0}}shouldExecute(e){return!0}render(e,t){throw Error(`render() must be implemented in ${this.name}`)}reset(){}setSize(e,t){}dispose(){}emit(e,t){this.eventBus&&this.eventBus.emit(e,t)}on(e,t){this.eventBus&&this.eventBus.on(e,t)}once(e,t){this.eventBus&&this.eventBus.once(e,t)}off(e,t){this.eventBus&&this.eventBus.off(e,t)}enable(){this.enabled||(this.enabled=!0,this.emit(`stage:enabled`,{stage:this.name}))}disable(){this.enabled&&(this.enabled=!1,this.emit(`stage:disabled`,{stage:this.name}))}toggle(){this.enabled?this.disable():this.enable()}isEnabled(){return this.enabled}log(...e){console.log(`[${this.name}]`,...e)}warn(...e){console.warn(`[${this.name}]`,...e)}error(...e){console.error(`[${this.name}]`,...e)}},se=class{constructor(e,t,n){this.width=e,this.height=t,this.tiles=n,this.tileIndex=0,this.tileBoundsCache=new Map,this.totalTilesCache=n*n,this.currentTileBounds=null,this.spiralOrder=this.generateSpiralOrder(n)}calculateTileBounds(e,t,n,r){let i=`${e}-${t}-${n}-${r}`;if(this.tileBoundsCache.has(i))return this.tileBoundsCache.get(i);let a=Math.ceil(n/t),o=Math.ceil(r/t),s=e%t,c=Math.floor(e/t),l=s*a,u=c*o,d={x:l,y:u,width:Math.min(a,n-l),height:Math.min(o,r-u)};return this.tileBoundsCache.set(i,d),d}generateSpiralOrder(e){let t=e*e,n=[];for(let r=0;r<t;r++){let t=r%e,i=Math.floor(r/e),a=(e-1)/2,o=t-a,s=i-a,c=Math.abs(o)+Math.abs(s),l=Math.sqrt(o*o+s*s),u=Math.atan(s,o);u<0&&(u+=2*Math.PI);let d=(t+i*e)*.001;n.push({index:r,x:t,y:i,manhattanDistance:c,euclideanDistance:l,angle:u,positionOffset:d})}return n.sort((e,t)=>{let n=e.manhattanDistance-t.manhattanDistance;if(Math.abs(n)>.01)return n;let r=e.euclideanDistance-t.euclideanDistance;if(Math.abs(r)>.01)return r;let i=e.angle-t.angle;return Math.abs(i)>.01?i:e.positionOffset-t.positionOffset}),n.map(e=>e.index)}handleTileRendering(e,t,n){let r=!0,i=-1,a=null,o=!0;if(t===1)if(n===0)i=-1,o=!0;else{let e=(n-1)%this.totalTilesCache;i=this.spiralOrder[e],a=this.calculateTileBounds(i,this.tiles,this.width,this.height),o=e===this.totalTilesCache-1,r=o}else i=-1,o=!0;return this.tileIndex=i,{tileIndex:i,tileBounds:a,shouldSwapTargets:r,isCompleteCycle:o}}setTileCount(e){if(e<1&&(console.warn(`TileManager: Tile count must be at least 1, clamping to 1`),e=1),e>10&&console.warn(`TileManager: Tile count > 10 may cause performance issues`),e>6){let t=e*e;console.warn(`TileManager: ${e}x${e} = ${t} tiles may impact performance and memory usage`)}this.tiles=e,this.totalTilesCache=e*e,this.tileIndex=0,this.spiralOrder=this.generateSpiralOrder(e),this.tileBoundsCache.clear()}setSize(e,t){this.width=e,this.height=t,this.tileBoundsCache.clear()}calculateCompletionThreshold(e){return this.totalTilesCache*e}getCurrentTileInfo(){return{tileIndex:this.tileIndex,tiles:this.tiles,totalTiles:this.totalTilesCache,currentBounds:this.currentTileBounds}}dispose(){this.tileBoundsCache.clear(),this.currentTileBounds=null}},ce=class{constructor(e,t,n={}){this.renderer=e,this.material=t,this.interactionModeEnabled=n.enabled===void 0?!0:n.enabled,this.interactionDelay=n.delay||100,this.interactionMode=!1,this.interactionTimeout=null,this.originalValues={},this.wasAccumulationEnabled=!0,this.interactionQualitySettings={maxBounceCount:1,numRaysPerPixel:1,useAdaptiveSampling:!1,useEnvMapIS:!1,enableAccumulation:!1,...n.qualitySettings},this.onEnterCallback=n.onEnter||null,this.onExitCallback=n.onExit||null,this.onResetCallback=n.onReset||null}enterInteractionMode(){this.interactionModeEnabled&&(this.interactionMode?clearTimeout(this.interactionTimeout):(this.interactionMode=!0,this.originalValues={},this.material.uniforms.enableAccumulation&&(this.wasAccumulationEnabled=this.material.uniforms.enableAccumulation.value),Object.keys(this.interactionQualitySettings).forEach(e=>{e===`pixelRatio`?(this.originalValues.dpr=this.renderer.getPixelRatio(),this.renderer.setPixelRatio(this.interactionQualitySettings.pixelRatio)):e===`enableAccumulation`||this.material.uniforms[e]&&(this.originalValues[e]=this.material.uniforms[e].value,this.material.uniforms[e].value=this.interactionQualitySettings[e])}),this.material.uniforms.enableAccumulation&&(this.originalValues.enableAccumulation=this.material.uniforms.enableAccumulation.value,this.material.uniforms.enableAccumulation.value=!1),this.material.uniforms.cameraIsMoving&&(this.originalValues.cameraIsMoving=this.material.uniforms.cameraIsMoving.value,this.material.uniforms.cameraIsMoving.value=!0),this.onEnterCallback&&this.onEnterCallback()),this.interactionTimeout=setTimeout(()=>{this.exitInteractionMode()},this.interactionDelay))}exitInteractionMode(){this.interactionMode&&(Object.keys(this.originalValues).forEach(e=>{e===`dpr`?this.renderer.setPixelRatio(this.originalValues.dpr):this.material.uniforms[e]&&(this.material.uniforms[e].value=this.originalValues[e])}),this.interactionMode=!1,this.originalValues={},this.onExitCallback&&this.onExitCallback(),this.onResetCallback&&this.onResetCallback())}updateInteractionMode(e){e&&this.enterInteractionMode()}setInteractionModeEnabled(e){this.interactionModeEnabled=e,!e&&this.interactionMode&&(clearTimeout(this.interactionTimeout),this.exitInteractionMode())}updateQualitySettings(e){Object.assign(this.interactionQualitySettings,e),this.interactionMode&&Object.keys(e).forEach(t=>{t===`pixelRatio`?this.renderer.setPixelRatio(e.pixelRatio):this.material.uniforms[t]&&(this.material.uniforms[t].value=e[t])})}setInteractionDelay(e){this.interactionDelay=e}getState(){return{interactionMode:this.interactionMode,interactionModeEnabled:this.interactionModeEnabled,interactionDelay:this.interactionDelay,hasTimeout:this.interactionTimeout!==null,qualitySettings:{...this.interactionQualitySettings},originalValues:{...this.originalValues},wasAccumulationEnabled:this.wasAccumulationEnabled}}forceExitInteractionMode(){this.interactionTimeout&&=(clearTimeout(this.interactionTimeout),null),this.exitInteractionMode()}isInInteractionMode(){return this.interactionMode}setCallbacks(e){e.onEnter&&(this.onEnterCallback=e.onEnter),e.onExit&&(this.onExitCallback=e.onExit),e.onReset&&(this.onResetCallback=e.onReset)}static createQualityPreset(e){let t={"ultra-low":{maxBounceCount:1,numRaysPerPixel:1,useAdaptiveSampling:!1,useEnvMapIS:!1,pixelRatio:.125,enableAccumulation:!1},low:{maxBounceCount:1,numRaysPerPixel:1,useAdaptiveSampling:!1,useEnvMapIS:!1,pixelRatio:.25,enableAccumulation:!1},medium:{maxBounceCount:2,numRaysPerPixel:1,useAdaptiveSampling:!1,useEnvMapIS:!0,pixelRatio:.5,enableAccumulation:!1},high:{maxBounceCount:3,numRaysPerPixel:1,useAdaptiveSampling:!0,useEnvMapIS:!0,pixelRatio:.75,enableAccumulation:!0}};return t[e]||t.low}dispose(){this.interactionTimeout&&=(clearTimeout(this.interactionTimeout),null),this.interactionMode&&this.forceExitInteractionMode(),this.onEnterCallback=null,this.onExitCallback=null,this.onResetCallback=null}},z={RENDER_COMPLETE:`engine:renderComplete`,RENDER_RESET:`engine:renderReset`,FRAME:`engine:frame`,DENOISING_START:`engine:denoisingStart`,DENOISING_END:`engine:denoisingEnd`,UPSCALING_START:`engine:upscalingStart`,UPSCALING_PROGRESS:`engine:upscalingProgress`,UPSCALING_END:`engine:upscalingEnd`,LOADING_UPDATE:`engine:loadingUpdate`,LOADING_RESET:`engine:loadingReset`,STATS_UPDATE:`engine:statsUpdate`,OBJECT_SELECTED:`engine:objectSelected`,OBJECT_DESELECTED:`engine:objectDeselected`,OBJECT_DOUBLE_CLICKED:`engine:objectDoubleClicked`,SELECT_MODE_CHANGED:`engine:selectModeChanged`,OBJECT_TRANSFORM_START:`engine:objectTransformStart`,OBJECT_TRANSFORM_END:`engine:objectTransformEnd`,TRANSFORM_MODE_CHANGED:`engine:transformModeChanged`,AUTO_FOCUS_UPDATED:`engine:autoFocusUpdated`,AUTO_EXPOSURE_UPDATED:`engine:autoExposureUpdated`,AF_POINT_PLACED:`engine:afPointPlaced`,SETTING_CHANGED:`engine:settingChanged`,ANIMATION_STARTED:`engine:animationStarted`,ANIMATION_PAUSED:`engine:animationPaused`,ANIMATION_STOPPED:`engine:animationStopped`,ANIMATION_FINISHED:`engine:animationFinished`,VIDEO_RENDER_PROGRESS:`engine:videoRenderProgress`,VIDEO_RENDER_COMPLETE:`engine:videoRenderComplete`,DISPOSE:`engine:dispose`},le=null;function ue(e){le=e}var de=()=>le?.({type:z.LOADING_RESET}),B=e=>{le?.({type:z.LOADING_UPDATE,...e})},fe=e=>{le?.({type:z.STATS_UPDATE,...e})};function pe(e){let t=e.frameCount||0;if(e.renderMode?.value===1&&t>0){let n=e.tileManager?.totalTilesCache||1;return 1+Math.floor((t-1)/n)}return t}function me(e){if(Array.isArray(e))e.forEach(e=>{e.userData&&e.userData.isFallback||(he(e),e.dispose())});else{if(e.userData&&e.userData.isFallback)return;he(e),e.dispose()}}function he(e){e&&[`alphaMap`,`aoMap`,`bumpMap`,`clearcoatMap`,`clearcoatNormalMap`,`clearcoatRoughnessMap`,`displacementMap`,`emissiveMap`,`envMap`,`gradientMap`,`lightMap`,`map`,`metalnessMap`,`normalMap`,`roughnessMap`,`specularMap`,`sheenColorMap`,`sheenRoughnessMap`,`specularIntensityMap`,`specularColorMap`,`thicknessMap`,`transmissionMap`].forEach(t=>{e[t]&&(e[t].dispose(),e[t]=null)})}function ge({material:e,geometry:t,children:n}){if(e&&me(e),t&&t.dispose(),n.length>0)for(let e of n)ge(e)}function _e(e,t=[]){if(e&&!(t.includes(e.name)||e.isScene)){if(e.isMaterial){me(e);return}for(;e.children.length>0;)for(let t of e.children)_e(t);ge(e),e.removeFromParent(),e.clear()}}function ve(e,t,n){return e===1?n*t:t}function ye(e,t,n,r=!1){return r?1:t===0?1/(e+1):e===0?1:1/(1+Math.floor((e-1)/n)+1)}function be(){let e=0,t=0,n=0,r=0;return{start(){e=performance.now()},end(){t=performance.now();let i=t-e;return r+=i,n++,i},getAverageFrameTime(){return n>0?r/n:0},getFPS(){let e=this.getAverageFrameTime();return e>0?1e3/e:0},reset(){n=0,r=0}}}function xe(e,n){let i=new t.StorageTexture(e,n);return i.type=r.FloatType,i.format=r.RGBAFormat,i.minFilter=r.LinearFilter,i.magFilter=r.LinearFilter,i}var Se=class{constructor(e,t){this.writeColor=null,this.writeNormalDepth=null,this.writeAlbedo=null,this.readTarget=null,this.currentTarget=0,this.renderWidth=0,this.renderHeight=0,e>0&&t>0&&this.create(e,t)}create(e,n){this.dispose(),this.renderWidth=e,this.renderHeight=n,this.writeColor=xe(e,n),this.writeNormalDepth=xe(e,n),this.writeAlbedo=xe(e,n),this.readTarget=new t.RenderTarget(e,n,{type:r.FloatType,format:r.RGBAFormat,minFilter:r.NearestFilter,magFilter:r.NearestFilter,depthBuffer:!1,stencilBuffer:!1,count:3}),this.readTarget.textures[0].name=`gColor`,this.readTarget.textures[1].name=`gNormalDepth`,this.readTarget.textures[2].name=`gAlbedo`,console.log(`StorageTexturePool: Created ${e}x${n} (3 write StorageTextures + 1 MRT RenderTarget)`)}ensureSize(e,t){return this.renderWidth!==e||this.renderHeight!==t||!this.writeColor?(this.create(e,t),!0):!1}getReadTextures(){return{color:this.readTarget.textures[0],normalDepth:this.readTarget.textures[1],albedo:this.readTarget.textures[2]}}getWriteTextures(){return{color:this.writeColor,normalDepth:this.writeNormalDepth,albedo:this.writeAlbedo}}copyToReadTargets(e){e.copyTextureToTexture(this.writeColor,this.readTarget.textures[0]),e.copyTextureToTexture(this.writeNormalDepth,this.readTarget.textures[1]),e.copyTextureToTexture(this.writeAlbedo,this.readTarget.textures[2])}clear(e){if(!this.readTarget||!e)return;let t=e.getRenderTarget();e.setRenderTarget(this.readTarget),e.clear(!0,!1,!1),e.setRenderTarget(t)}swap(){this.currentTarget=1-this.currentTarget}setSize(e,t){if(this.renderWidth=e,this.renderHeight=t,this.writeColor?.setSize(e,t),this.writeNormalDepth?.setSize(e,t),this.writeAlbedo?.setSize(e,t),this.readTarget){this.readTarget.setSize(e,t);for(let e of this.readTarget.textures)e.needsUpdate=!0}}dispose(){this.writeColor?.dispose(),this.writeNormalDepth?.dispose(),this.writeAlbedo?.dispose(),this.readTarget?.dispose(),this.writeColor=null,this.writeNormalDepth=null,this.writeAlbedo=null,this.readTarget=null}},V={resolution:512,canvasWidth:512,canvasHeight:512,toneMapping:4,exposure:1,saturation:1.2,enableEnvironment:!0,showBackground:!0,transparentBackground:!1,useImportanceSampledEnvironment:!0,environmentIntensity:1,backgroundIntensity:1,environmentRotation:270,globalIlluminationIntensity:1,environmentMode:`hdri`,gradientZenithColor:`#0077BE`,gradientHorizonColor:`#87CEEB`,gradientGroundColor:`#654321`,solidSkyColor:`#87CEEB`,skySunAzimuth:90,skySunElevation:20,skySunIntensity:15,skyRayleighDensity:.9,skyTurbidity:.8,skyMieAnisotropy:.76,skyPreset:`clearMorning`,enableDOF:!1,fov:55,focusDistance:.8,aperture:5.6,focalLength:50,apertureScale:1,anamorphicRatio:1,autoFocusMode:`auto`,afScreenPoint:{x:.5,y:.5},afSmoothingFactor:.15,enablePathTracer:!0,enableAccumulation:!0,pauseRendering:!1,maxSamples:60,bounces:3,samplesPerPixel:1,transmissiveBounces:5,samplingTechnique:3,enableEmissiveTriangleSampling:!1,emissiveBoost:1,adaptiveSampling:!1,adaptiveSamplingMin:1,adaptiveSamplingMax:8,adaptiveSamplingVarianceThreshold:.1,temporalVarianceWeight:.6,enableEarlyTermination:!0,earlyTerminationThreshold:.002,showAdaptiveSamplingHelper:!1,performanceModeAdaptive:`medium`,fireflyThreshold:3,renderLimitMode:`frames`,renderTimeLimit:30,renderMode:0,enableAlphaShadows:!1,tiles:3,tilesHelper:!1,showLightHelper:!1,directionalLightIntensity:0,directionalLightColor:`#ffffff`,directionalLightPosition:[1,1,1],directionalLightAngle:0,filterStrength:.75,strengthDecaySpeed:.05,edgeThreshold:1,enableOIDN:!1,oidnQuality:`fast`,debugGbufferMaps:!1,enableUpscaler:!1,upscalerScale:2,upscalerQuality:`fast`,upscalerHdr:!0,debugMode:0,debugThreshold:100,debugModel:0,enableBloom:!1,bloomStrength:.2,bloomRadius:.15,bloomThreshold:.85,interactionModeEnabled:!0,debugVisScale:100,denoiserStrategy:`none`,enableASVGF:!1,asvgfTemporalAlpha:.1,asvgfAtrousIterations:8,asvgfPhiColor:10,asvgfPhiNormal:128,asvgfPhiDepth:1,asvgfVarianceBoost:1,asvgfMaxAccumFrames:32,asvgfDebugMode:0,asvgfQualityPreset:`medium`,showAsvgfHeatmap:!1,ssrcTemporalAlpha:.1,ssrcSpatialRadius:4,ssrcSpatialWeight:.4,autoExposure:!1,autoExposureKeyValue:.18,autoExposureMinExposure:.1,autoExposureMaxExposure:20,autoExposureAdaptSpeedBright:3,autoExposureAdaptSpeedDark:.5},Ce={low:{temporalAlpha:.3,atrousIterations:1,phiColor:30,phiNormal:64,phiDepth:2,phiLuminance:6,maxAccumFrames:8,varianceBoost:.5},medium:{temporalAlpha:.1,atrousIterations:3,phiColor:20,phiNormal:128,phiDepth:1,phiLuminance:2,maxAccumFrames:32,varianceBoost:1},high:{temporalAlpha:.05,atrousIterations:8,phiColor:5,phiNormal:256,phiDepth:.5,phiLuminance:2,maxAccumFrames:64,varianceBoost:1.5}},we={fov:{min:10,max:90,default:V.fov},focusDistance:{min:.3,max:100,default:V.focusDistance},aperture:{options:[1.4,2,2.8,4,5.6,8,11,16],default:V.aperture},focalLength:{min:0,max:200,default:V.focalLength}},Te={clearMorning:{name:`Clear Morning`,sunAzimuth:90,sunElevation:20,sunIntensity:15,rayleighDensity:.9,turbidity:.8},clearNoon:{name:`Clear Noon`,sunAzimuth:0,sunElevation:75,sunIntensity:20,rayleighDensity:1,turbidity:.3},overcast:{name:`Overcast`,sunAzimuth:0,sunElevation:45,sunIntensity:6,rayleighDensity:.6,turbidity:4},goldenHour:{name:`Golden Hour`,sunAzimuth:270,sunElevation:10,sunIntensity:19,rayleighDensity:.8,turbidity:1.2},sunset:{name:`Sunset`,sunAzimuth:270,sunElevation:2,sunIntensity:18,rayleighDensity:.7,turbidity:2},dusk:{name:`Dusk`,sunAzimuth:270,sunElevation:-8,sunIntensity:8,rayleighDensity:.5,turbidity:1.5}},Ee={portrait:{name:`Portrait`,description:`Shallow depth of field, background blur`,fov:45,focusDistance:1.5,aperture:1.4,focalLength:135,apertureScale:1.5},landscape:{name:`Landscape`,description:`Maximum depth of field, everything in focus`,fov:65,focusDistance:10,aperture:16,focalLength:24,apertureScale:.5},macro:{name:`Macro`,description:`Extreme close-up with thin focus plane`,fov:40,focusDistance:.3,aperture:2,focalLength:100,apertureScale:2},product:{name:`Product`,description:`Sharp detail with subtle background separation`,fov:50,focusDistance:.8,aperture:2.8,focalLength:85,apertureScale:1},architectural:{name:`Architectural`,description:`Wide view with deep focus`,fov:75,focusDistance:5,aperture:11,focalLength:16,apertureScale:.5},cinematic:{name:`Cinematic`,description:`Dramatic depth separation with anamorphic bokeh`,fov:35,focusDistance:3,aperture:1.4,focalLength:200,apertureScale:1.8,anamorphicRatio:1.5}},De={MANUAL:`manual`,AUTO:`auto`},Oe={SMOOTHING_FACTOR:.15,RESET_THRESHOLD:.05,FALLBACK_DISTANCE:10,SNAP_THRESHOLD:.5},H={FLOATS_PER_TRIANGLE:32,POSITION_A_OFFSET:0,POSITION_B_OFFSET:4,POSITION_C_OFFSET:8,NORMAL_A_OFFSET:12,NORMAL_B_OFFSET:16,NORMAL_C_OFFSET:20,UV_AB_OFFSET:24,UV_C_MAT_OFFSET:28},U={SLOTS_PER_MATERIAL:27,FLOATS_PER_MATERIAL:108,IOR:0,TRANSMISSION:1,THICKNESS:2,EMISSIVE_INTENSITY:3,ATTENUATION_COLOR:4,ATTENUATION_DISTANCE:7,OPACITY:8,SIDE:9,TRANSPARENT:10,ALPHA_TEST:11,ALPHA_MODE:12,DEPTH_WRITE:13,NORMAL_SCALE:14,COLOR:16,METALNESS:19,EMISSIVE:20,ROUGHNESS:23,ALBEDO_MAP_INDEX:24,NORMAL_MAP_INDEX:25,ROUGHNESS_MAP_INDEX:26,METALNESS_MAP_INDEX:27,EMISSIVE_MAP_INDEX:28,BUMP_MAP_INDEX:29,CLEARCOAT:30,CLEARCOAT_ROUGHNESS:31,DISPERSION:32,VISIBLE:33,SHEEN:34,SHEEN_ROUGHNESS:35,SHEEN_COLOR:36,SPECULAR_INTENSITY:40,SPECULAR_COLOR:41,IRIDESCENCE:44,IRIDESCENCE_IOR:45,IRIDESCENCE_THICKNESS_RANGE:46,BUMP_SCALE:48,DISPLACEMENT_SCALE:49,DISPLACEMENT_MAP_INDEX:50,ALBEDO_TRANSFORM:52,NORMAL_TRANSFORM:60,ROUGHNESS_TRANSFORM:68,METALNESS_TRANSFORM:76,EMISSIVE_TRANSFORM:84,BUMP_TRANSFORM:92,DISPLACEMENT_TRANSFORM:100,SLOT:{IOR_TRANSMISSION:0,ATTENUATION:1,OPACITY_ALPHA:2,ALPHA_MODE:3,COLOR_METALNESS:4,EMISSIVE_ROUGHNESS:5,MAP_INDICES_A:6,MAP_INDICES_B:7,DISPERSION_SHEEN:8,SHEEN_COLOR:9,SPECULAR:10,IRIDESCENCE:11,BUMP_DISPLACEMENT:12,ALBEDO_TRANSFORM_A:13,ALBEDO_TRANSFORM_B:14,NORMAL_TRANSFORM_A:15,NORMAL_TRANSFORM_B:16,ROUGHNESS_TRANSFORM_A:17,ROUGHNESS_TRANSFORM_B:18,METALNESS_TRANSFORM_A:19,METALNESS_TRANSFORM_B:20,EMISSIVE_TRANSFORM_A:21,EMISSIVE_TRANSFORM_B:22,BUMP_TRANSFORM_A:23,BUMP_TRANSFORM_B:24,DISPLACEMENT_TRANSFORM_A:25,DISPLACEMENT_TRANSFORM_B:26}},ke={TRIANGLE_LEAF:-1,BLAS_POINTER_LEAF:-2},Ae={PIXELS_PER_MATERIAL:27,RGBA_COMPONENTS:4,VEC4_PER_TRIANGLE:8,VEC4_PER_BVH_NODE:4,FLOATS_PER_VEC4:4,MIN_TEXTURE_WIDTH:4,MAX_CONCURRENT_WORKERS:Math.min(typeof navigator<`u`&&navigator.hardwareConcurrency||4,6),BUFFER_POOL_SIZE:20,CANVAS_POOL_SIZE:12,CACHE_SIZE_LIMIT:50,MAX_TEXTURE_SIZE:8192},W=[0,0,1,1,0,0,0,1],je={maxSamples:30,bounces:20,transmissiveBounces:8,samplesPerPixel:1,renderMode:1,enableAlphaShadows:!0,tiles:3,tilesHelper:!0,enableOIDN:!0,oidnQuality:`balance`,interactionModeEnabled:!1},Me={maxSamples:V.maxSamples,bounces:V.bounces,samplesPerPixel:V.samplesPerPixel,renderMode:V.renderMode,enableAlphaShadows:V.enableAlphaShadows,transmissiveBounces:V.transmissiveBounces,tiles:V.tiles,tilesHelper:V.tilesHelper,enableOIDN:!1,oidnQuality:`fast`,interactionModeEnabled:!0},Ne={MAX_BUFFER_MEMORY:1024*1024*1024,MAX_TEXTURE_MEMORY:2048*1024*1024,CLEANUP_THRESHOLD:.8,CHUNK_SIZE_THRESHOLD:64*1024*1024,STREAM_BATCH_SIZE:4},Pe={cameraViewMatrix:`ptCameraViewMatrix`,cameraProjectionMatrix:`ptCameraProjectionMatrix`},Fe=class{constructor(e=1920,t=1080){this._uniforms=new Map,this._booleans=new Set,this._lightBuffers={},this._initUniforms(e,t),this._nameAll()}get(e){return this._uniforms.get(e)}set(e,t){let n=this._uniforms.get(e);if(!n){console.warn(`UniformManager: Unknown uniform "${e}"`);return}this._booleans.has(e)?n.value=+!!t:typeof t==`object`&&t&&typeof n.value?.copy==`function`?n.value.copy(t):n.value=t}has(e){return this._uniforms.has(e)}keys(){return this._uniforms.keys()}getLightBufferNodes(){return this._lightBuffers}updateMany(e){let t=!1;for(let[n,r]of Object.entries(e)){let e=this._uniforms.get(n);e&&e.value!==r&&(e.value=r,t=!0)}return t}_initUniforms(e,t){let i=(e,t,r)=>{let i=(0,n.uniform)(t,r);return this._uniforms.set(e,i),i},a=(e,t)=>(this._booleans.add(e),i(e,+!!t,`int`));i(`frame`,0,`uint`),i(`maxBounces`,V.bounces,`int`),i(`samplesPerPixel`,V.samplesPerPixel,`int`),i(`maxSamples`,V.maxSamples,`int`),i(`transmissiveBounces`,V.transmissiveBounces,`int`),i(`visMode`,V.debugMode,`int`),i(`debugVisScale`,V.debugVisScale,`float`),a(`enableAccumulation`,!0),i(`accumulationAlpha`,0,`float`),a(`cameraIsMoving`,!1),a(`hasPreviousAccumulated`,!1),i(`environmentIntensity`,V.environmentIntensity,`float`),i(`backgroundIntensity`,V.backgroundIntensity,`float`),a(`showBackground`,V.showBackground),a(`transparentBackground`,V.transparentBackground),a(`enableEnvironment`,V.enableEnvironment),i(`environmentMatrix`,new r.Matrix4,`mat4`),a(`useEnvMapIS`,V.useImportanceSampledEnvironment),i(`envTotalSum`,0,`float`),i(`envCompensationDelta`,0,`float`),i(`envResolution`,new r.Vector2(1,1),`vec2`),i(`sunDirection`,new r.Vector3(0,1,0),`vec3`),i(`sunAngularSize`,.0087,`float`),a(`hasSun`,!1),i(`globalIlluminationIntensity`,V.globalIlluminationIntensity,`float`),i(`exposure`,V.exposure,`float`),i(`numDirectionalLights`,0,`int`),i(`numAreaLights`,0,`int`),i(`numPointLights`,0,`int`),i(`numSpotLights`,0,`int`),this._lightBuffers={directional:(0,n.uniformArray)(new Float32Array(128),`float`),area:(0,n.uniformArray)(new Float32Array(208),`float`),point:(0,n.uniformArray)(new Float32Array(144),`float`),spot:(0,n.uniformArray)(new Float32Array(224),`float`)},i(`cameraWorldMatrix`,new r.Matrix4,`mat4`),i(`cameraProjectionMatrixInverse`,new r.Matrix4,`mat4`),i(`cameraViewMatrix`,new r.Matrix4,`mat4`),i(`cameraProjectionMatrix`,new r.Matrix4,`mat4`),a(`enableDOF`,V.enableDOF),i(`focusDistance`,V.focusDistance,`float`),i(`focalLength`,V.focalLength,`float`),i(`aperture`,V.aperture,`float`),i(`apertureScale`,1,`float`),i(`anamorphicRatio`,V.anamorphicRatio??1,`float`),i(`sceneScale`,1,`float`),this._uniforms.set(`samplingTechnique`,x),x.value=V.samplingTechnique,a(`useAdaptiveSampling`,V.adaptiveSampling),i(`adaptiveSamplingMin`,V.adaptiveSamplingMin??1,`int`),i(`adaptiveSamplingMax`,V.adaptiveSamplingMax,`int`),i(`fireflyThreshold`,V.fireflyThreshold,`float`),a(`enableEmissiveTriangleSampling`,V.enableEmissiveTriangleSampling),i(`emissiveBoost`,V.emissiveBoost,`float`),i(`emissiveTriangleCount`,0,`int`),i(`emissiveTotalPower`,0,`float`),i(`lightBVHNodeCount`,0,`int`),i(`emissiveVec4Offset`,0,`int`),i(`renderMode`,V.renderMode,`int`),a(`enableAlphaShadows`,V.enableAlphaShadows),i(`resolution`,new r.Vector2(e,t),`vec2`),i(`totalTriangleCount`,0,`int`)}_nameAll(){for(let[e,t]of this._uniforms)t.name=Pe[e]||e}dispose(){this._disposed||(this._disposed=!0,this._uniforms.clear(),this._booleans.clear(),this._lightBuffers={})}},Ie=U.SLOTS_PER_MATERIAL,G=H.UV_C_MAT_OFFSET+2,K=H.NORMAL_C_OFFSET+3,Le=H.NORMAL_A_OFFSET+3,Re=new Set([`transmission`,`transparent`,`opacity`,`alphaMode`]),ze=class{constructor(e){this.sdfs=e,this.materialStorageAttr=null,this.materialStorageNode=null,this.materialCount=0,this.albedoMaps=null,this.emissiveMaps=null,this.normalMaps=null,this.bumpMaps=null,this.roughnessMaps=null,this.metalnessMaps=null,this.displacementMaps=null,this.compiledFeatures=null,this.callbacks={}}setMaterialData(e){if(!e)return;let r=e.length/4;this.materialStorageNode?(this.materialStorageAttr=new t.StorageInstancedBufferAttribute(e,4),this.materialStorageNode.value=this.materialStorageAttr,this.materialStorageNode.bufferCount=r):(this.materialStorageAttr=new t.StorageInstancedBufferAttribute(e,4),this.materialStorageNode=(0,n.storage)(this.materialStorageAttr,`vec4`,r).toReadOnly()),this.materialCount=Math.floor(r/Ie),console.log(`MaterialDataManager: ${this.materialCount} materials (storage buffer)`)}getStorageAttr(){return this.materialStorageAttr}getStorageNode(){return this.materialStorageNode}setMaterialTextures(e){e.albedoMaps&&(this.albedoMaps=e.albedoMaps),e.emissiveMaps&&(this.emissiveMaps=e.emissiveMaps),e.normalMaps&&(this.normalMaps=e.normalMaps),e.bumpMaps&&(this.bumpMaps=e.bumpMaps),e.roughnessMaps&&(this.roughnessMaps=e.roughnessMaps),e.metalnessMaps&&(this.metalnessMaps=e.metalnessMaps),e.displacementMaps&&(this.displacementMaps=e.displacementMaps)}loadTexturesFromSdfs(){this.albedoMaps=this.sdfs.albedoTextures,this.emissiveMaps=this.sdfs.emissiveTextures,this.normalMaps=this.sdfs.normalTextures,this.bumpMaps=this.sdfs.bumpTextures,this.roughnessMaps=this.sdfs.roughnessTextures,this.metalnessMaps=this.sdfs.metalnessTextures,this.displacementMaps=this.sdfs.displacementTextures}getTextureArrays(){return{albedoMaps:this.albedoMaps,emissiveMaps:this.emissiveMaps,normalMaps:this.normalMaps,bumpMaps:this.bumpMaps,roughnessMaps:this.roughnessMaps,metalnessMaps:this.metalnessMaps,displacementMaps:this.displacementMaps}}updateMaterialProperty(e,t,n){if(!this.materialStorageAttr){console.warn(`Material storage buffer not available`);return}let r=this.materialStorageAttr.array,i=e*U.FLOATS_PER_MATERIAL;switch(t){case`color`:n.r===void 0?Array.isArray(n)&&(r[i+U.COLOR]=n[0],r[i+U.COLOR+1]=n[1],r[i+U.COLOR+2]=n[2]):(r[i+U.COLOR]=n.r,r[i+U.COLOR+1]=n.g,r[i+U.COLOR+2]=n.b);break;case`metalness`:r[i+U.METALNESS]=n;break;case`emissive`:n.r===void 0?Array.isArray(n)&&(r[i+U.EMISSIVE]=n[0],r[i+U.EMISSIVE+1]=n[1],r[i+U.EMISSIVE+2]=n[2]):(r[i+U.EMISSIVE]=n.r,r[i+U.EMISSIVE+1]=n.g,r[i+U.EMISSIVE+2]=n.b);break;case`roughness`:r[i+U.ROUGHNESS]=n;break;case`ior`:r[i+U.IOR]=n;break;case`transmission`:r[i+U.TRANSMISSION]=n;break;case`thickness`:r[i+U.THICKNESS]=n;break;case`emissiveIntensity`:r[i+U.EMISSIVE_INTENSITY]=n;break;case`attenuationColor`:n.r===void 0?Array.isArray(n)&&(r[i+U.ATTENUATION_COLOR]=n[0],r[i+U.ATTENUATION_COLOR+1]=n[1],r[i+U.ATTENUATION_COLOR+2]=n[2]):(r[i+U.ATTENUATION_COLOR]=n.r,r[i+U.ATTENUATION_COLOR+1]=n.g,r[i+U.ATTENUATION_COLOR+2]=n.b);break;case`attenuationDistance`:r[i+U.ATTENUATION_DISTANCE]=n;break;case`dispersion`:r[i+U.DISPERSION]=n;break;case`sheen`:r[i+U.SHEEN]=n;break;case`sheenRoughness`:r[i+U.SHEEN_ROUGHNESS]=n;break;case`sheenColor`:n.r===void 0?Array.isArray(n)&&(r[i+U.SHEEN_COLOR]=n[0],r[i+U.SHEEN_COLOR+1]=n[1],r[i+U.SHEEN_COLOR+2]=n[2]):(r[i+U.SHEEN_COLOR]=n.r,r[i+U.SHEEN_COLOR+1]=n.g,r[i+U.SHEEN_COLOR+2]=n.b);break;case`specularIntensity`:r[i+U.SPECULAR_INTENSITY]=n;break;case`specularColor`:n.r===void 0?Array.isArray(n)&&(r[i+U.SPECULAR_COLOR]=n[0],r[i+U.SPECULAR_COLOR+1]=n[1],r[i+U.SPECULAR_COLOR+2]=n[2]):(r[i+U.SPECULAR_COLOR]=n.r,r[i+U.SPECULAR_COLOR+1]=n.g,r[i+U.SPECULAR_COLOR+2]=n.b);break;case`iridescence`:r[i+U.IRIDESCENCE]=n;break;case`iridescenceIOR`:r[i+U.IRIDESCENCE_IOR]=n;break;case`iridescenceThicknessRange`:Array.isArray(n)&&(r[i+U.IRIDESCENCE_THICKNESS_RANGE]=n[0],r[i+U.IRIDESCENCE_THICKNESS_RANGE+1]=n[1]);break;case`clearcoat`:r[i+U.CLEARCOAT]=n;break;case`clearcoatRoughness`:r[i+U.CLEARCOAT_ROUGHNESS]=n;break;case`opacity`:r[i+U.OPACITY]=n;break;case`side`:r[i+U.SIDE]=n,this._patchTriangleSideForMaterial(e,n);break;case`transparent`:r[i+U.TRANSPARENT]=n;break;case`alphaTest`:r[i+U.ALPHA_TEST]=n;break;case`alphaMode`:r[i+U.ALPHA_MODE]=n;break;case`depthWrite`:r[i+U.DEPTH_WRITE]=n;break;case`normalScale`:n.x===void 0?typeof n==`number`&&(r[i+U.NORMAL_SCALE]=n,r[i+U.NORMAL_SCALE+1]=n):(r[i+U.NORMAL_SCALE]=n.x,r[i+U.NORMAL_SCALE+1]=n.y);break;case`bumpScale`:r[i+U.BUMP_SCALE]=n;break;case`displacementScale`:r[i+U.DISPLACEMENT_SCALE]=n;break;default:console.warn(`Unknown material property: ${t}`);return}this.materialStorageAttr.needsUpdate=!0,Re.has(t)&&this._recomputeOpaqueBlockerForMaterial(e),[`transmission`,`clearcoat`,`sheen`,`iridescence`,`dispersion`,`transparent`,`opacity`,`alphaTest`].includes(t)&&this.rescanMaterialFeatures()&&this._notifyFeaturesChanged(),this._notifyReset()}updateMaterialDataFromObject(e,t){if(!this.materialStorageAttr){console.warn(`Material storage buffer not available`);return}let n=this.materialStorageAttr.array,r=e*U.FLOATS_PER_MATERIAL;t.color&&(n[r+U.COLOR]=t.color.r??t.color[0]??1,n[r+U.COLOR+1]=t.color.g??t.color[1]??1,n[r+U.COLOR+2]=t.color.b??t.color[2]??1),n[r+U.METALNESS]=t.metalness??0,t.emissive&&(n[r+U.EMISSIVE]=t.emissive.r??t.emissive[0]??0,n[r+U.EMISSIVE+1]=t.emissive.g??t.emissive[1]??0,n[r+U.EMISSIVE+2]=t.emissive.b??t.emissive[2]??0),n[r+U.ROUGHNESS]=t.roughness??1,n[r+U.IOR]=t.ior??1.5,n[r+U.TRANSMISSION]=t.transmission??0,n[r+U.THICKNESS]=t.thickness??.1,n[r+U.EMISSIVE_INTENSITY]=t.emissiveIntensity??1,t.attenuationColor&&(n[r+U.ATTENUATION_COLOR]=t.attenuationColor.r??t.attenuationColor[0]??1,n[r+U.ATTENUATION_COLOR+1]=t.attenuationColor.g??t.attenuationColor[1]??1,n[r+U.ATTENUATION_COLOR+2]=t.attenuationColor.b??t.attenuationColor[2]??1),n[r+U.ATTENUATION_DISTANCE]=t.attenuationDistance??1/0,n[r+U.DISPERSION]=t.dispersion??0,n[r+U.VISIBLE]=1,n[r+U.SHEEN]=t.sheen??0,n[r+U.SHEEN_ROUGHNESS]=t.sheenRoughness??1,t.sheenColor&&(n[r+U.SHEEN_COLOR]=t.sheenColor.r??t.sheenColor[0]??0,n[r+U.SHEEN_COLOR+1]=t.sheenColor.g??t.sheenColor[1]??0,n[r+U.SHEEN_COLOR+2]=t.sheenColor.b??t.sheenColor[2]??0),n[r+U.SPECULAR_INTENSITY]=t.specularIntensity??1,t.specularColor&&(n[r+U.SPECULAR_COLOR]=t.specularColor.r??t.specularColor[0]??1,n[r+U.SPECULAR_COLOR+1]=t.specularColor.g??t.specularColor[1]??1,n[r+U.SPECULAR_COLOR+2]=t.specularColor.b??t.specularColor[2]??1),n[r+U.IRIDESCENCE]=t.iridescence??0,n[r+U.IRIDESCENCE_IOR]=t.iridescenceIOR??1.3,t.iridescenceThicknessRange&&(n[r+U.IRIDESCENCE_THICKNESS_RANGE]=t.iridescenceThicknessRange[0]??100,n[r+U.IRIDESCENCE_THICKNESS_RANGE+1]=t.iridescenceThicknessRange[1]??400),n[r+U.ALBEDO_MAP_INDEX]=t.map??-1,n[r+U.NORMAL_MAP_INDEX]=t.normalMap??-1,n[r+U.ROUGHNESS_MAP_INDEX]=t.roughnessMap??-1,n[r+U.METALNESS_MAP_INDEX]=t.metalnessMap??-1,n[r+U.EMISSIVE_MAP_INDEX]=t.emissiveMap??-1,n[r+U.BUMP_MAP_INDEX]=t.bumpMap??-1,n[r+U.CLEARCOAT]=t.clearcoat??0,n[r+U.CLEARCOAT_ROUGHNESS]=t.clearcoatRoughness??0,n[r+U.OPACITY]=t.opacity??1,n[r+U.SIDE]=t.side??0,this._patchTriangleSideForMaterial(e,t.side??0),this._recomputeOpaqueBlockerForMaterial(e),n[r+U.TRANSPARENT]=t.transparent??0,n[r+U.ALPHA_TEST]=t.alphaTest??0,n[r+U.ALPHA_MODE]=t.alphaMode??0,n[r+U.DEPTH_WRITE]=t.depthWrite??1,n[r+U.NORMAL_SCALE]=t.normalScale?.x??(typeof t.normalScale==`number`?t.normalScale:1),n[r+U.NORMAL_SCALE+1]=t.normalScale?.y??(typeof t.normalScale==`number`?t.normalScale:1),n[r+U.BUMP_SCALE]=t.bumpScale??1,n[r+U.DISPLACEMENT_SCALE]=t.displacementScale??1,n[r+U.DISPLACEMENT_MAP_INDEX]=t.displacementMap??-1;let i=[1,0,0,0,1,0,0,0,1],a=[{key:`mapMatrix`,offset:U.ALBEDO_TRANSFORM},{key:`normalMapMatrices`,offset:U.NORMAL_TRANSFORM},{key:`roughnessMapMatrices`,offset:U.ROUGHNESS_TRANSFORM},{key:`metalnessMapMatrices`,offset:U.METALNESS_TRANSFORM},{key:`emissiveMapMatrices`,offset:U.EMISSIVE_TRANSFORM},{key:`bumpMapMatrices`,offset:U.BUMP_TRANSFORM},{key:`displacementMapMatrices`,offset:U.DISPLACEMENT_TRANSFORM}];for(let{key:e,offset:o}of a){let a=t[e]??i;for(let e=0;e<9;e++)r+o+e<n.length&&(n[r+o+e]=a[e])}this.materialStorageAttr.needsUpdate=!0,this.rescanMaterialFeatures()&&this._notifyFeaturesChanged(),this._notifyReset()}updateMaterial(e,t){let n=this.sdfs.geometryExtractor.createMaterialObject(t);this.updateMaterialDataFromObject(e,n)}updateTextureTransform(e,t,n){if(!this.materialStorageAttr){console.warn(`Material storage buffer not available`);return}let r=this.materialStorageAttr.array,i=e*U.FLOATS_PER_MATERIAL,a={map:U.ALBEDO_TRANSFORM,normalMap:U.NORMAL_TRANSFORM,roughnessMap:U.ROUGHNESS_TRANSFORM,metalnessMap:U.METALNESS_TRANSFORM,emissiveMap:U.EMISSIVE_TRANSFORM,bumpMap:U.BUMP_TRANSFORM,displacementMap:U.DISPLACEMENT_TRANSFORM}[t];if(a===void 0){console.warn(`Unknown texture name for transform update: ${t}`);return}for(let e=0;e<9;e++)i+a+e<r.length&&(r[i+a+e]=n[e]);this.materialStorageAttr.needsUpdate=!0,this._notifyReset()}rescanMaterialFeatures(){if(!this.materialStorageAttr?.array)return console.warn(`[MaterialDataManager] Material storage buffer not available for feature scanning`),!1;let e=this.materialStorageAttr.array,t=this.sdfs.materialCount||1,n={hasClearcoat:!1,hasTransmission:!1,hasDispersion:!1,hasIridescence:!1,hasSheen:!1,hasTransparency:!1,hasMultiLobeMaterials:!1,hasMRTOutputs:!0};for(let r=0;r<t;r++){let t=r*U.FLOATS_PER_MATERIAL,i=e[t+U.TRANSMISSION],a=e[t+U.DISPERSION],o=e[t+U.SHEEN],s=e[t+U.IRIDESCENCE],c=e[t+U.CLEARCOAT],l=e[t+U.OPACITY],u=e[t+U.TRANSPARENT],d=e[t+U.ALPHA_TEST];c>0&&(n.hasClearcoat=!0),i>0&&(n.hasTransmission=!0),a>0&&(n.hasDispersion=!0),s>0&&(n.hasIridescence=!0),o>0&&(n.hasSheen=!0),(u>0||l<1||d>0)&&(n.hasTransparency=!0),[c>0,i>0,s>0,o>0].filter(Boolean).length>=2&&(n.hasMultiLobeMaterials=!0)}let r=JSON.stringify(this.sdfs.sceneFeatures)!==JSON.stringify(n);return r&&(this.sdfs.sceneFeatures=n),r}injectMaterialFeatureDefines(){let e=this.sdfs.sceneFeatures;if(!e){console.warn(`[MaterialDataManager] No sceneFeatures detected, skipping define injection`);return}let t=JSON.stringify(e);(!this.compiledFeatures||this.compiledFeatures!==t)&&(console.log(`[MaterialDataManager] Material features:`,e),this.compiledFeatures=t)}_notifyReset(){this.callbacks.onReset&&this.callbacks.onReset()}_notifyFeaturesChanged(){this.injectMaterialFeatureDefines()}_recomputeOpaqueBlockerForMaterial(e){let t=this.materialStorageAttr?.array;if(!t)return;let n=e*U.FLOATS_PER_MATERIAL,r=t[n+U.ALPHA_MODE]|0,i=t[n+U.TRANSPARENT]|0,a=t[n+U.TRANSMISSION]||0,o=t[n+U.OPACITY]??1,s=+(r===0&&i===0&&a===0&&o>=1);this._patchTriangleFlagForMaterial(e,Le,s)}_patchTriangleFlagForMaterial(e,t,n){let r=this.callbacks.getTriangleData?.(),i=r?.array,a=r?.count|0;if(!i||a===0)return;let o=H.FLOATS_PER_TRIANGLE,s=0;for(let r=0;r<a;r++){let a=r*o;i[a+G]===e&&(i[a+t]=n,s++)}s>0&&this.callbacks.onTriangleDataChanged&&this.callbacks.onTriangleDataChanged()}_patchTriangleSideForMaterial(e,t){this._patchTriangleFlagForMaterial(e,K,t)}dispose(){this.materialStorageAttr=null,this.materialStorageNode=null,this.materialCount=0,this.albedoMaps=null,this.emissiveMaps=null,this.normalMaps=null,this.bumpMaps=null,this.roughnessMaps=null,this.metalnessMaps=null,this.displacementMaps=null,this.compiledFeatures=null}};async function q(e){let t=e instanceof URL?e.href:e,n=await fetch(t);if(!n.ok)throw Error(`Failed to fetch worker script: ${n.status}`);let r=new Blob([await n.text()],{type:`application/javascript`});return new Worker(URL.createObjectURL(r),{type:`module`})}var Be=``+(typeof document>`u`&&typeof location>`u`?require(`url`).pathToFileURL(__dirname+`/assets/CDFWorker-BFQUr3By.js`).href:new URL(`assets/CDFWorker-BFQUr3By.js`,typeof document>`u`?location.href:document.currentScript&&document.currentScript.tagName.toUpperCase()===`SCRIPT`&&document.currentScript.src||document.baseURI).href);function Ve(e,t,n=0,r=e.length){let i=n,a=n+r-1;for(;i<a;){let n=i+a>>1;e[n]<t?i=n+1:a=n}return i-n}function He(e,t,n){return .2126*e+.7152*t+.0722*n}function Ue(e){return e<=.04045?e/12.92:((e+.055)/1.055)**2.4}function We(e){let{width:t,height:n}=e.image,i=e.image.data,a=!1;if(!i){let r=new OffscreenCanvas(t,n).getContext(`2d`);r.drawImage(e.image,0,0,t,n),i=r.getImageData(0,0,t,n).data,a=!0}let o;if(e.type===r.FloatType&&i instanceof Float32Array)o=new Float32Array(i);else if(e.type===r.HalfFloatType){o=new Float32Array(i.length);for(let e=0,t=i.length;e<t;e++)o[e]=r.DataUtils.fromHalfFloat(i[e])}else{let e;e=i instanceof Int8Array||i instanceof Int16Array||i instanceof Int32Array?2**(8*i.BYTES_PER_ELEMENT-1)-1:2**(8*i.BYTES_PER_ELEMENT)-1,o=new Float32Array(i.length);for(let t=0,n=i.length;t<n;t++)o[t]=i[t]/e}if(!a&&e.colorSpace===r.SRGBColorSpace&&(a=!0),a)for(let e=0,t=o.length;e<t;e+=4)o[e]=Ue(o[e]),o[e+1]=Ue(o[e+1]),o[e+2]=Ue(o[e+2]);if(e.flipY){let e=new Float32Array(o.length);for(let r=0;r<n;r++){let i=n-r-1,a=r*t*4,s=i*t*4;e.set(o.subarray(a,a+t*4),s)}o=e}return{floatData:o,width:t,height:n}}var Ge=class e{constructor(){this.marginalData=new Float32Array([0,1]),this.conditionalData=new Float32Array([0,0,1,1]),this.totalSum=0,this.compensationDelta=0,this.width=0,this.height=0,this._worker=null}dispose(){this.marginalData=null,this.conditionalData=null,this._worker&&=(this._worker.terminate(),null)}updateFrom(t){let{floatData:n,width:r,height:i}=We(t),a=e.computeCDF(n,r,i);this.marginalData=a.marginalData,this.conditionalData=a.conditionalData,this.totalSum=a.totalSum,this.compensationDelta=a.compensationDelta,this.width=r,this.height=i}async updateFromAsync(e){let{floatData:t,width:n,height:r}=We(e);try{this._worker=new Worker(Be,{type:`module`})}catch(e){if(e.name!==`SecurityError`)throw e;this._worker=await q(Be)}try{let e=await new Promise((e,i)=>{this._worker.onmessage=t=>{t.data.error?i(Error(t.data.error)):e(t.data)},this._worker.onerror=i,this._worker.postMessage({floatData:t,width:n,height:r},[t.buffer])});this.marginalData=e.marginalData,this.conditionalData=e.conditionalData,this.totalSum=e.totalSum,this.compensationDelta=e.compensationDelta,this.width=e.width,this.height=e.height}finally{this._worker&&=(this._worker.terminate(),null)}}static computeCDF(e,t,n){let r=t*n,i=new Float32Array(r),a=0;for(let r=0;r<n;r++){let o=Math.sin(Math.PI*(r+.5)/n);for(let n=0;n<t;n++){let s=r*t+n,c=He(e[4*s],e[4*s+1],e[4*s+2])*o;i[s]=c,a+=c}}let o=a/r,s=0;for(let e=0;e<r;e++)i[e]=Math.max(0,i[e]-o),s+=i[e];let c=s>0,l=c?s:a,u=c?o:0;if(!c)for(let r=0;r<n;r++){let a=Math.sin(Math.PI*(r+.5)/n);for(let n=0;n<t;n++){let o=r*t+n;i[o]=He(e[4*o],e[4*o+1],e[4*o+2])*a}}let d=new Float32Array(r),f=new Float32Array(n),p=0;for(let e=0;e<n;e++){let n=0;for(let r=0;r<t;r++){let a=e*t+r;n+=i[a],d[a]=n}if(n!==0)for(let r=e*t,i=e*t+t;r<i;r++)d[r]/=n;p+=n,f[e]=p}if(p!==0)for(let e=0,t=f.length;e<t;e++)f[e]/=p;let m=new Float32Array(n),h=new Float32Array(r);for(let e=0;e<n;e++)m[e]=(Ve(f,(e+1)/n)+.5)/n;for(let e=0;e<n;e++)for(let n=0;n<t;n++){let r=e*t+n;h[r]=(Ve(d,(n+1)/t,e*t,t)+.5)/t}return{marginalData:m,conditionalData:h,totalSum:l,compensationDelta:u}}},Ke=Math.PI,qe=Math.PI*2,Je=Math.E,Ye=[5804542996261093e-21,13562911419845635e-21,30265902468824876e-21],Xe=[183999185144339.78,277980239196605.28,407904795438610.94],Ze=1.6110731556870734,Qe=1.5,$e=1e3,et=8400,tt=1250,nt=.9999566769464484,rt=.05968310365946075,it=.07957747154594767;function at(e){return $e*Math.max(0,1-Je**+(-(Ze-Math.acos(Math.max(-1,Math.min(1,e))))/Qe))}function ot(e){let t=.2*e*1e-17;return[.434*t*Xe[0],.434*t*Xe[1],.434*t*Xe[2]]}function st(e){return rt*(1+e**2)}function ct(e,t){let n=t*t;return it*((1-n)/(1-2*t*e+n)**1.5)}function lt(e,t){return e[0]*t[0]+e[1]*t[1]+e[2]*t[2]}function ut(e){let t=Math.sqrt(e[0]*e[0]+e[1]*e[1]+e[2]*e[2]);return t===0?[0,0,0]:[e[0]/t,e[1]/t,e[2]/t]}function dt(e,t,n,r,i,a,o,s){let c=(1-t)*Ke,l=(e-.5)*qe,u=Math.sin(c),d=ut([u*Math.sin(l),Math.cos(c),u*Math.cos(l)]),f=ut(n),p=at(f[1])*r,m=i-1*(1-(1-Math.max(0,Math.min(1,1-Math.exp(f[1]/45e4))))),h=[Ye[0]*m,Ye[1]*m,Ye[2]*m],g=ot(s),_=[g[0]*a,g[1]*a,g[2]*a],v=Math.acos(Math.max(0,d[1])),y=Math.cos(v)+.15*(93.885-180/Ke*v)**-1.253,b=et/y,x=tt/y,S=[Math.exp(-(h[0]*b+_[0]*x)),Math.exp(-(h[1]*b+_[1]*x)),Math.exp(-(h[2]*b+_[2]*x))],C=lt(d,f),w=st(C*.5+.5),T=[h[0]*w,h[1]*w,h[2]*w],E=ct(C,o),D=[_[0]*E,_[1]*E,_[2]*E],O=[T[0]+D[0],T[1]+D[1],T[2]+D[2]],k=[h[0]+_[0],h[1]+_[1],h[2]+_[2]],A=[(p*(O[0]/k[0])*(1-S[0]))**1.5,(p*(O[1]/k[1])*(1-S[1]))**1.5,(p*(O[2]/k[2])*(1-S[2]))**1.5],j=Math.max(0,Math.min(1,1-(1-f[1])**5)),M=[Math.sqrt(p*(O[0]/k[0])*S[0]),Math.sqrt(p*(O[1]/k[1])*S[1]),Math.sqrt(p*(O[2]/k[2])*S[2])],N=1-j;for(let e=0;e<3;e++){let t=1*(1-N)+M[e]*N;A[e]*=t}let P=[.1*S[0],.1*S[1],.1*S[2]],ee=ft(nt,nt+2e-5,C);for(let e=0;e<3;e++)P[e]+=p*19e3*S[e]*ee;let F=65504;return[Math.min((A[0]+P[0])*.04,F),Math.min((A[1]+P[1])*.04+3e-4,F),Math.min((A[2]+P[2])*.04+75e-5,F),1]}function ft(e,t,n){let r=Math.max(0,Math.min(1,(n-e)/(t-e)));return r*r*(3-2*r)}var pt=class{constructor(e=512,t=256){this.width=e,this.height=t,this.lastRenderTime=0,this._pixels=new Float32Array(e*t*4),this._texture=new r.DataTexture(this._pixels,e,t,r.RGBAFormat,r.FloatType),this._texture.mapping=r.EquirectangularReflectionMapping,this._texture.colorSpace=r.LinearSRGBColorSpace,this._texture.minFilter=r.LinearFilter,this._texture.magFilter=r.LinearFilter,this._texture.wrapS=r.RepeatWrapping,this._texture.wrapT=r.ClampToEdgeWrapping,this._texture.generateMipmaps=!1}render(e){let t=performance.now(),n=[e.sunDirection.x,e.sunDirection.y,e.sunDirection.z],r=e.sunIntensity||1,i=e.rayleighDensity||2,a=e.mieDensity||.005,o=e.mieAnisotropy||.8,s=e.turbidity||2,{width:c,height:l}=this,u=this._pixels;for(let e=0;e<l;e++){let t=(e+.5)/l;for(let l=0;l<c;l++){let d=dt((l+.5)/c,t,n,r,i,a,o,s),f=(e*c+l)*4;u[f]=d[0],u[f+1]=d[1],u[f+2]=d[2],u[f+3]=d[3]}}return this._texture.needsUpdate=!0,this.lastRenderTime=performance.now()-t,this._texture}setResolution(e,t){this.width===e&&this.height===t||(this.width=e,this.height=t,this._pixels=new Float32Array(e*t*4),this._texture.dispose(),this._texture=new r.DataTexture(this._pixels,e,t,r.RGBAFormat,r.FloatType),this._texture.mapping=r.EquirectangularReflectionMapping,this._texture.colorSpace=r.LinearSRGBColorSpace,this._texture.minFilter=r.LinearFilter,this._texture.magFilter=r.LinearFilter,this._texture.wrapS=r.RepeatWrapping,this._texture.wrapT=r.ClampToEdgeWrapping,this._texture.generateMipmaps=!1)}getLastRenderTime(){return this.lastRenderTime}dispose(){this._texture.dispose()}},mt=class{constructor(e=512,t=256){this.width=e,this.height=t,this.lastRenderTime=0,this._pixels=new Float32Array(e*t*4),this._texture=new r.DataTexture(this._pixels,e,t,r.RGBAFormat,r.FloatType),this._texture.mapping=r.EquirectangularReflectionMapping,this._texture.colorSpace=r.LinearSRGBColorSpace,this._texture.minFilter=r.LinearFilter,this._texture.magFilter=r.LinearFilter,this._texture.wrapS=r.RepeatWrapping,this._texture.wrapT=r.ClampToEdgeWrapping,this._texture.generateMipmaps=!1}renderGradient(e){let t=performance.now(),{width:n,height:r}=this,i=this._pixels,a=e.zenithColor.r,o=e.zenithColor.g,s=e.zenithColor.b,c=e.horizonColor.r,l=e.horizonColor.g,u=e.horizonColor.b,d=e.groundColor.r,f=e.groundColor.g,p=e.groundColor.b;for(let e=0;e<r;e++){let t=(e+.5)/r,m,h,g;if(t>.5){let e=(t-.5)*2;m=c+(a-c)*e,h=l+(o-l)*e,g=u+(s-u)*e}else{let e=t*2;m=d+(c-d)*e,h=f+(l-f)*e,g=p+(u-p)*e}for(let t=0;t<n;t++){let r=(e*n+t)*4;i[r]=m,i[r+1]=h,i[r+2]=g,i[r+3]=1}}return this._texture.needsUpdate=!0,this.lastRenderTime=performance.now()-t,this._texture}renderSolid(e){let t=performance.now(),{width:n,height:r}=this,i=this._pixels,a=e.color.r,o=e.color.g,s=e.color.b;for(let e=0;e<r;e++)for(let t=0;t<n;t++){let r=(e*n+t)*4;i[r]=a,i[r+1]=o,i[r+2]=s,i[r+3]=1}return this._texture.needsUpdate=!0,this.lastRenderTime=performance.now()-t,this._texture}setResolution(e,t){this.width===e&&this.height===t||(this.width=e,this.height=t,this._pixels=new Float32Array(e*t*4),this._texture.dispose(),this._texture=new r.DataTexture(this._pixels,e,t,r.RGBAFormat,r.FloatType),this._texture.mapping=r.EquirectangularReflectionMapping,this._texture.colorSpace=r.LinearSRGBColorSpace,this._texture.minFilter=r.LinearFilter,this._texture.magFilter=r.LinearFilter,this._texture.wrapS=r.RepeatWrapping,this._texture.wrapT=r.ClampToEdgeWrapping,this._texture.generateMipmaps=!1)}getLastRenderTime(){return this.lastRenderTime}dispose(){this._texture.dispose()}},ht=class{constructor(e,t){this.scene=e,this.uniforms=t,this.equirectHdrInfo=new Ge,this.proceduralSkyRenderer=null,this.simpleSkyRenderer=null,this._envPlaceholder=new r.DataTexture(new Float32Array([0,0,0,1]),1,1,r.RGBAFormat,r.FloatType),this._envPlaceholder.needsUpdate=!0,this.environmentTexture=this._envPlaceholder,this.envTexSize=new r.Vector2,this.envCDFStorageAttr=null,this.envCDFStorageNode=null,this._initCDFStorageBuffers(),this.environmentRotationMatrix=new r.Matrix4,this.cdfBuildTime=0,this.envParams={mode:`hdri`,gradientZenithColor:new r.Color(V.gradientZenithColor),gradientHorizonColor:new r.Color(V.gradientHorizonColor),gradientGroundColor:new r.Color(V.gradientGroundColor),solidSkyColor:new r.Color(V.solidSkyColor),skySunDirection:this._calculateInitialSunDirection(),skySunIntensity:V.skySunIntensity,skyRayleighDensity:V.skyRayleighDensity,skyTurbidity:V.skyTurbidity,skyMieAnisotropy:V.skyMieAnisotropy},this.callbacks={},this._previousHDRI=null}async setMode(e){let t=this.envParams.mode;this.envParams.mode=e,e!==`hdri`&&t===`hdri`&&(this._previousHDRI=this.environmentTexture),e===`gradient`?await this.generateGradientTexture():e===`color`?await this.generateSolidColorTexture():e===`procedural`?await this.generateProceduralSkyTexture():e===`hdri`&&this._previousHDRI&&(await this.setEnvironmentMap(this._previousHDRI),this._previousHDRI=null),this.markDirty(),this.callbacks.onAutoExposureReset?.(),this._notifyReset()}markDirty(){this.environmentTexture&&(this.environmentTexture.needsUpdate=!0)}get params(){return this.envParams}get texture(){return this.environmentTexture}generateGradient(){return this.generateGradientTexture()}generateSolid(){return this.generateSolidColorTexture()}generateProcedural(){return this.generateProceduralSkyTexture()}_initCDFStorageBuffers(){let e=new Float32Array([0,1,0,0,1,1]);this.envCDFStorageAttr=new t.StorageInstancedBufferAttribute(e,1),this.envCDFStorageNode=(0,n.storage)(this.envCDFStorageAttr,`float`,e.length).toReadOnly()}_updateCDFStorageBuffers(){let e=this.equirectHdrInfo.marginalData,n=this.equirectHdrInfo.conditionalData;if(!e||!n)return;let r=new Float32Array(e.length+n.length);r.set(e,0),r.set(n,e.length),this.envCDFStorageAttr=new t.StorageInstancedBufferAttribute(r,1),this.envCDFStorageNode.value=this.envCDFStorageAttr,this.envCDFStorageNode.bufferCount=r.length}getCDFStorageNodes(){return{cdfNode:this.envCDFStorageNode}}setEnvironmentTexture(e){e&&(this.environmentTexture=e,this.envTexSize.set(e.image.width,e.image.height),console.log(`EnvironmentManager: Environment map ${e.image.width}x${e.image.height}`))}getEnvironmentTexture(){return this.environmentTexture}setEnvironmentRotation(e){let t=Math.PI/180*e;this.environmentRotationMatrix.makeRotationY(t),this.uniforms.get(`environmentMatrix`).value.copy(this.environmentRotationMatrix)}async buildEnvironmentCDF({useWorker:e=!0}={}){if(!this.scene.environment){this._updateCDFStorageBuffers(),this.uniforms.set(`envTotalSum`,0),this.uniforms.set(`envCompensationDelta`,0),this.uniforms.set(`useEnvMapIS`,0);return}try{let t=performance.now(),n=this.scene.environment;if(!n.image){this._updateCDFStorageBuffers(),this.uniforms.set(`envTotalSum`,0),this.uniforms.set(`envCompensationDelta`,0),this.uniforms.set(`useEnvMapIS`,0);return}e?await this.equirectHdrInfo.updateFromAsync(n):this.equirectHdrInfo.updateFrom(n),this.cdfBuildTime=performance.now()-t,this._updateCDFStorageBuffers(),this.uniforms.set(`envTotalSum`,this.equirectHdrInfo.totalSum),this.uniforms.set(`envCompensationDelta`,this.equirectHdrInfo.compensationDelta),this.uniforms.set(`useEnvMapIS`,1);let{width:r,height:i}=this.equirectHdrInfo;r&&i&&this.uniforms.get(`envResolution`).value.set(r,i),console.log(`Environment CDF built in ${this.cdfBuildTime.toFixed(2)}ms (worker: ${e})`)}catch(e){console.error(`Error building environment CDF:`,e),this.uniforms.set(`useEnvMapIS`,0),this.uniforms.set(`envTotalSum`,0),this.uniforms.set(`envCompensationDelta`,0)}}applyCDFResults(){let e=this.scene.environment,t=this.callbacks.getSceneTextureNodes?.();t&&e&&t.envTex&&(t.envTex.value=e),e&&!e._isGeneratedProcedural&&this.uniforms.set(`hasSun`,0)}async setEnvironmentMap(e){this.scene.environment=e,this.setEnvironmentTexture(e),e?await this.buildEnvironmentCDF():(this._updateCDFStorageBuffers(),this.uniforms.set(`envTotalSum`,0),this.uniforms.set(`envCompensationDelta`,0),this.uniforms.set(`useEnvMapIS`,0));let t=this.callbacks.getSceneTextureNodes?.();t&&e&&t.envTex&&(t.envTex.value=e),e&&!e._isGeneratedProcedural&&this.uniforms.set(`hasSun`,0),this._notifyReset()}async generateGradientTexture(){this.simpleSkyRenderer||=new mt(512,256);let e={zenithColor:this.envParams.gradientZenithColor,horizonColor:this.envParams.gradientHorizonColor,groundColor:this.envParams.gradientGroundColor};try{let t=this.simpleSkyRenderer.renderGradient(e);t._isGeneratedProcedural=!0,await this.setEnvironmentMap(t),this.uniforms.set(`hasSun`,0)}catch(e){console.error(`Error generating gradient sky:`,e)}}async generateSolidColorTexture(){this.simpleSkyRenderer||=new mt(512,256);let e={color:this.envParams.solidSkyColor};try{let t=this.simpleSkyRenderer.renderSolid(e);t._isGeneratedProcedural=!0,await this.setEnvironmentMap(t),this.uniforms.set(`hasSun`,0)}catch(e){console.error(`Error generating solid color sky:`,e)}}async generateProceduralSkyTexture(){this.proceduralSkyRenderer||=new pt(512,256);let e={sunDirection:this.envParams.skySunDirection.clone(),sunIntensity:this.envParams.skySunIntensity*.05,rayleighDensity:this.envParams.skyRayleighDensity*2,mieDensity:this.envParams.skyTurbidity*.005,mieAnisotropy:this.envParams.skyMieAnisotropy,turbidity:this.envParams.skyTurbidity*2};try{let t=this.proceduralSkyRenderer.render(e);t._isGeneratedProcedural=!0,await this.setEnvironmentMap(t),this.uniforms.get(`sunDirection`).value.copy(this.envParams.skySunDirection),this.uniforms.set(`sunAngularSize`,.0087),this.uniforms.set(`hasSun`,1),console.log(`Sun parameters synced: dir=${this.envParams.skySunDirection.toArray().map(e=>e.toFixed(2)).join(`,`)}`)}catch(e){console.error(`Error generating procedural sky:`,e)}}_calculateInitialSunDirection(){let e=V.skySunAzimuth*(Math.PI/180),t=V.skySunElevation*(Math.PI/180);return new r.Vector3(Math.cos(t)*Math.sin(e),Math.sin(t),Math.cos(t)*Math.cos(e)).normalize()}_notifyReset(){this.callbacks.onReset&&this.callbacks.onReset()}dispose(){this.proceduralSkyRenderer=null,this.simpleSkyRenderer=null,this.envCDFStorageAttr?.dispose?.(),this.envCDFStorageAttr=null,this.envCDFStorageNode=null,this.environmentTexture&&this.environmentTexture!==this._envPlaceholder&&this.environmentTexture.dispose?.(),this._envPlaceholder?.dispose(),this._envPlaceholder=null,this.environmentTexture=null,this._previousHDRI=null}},gt=y({origin:`vec3`,direction:`vec3`}),_t=y({color:`vec4`,emissive:`vec3`,emissiveIntensity:`float`,roughness:`float`,metalness:`float`,ior:`float`,transmission:`float`,thickness:`float`,clearcoat:`float`,clearcoatRoughness:`float`,opacity:`float`,transparent:`bool`,attenuationColor:`vec3`,attenuationDistance:`float`,dispersion:`float`,sheen:`float`,sheenRoughness:`float`,sheenColor:`vec3`,specularIntensity:`float`,specularColor:`vec3`,alphaTest:`float`,alphaMode:`int`,side:`int`,depthWrite:`int`,albedoMapIndex:`int`,emissiveMapIndex:`int`,normalMapIndex:`int`,bumpMapIndex:`int`,bumpScale:`float`,displacementScale:`float`,metalnessMapIndex:`int`,roughnessMapIndex:`int`,displacementMapIndex:`int`,normalScale:`vec2`,albedoTransform:`mat3`,emissiveTransform:`mat3`,normalTransform:`mat3`,bumpTransform:`mat3`,metalnessTransform:`mat3`,roughnessTransform:`mat3`,displacementTransform:`mat3`,iridescence:`float`,iridescenceIOR:`float`,iridescenceThicknessRange:`vec2`}),vt=y({color:`vec4`,ior:`float`,transmission:`float`,attenuationColor:`vec3`,attenuationDistance:`float`,albedoMapIndex:`int`,opacity:`float`,transparent:`bool`,alphaTest:`float`,alphaMode:`int`,albedoTransform:`mat3`});y({position:`vec3`,radius:`float`,material:_t});var yt=y({didHit:`bool`,dst:`float`,hitPoint:`vec3`,normal:`vec3`,uv:`vec2`,materialIndex:`int`,meshIndex:`int`,triangleIndex:`int`,boxTests:`int`,triTests:`int`});y({posA:`vec3`,posB:`vec3`,posC:`vec3`,uvA:`vec2`,uvB:`vec2`,uvC:`vec2`,normalA:`vec3`,normalB:`vec3`,normalC:`vec3`,material:_t,materialIndex:`int`,meshIndex:`int`}),y({color:`vec4`,samples:`int`});var bt=y({direction:`vec3`,value:`vec3`,pdf:`float`}),xt=y({specular:`float`,diffuse:`float`,sheen:`float`,clearcoat:`float`,transmission:`float`,iridescence:`float`}),St=y({diffuseImportance:`float`,specularImportance:`float`,transmissionImportance:`float`,clearcoatImportance:`float`,envmapImportance:`float`}),Ct=y({NoL:`float`,NoV:`float`,NoH:`float`,VoH:`float`,LoH:`float`}),wt=y({albedo:`vec4`,emissive:`vec3`,metalness:`float`,roughness:`float`,normal:`vec3`,hasTextures:`bool`}),Tt=y({isMetallic:`bool`,isRough:`bool`,isSmooth:`bool`,isTransmissive:`bool`,hasClearcoat:`bool`,isEmissive:`bool`,complexityScore:`float`}),Et=y({albedoUV:`vec2`,normalUV:`vec2`,metalnessUV:`vec2`,emissiveUV:`vec2`,bumpUV:`vec2`,roughnessUV:`vec2`,normalBumpSameUV:`bool`,metalRoughSameUV:`bool`,albedoEmissiveSameUV:`bool`,allSameUV:`bool`}),Dt=y({F0:`vec3`,NoV:`float`,diffuseColor:`vec3`,isPurelyDiffuse:`bool`,alpha:`float`,k:`float`,alpha2:`float`,invRoughness:`float`,metalFactor:`float`,iorFactor:`float`,maxSheenColor:`float`}),Ot=y({envWeight:`float`,specularWeight:`float`,diffuseWeight:`float`,transmissionWeight:`float`,clearcoatWeight:`float`,totalWeight:`float`,useEnv:`bool`,useSpecular:`bool`,useDiffuse:`bool`,useTransmission:`bool`,useClearcoat:`bool`}),kt=y({brdfWeight:`float`,lightWeight:`float`,envWeight:`float`,useBRDFSampling:`bool`,useLightSampling:`bool`,useEnvSampling:`bool`});y({traversals:`int`,transmissiveTraversals:`int`,rayType:`int`,isPrimaryRay:`bool`,actualBounceDepth:`int`});var At=3.14159,jt=1/At,Mt=2*At,Nt=1e-6,Pt=.05,Ft=.089,It=.001,Lt=(0,n.vec3)(.2126,.7152,.0722),J=U.SLOTS_PER_MATERIAL,Rt=U.SLOT,Y=Rt,zt=(0,n.mat3)(3.2404542,-.969266,.0556434,-1.5371385,1.8760108,-.2040259,-.4985314,.041556,1.0572252);(0,n.wgslFn)(`
144
144
  fn sRGBToLinear( srgbColor: vec3f ) -> vec3f {
145
145
 
146
146
  return pow( srgbColor, vec3f( 2.2 ) );
@@ -152,7 +152,7 @@
152
152
  return pow( color, vec3f( 1.0 / 2.2 ) );
153
153
 
154
154
  }
155
- `);var Xt=(0,n.wgslFn)(`
155
+ `);var Bt=(0,n.wgslFn)(`
156
156
  fn square( x: f32 ) -> f32 {
157
157
 
158
158
  return x * x;
@@ -164,7 +164,7 @@
164
164
  return x * x;
165
165
 
166
166
  }
167
- `);var Zt=(0,n.wgslFn)(`
167
+ `);var Vt=(0,n.wgslFn)(`
168
168
  fn maxComponent( v: vec3f ) -> f32 {
169
169
 
170
170
  return max( max( v.r, v.g ), v.b );
@@ -176,24 +176,24 @@
176
176
  return min( min( v.r, v.g ), v.b );
177
177
 
178
178
  }
179
- `);var Qt=(0,n.wgslFn)(`
179
+ `);var Ht=(0,n.wgslFn)(`
180
180
  fn luminance( color: vec3f ) -> f32 {
181
181
 
182
182
  return dot( color, vec3f( 0.2126, 0.7152, 0.0722 ) );
183
183
 
184
184
  }
185
- `),$t=(0,n.wgslFn)(`
185
+ `),Ut=(0,n.wgslFn)(`
186
186
  fn powerHeuristic( pdf1: f32, pdf2: f32 ) -> f32 {
187
187
 
188
188
  let p1 = pdf1 * pdf1;
189
189
  let p2 = pdf2 * pdf2;
190
- return p1 / max( p1 + p2, ${q} );
190
+ return p1 / max( p1 + p2, ${It} );
191
191
 
192
192
  }
193
- `),en=(0,n.wgslFn)(`
193
+ `),Wt=(0,n.wgslFn)(`
194
194
  fn balanceHeuristic( pdf1: f32, pdf2: f32 ) -> f32 {
195
195
 
196
- return pdf1 / max( pdf1 + pdf2, ${q} );
196
+ return pdf1 / max( pdf1 + pdf2, ${It} );
197
197
 
198
198
  }
199
199
  `);(0,n.wgslFn)(`
@@ -211,17 +211,7 @@
211
211
  return color + ( dither - 0.5 ) * ditheringAmount / 255.0;
212
212
 
213
213
  }
214
- `),(0,n.wgslFn)(`
215
- fn reduceFireflies( color: vec3f, maxValue: f32 ) -> vec3f {
216
-
217
- let lum = dot( color, vec3f( 0.2126, 0.7152, 0.0722 ) );
218
- if ( lum > maxValue ) {
219
- return color * ( maxValue / lum );
220
- }
221
- return color;
222
-
223
- }
224
- `);var tn=(0,n.wgslFn)(`
214
+ `);var Gt=(0,n.wgslFn)(`
225
215
  fn constructTBN( N: vec3f ) -> mat3x3f {
226
216
 
227
217
  var majorAxis: vec3f;
@@ -235,7 +225,7 @@
235
225
  return mat3x3f( T, B, N );
236
226
 
237
227
  }
238
- `),nn=(0,n.Fn)(([e,t,r])=>{let i=t.add(r).toVar(),a=(0,n.dot)(i,i).toVar();return i.assign(a.greaterThan(K).select(i.div(a.sqrt()),(0,n.vec3)(0,0,1))),Ft({NoL:(0,n.max)((0,n.dot)(e,r),.001),NoV:(0,n.max)((0,n.dot)(e,t),.001),NoH:(0,n.max)((0,n.dot)(e,i),.001),VoH:(0,n.max)((0,n.dot)(t,i),.001),LoH:(0,n.max)((0,n.dot)(r,i),.001)})}),rn=(0,n.wgslFn)(`
228
+ `),Kt=(0,n.Fn)(([e,t,r])=>{let i=t.add(r).toVar(),a=(0,n.dot)(i,i).toVar();return i.assign(a.greaterThan(Nt).select(i.div(a.sqrt()),(0,n.vec3)(0,0,1))),Ct({NoL:(0,n.max)((0,n.dot)(e,r),.001),NoV:(0,n.max)((0,n.dot)(e,t),.001),NoH:(0,n.max)((0,n.dot)(e,i),.001),VoH:(0,n.max)((0,n.dot)(t,i),.001),LoH:(0,n.max)((0,n.dot)(r,i),.001)})}),qt=(0,n.wgslFn)(`
239
229
  fn calculateFireflyThreshold( baseThreshold: f32, bounceIndex: i32, frame: i32 ) -> f32 {
240
230
 
241
231
  let depthFactor = 1.0 / ( 1.0 + f32( bounceIndex ) * 0.1 );
@@ -243,7 +233,7 @@
243
233
  return baseThreshold * depthFactor * relaxation;
244
234
 
245
235
  }
246
- `),an=(0,n.wgslFn)(`
236
+ `),Jt=(0,n.wgslFn)(`
247
237
  fn applySoftSuppression( value: f32, threshold: f32, dampingFactor: f32 ) -> f32 {
248
238
 
249
239
  if ( value <= threshold ) {
@@ -254,7 +244,7 @@
254
244
  return value * suppressionFactor;
255
245
 
256
246
  }
257
- `),on=(0,n.wgslFn)(`
247
+ `),Yt=(0,n.wgslFn)(`
258
248
  fn applySoftSuppressionRGB( color: vec3f, threshold: f32, dampingFactor: f32 ) -> vec3f {
259
249
 
260
250
  let lum = dot( color, vec3f( 0.2126, 0.7152, 0.0722 ) );
@@ -262,13 +252,13 @@
262
252
  return color;
263
253
  }
264
254
  let suppressedLum = applySoftSuppression( lum, threshold, dampingFactor );
265
- if ( lum > ${K} ) {
255
+ if ( lum > ${Nt} ) {
266
256
  return color * ( suppressedLum / lum );
267
257
  }
268
258
  return color;
269
259
 
270
260
  }
271
- `,[an]),sn=(0,n.Fn)(([e,t,r,i,a])=>{let o=e.greaterThan(.7).toVar(),s=t.greaterThan(.8).toVar(),c=t.lessThan(.3).toVar(),l=r.greaterThan(.5).toVar(),u=i.greaterThan(.5).toVar(),d=a.x.add(a.y).add(a.z).greaterThan(0).toVar(),f=(0,n.float)(.15).mul((0,n.float)(o)).add((0,n.float)(.25).mul((0,n.float)(c))).add((0,n.float)(.45).mul((0,n.float)(l))).add((0,n.float)(.35).mul((0,n.float)(u))).add((0,n.float)(.3).mul((0,n.float)(d))).toVar(),p=(0,n.float)(0).toVar();return(0,n.If)(o.and(c),()=>{p.addAssign(.15)}),(0,n.If)(l.and(u),()=>{p.addAssign(.2)}),(0,n.If)(d.and(l.or(o)),()=>{p.addAssign(.1)}),Lt({isMetallic:o,isRough:s,isSmooth:c,isTransmissive:l,hasClearcoat:u,isEmissive:d,complexityScore:(0,n.clamp)(f.add(p),0,1)})}),cn=(0,n.Fn)(([e,t,r,i,a])=>{let o=Zt({v:a}).toVar(),s=(0,n.float)(.5).toVar(),c=(0,n.float)(.5).toVar(),l=(0,n.bool)(!0),u=o.greaterThan(.01).toVar();return(0,n.If)(e.lessThan(.1).and(t.greaterThan(.8)),()=>{s.assign(.7),c.assign(.3)}).ElseIf(e.greaterThan(.7),()=>{s.assign(.4),c.assign(.6)}),(0,n.If)(i.greaterThan((0,n.int)(5)),()=>{s.assign(.6),c.assign(.4)}),Vt({brdfWeight:s,lightWeight:c,envWeight:(0,n.float)(0),useBRDFSampling:l,useLightSampling:u,useEnvSampling:(0,n.bool)(!1)})}),X=(0,n.Fn)(([e,t,n,r])=>{let i=t.mul(r).add(n);return e.element(i)}),ln=(0,n.wgslFn)(`
261
+ `,[Jt]),Xt=(0,n.Fn)(([e,t,r,i,a])=>{let o=e.greaterThan(.7).toVar(),s=t.greaterThan(.8).toVar(),c=t.lessThan(.3).toVar(),l=r.greaterThan(.5).toVar(),u=i.greaterThan(.5).toVar(),d=a.x.add(a.y).add(a.z).greaterThan(0).toVar(),f=(0,n.float)(.15).mul((0,n.float)(o)).add((0,n.float)(.25).mul((0,n.float)(c))).add((0,n.float)(.45).mul((0,n.float)(l))).add((0,n.float)(.35).mul((0,n.float)(u))).add((0,n.float)(.3).mul((0,n.float)(d))).toVar(),p=(0,n.float)(0).toVar();return(0,n.If)(o.and(c),()=>{p.addAssign(.15)}),(0,n.If)(l.and(u),()=>{p.addAssign(.2)}),(0,n.If)(d.and(l.or(o)),()=>{p.addAssign(.1)}),Tt({isMetallic:o,isRough:s,isSmooth:c,isTransmissive:l,hasClearcoat:u,isEmissive:d,complexityScore:(0,n.clamp)(f.add(p),0,1)})}),Zt=(0,n.Fn)(([e,t,r,i,a])=>{let o=Vt({v:a}).toVar(),s=(0,n.float)(.5).toVar(),c=(0,n.float)(.5).toVar(),l=(0,n.bool)(!0),u=o.greaterThan(.01).toVar();return(0,n.If)(e.lessThan(.1).and(t.greaterThan(.8)),()=>{s.assign(.7),c.assign(.3)}).ElseIf(e.greaterThan(.7),()=>{s.assign(.4),c.assign(.6)}),(0,n.If)(i.greaterThan((0,n.int)(5)),()=>{s.assign(.6),c.assign(.4)}),kt({brdfWeight:s,lightWeight:c,envWeight:(0,n.float)(0),useBRDFSampling:l,useLightSampling:u,useEnvSampling:(0,n.bool)(!1)})}),X=(0,n.Fn)(([e,t,n,r])=>{let i=t.mul(r).add(n);return e.element(i)}),Qt=(0,n.wgslFn)(`
272
262
  fn arrayToMat3( data1: vec4f, data2: vec4f ) -> mat3x3f {
273
263
 
274
264
  return mat3x3f(
@@ -278,7 +268,7 @@
278
268
  );
279
269
 
280
270
  }
281
- `),un=(0,n.Fn)(([e,t])=>{let r=X(t,e,(0,n.int)(Y.COLOR_METALNESS),(0,n.int)(J)).toVar(),i=X(t,e,(0,n.int)(Y.EMISSIVE_ROUGHNESS),(0,n.int)(J)).toVar(),a=X(t,e,(0,n.int)(Y.IOR_TRANSMISSION),(0,n.int)(J)).toVar(),o=X(t,e,(0,n.int)(Y.ATTENUATION),(0,n.int)(J)).toVar(),s=X(t,e,(0,n.int)(Y.DISPERSION_SHEEN),(0,n.int)(J)).toVar(),c=X(t,e,(0,n.int)(Y.SHEEN_COLOR),(0,n.int)(J)).toVar(),l=X(t,e,(0,n.int)(Y.SPECULAR),(0,n.int)(J)).toVar(),u=X(t,e,(0,n.int)(Y.IRIDESCENCE),(0,n.int)(J)).toVar(),d=X(t,e,(0,n.int)(Y.MAP_INDICES_A),(0,n.int)(J)).toVar(),f=X(t,e,(0,n.int)(Y.MAP_INDICES_B),(0,n.int)(J)).toVar(),p=X(t,e,(0,n.int)(Y.OPACITY_ALPHA),(0,n.int)(J)).toVar(),m=X(t,e,(0,n.int)(Y.ALPHA_MODE),(0,n.int)(J)).toVar(),h=X(t,e,(0,n.int)(Y.BUMP_DISPLACEMENT),(0,n.int)(J)).toVar(),g=X(t,e,(0,n.int)(Y.ALBEDO_TRANSFORM_A),(0,n.int)(J)).toVar(),_=X(t,e,(0,n.int)(Y.ALBEDO_TRANSFORM_B),(0,n.int)(J)).toVar(),v=X(t,e,(0,n.int)(Y.NORMAL_TRANSFORM_A),(0,n.int)(J)).toVar(),y=X(t,e,(0,n.int)(Y.NORMAL_TRANSFORM_B),(0,n.int)(J)).toVar(),b=X(t,e,(0,n.int)(Y.ROUGHNESS_TRANSFORM_A),(0,n.int)(J)).toVar(),x=X(t,e,(0,n.int)(Y.ROUGHNESS_TRANSFORM_B),(0,n.int)(J)).toVar(),S=X(t,e,(0,n.int)(Y.METALNESS_TRANSFORM_A),(0,n.int)(J)).toVar(),C=X(t,e,(0,n.int)(Y.METALNESS_TRANSFORM_B),(0,n.int)(J)).toVar(),w=X(t,e,(0,n.int)(Y.EMISSIVE_TRANSFORM_A),(0,n.int)(J)).toVar(),T=X(t,e,(0,n.int)(Y.EMISSIVE_TRANSFORM_B),(0,n.int)(J)).toVar(),E=X(t,e,(0,n.int)(Y.BUMP_TRANSFORM_A),(0,n.int)(J)).toVar(),D=X(t,e,(0,n.int)(Y.BUMP_TRANSFORM_B),(0,n.int)(J)).toVar(),O=X(t,e,(0,n.int)(Y.DISPLACEMENT_TRANSFORM_A),(0,n.int)(J)).toVar(),k=X(t,e,(0,n.int)(Y.DISPLACEMENT_TRANSFORM_B),(0,n.int)(J)).toVar();return kt({color:(0,n.vec4)(r.rgb,1),metalness:r.a,emissive:i.rgb,roughness:i.a,ior:a.r,transmission:a.g,thickness:a.b,emissiveIntensity:a.a,attenuationColor:o.rgb,attenuationDistance:o.a,dispersion:s.r,sheen:s.b,sheenRoughness:s.a,sheenColor:c.rgb,specularIntensity:l.r,specularColor:l.gba,iridescence:u.r,iridescenceIOR:u.g,iridescenceThicknessRange:u.ba,albedoMapIndex:(0,n.int)(d.r),normalMapIndex:(0,n.int)(d.g),roughnessMapIndex:(0,n.int)(d.b),metalnessMapIndex:(0,n.int)(d.a),emissiveMapIndex:(0,n.int)(f.r),bumpMapIndex:(0,n.int)(f.g),clearcoat:f.b,clearcoatRoughness:f.a,opacity:p.r,side:(0,n.int)(p.g),transparent:p.b,alphaTest:p.a,alphaMode:(0,n.int)(m.r),depthWrite:(0,n.int)(m.g),normalScale:(0,n.vec2)(m.b,m.b),bumpScale:h.r,displacementScale:h.g,displacementMapIndex:(0,n.int)(h.b),albedoTransform:ln({data1:g,data2:_}),normalTransform:ln({data1:v,data2:y}),roughnessTransform:ln({data1:b,data2:x}),metalnessTransform:ln({data1:S,data2:C}),emissiveTransform:ln({data1:w,data2:T}),bumpTransform:ln({data1:E,data2:D}),displacementTransform:ln({data1:O,data2:k})})}),dn=(0,n.Fn)(([e,t])=>{let r=X(t,e,(0,n.int)(Y.IOR_TRANSMISSION),(0,n.int)(J)).toVar(),i=X(t,e,(0,n.int)(Y.ATTENUATION),(0,n.int)(J)).toVar(),a=X(t,e,(0,n.int)(Y.MAP_INDICES_A),(0,n.int)(J)).toVar(),o=X(t,e,(0,n.int)(Y.OPACITY_ALPHA),(0,n.int)(J)).toVar(),s=X(t,e,(0,n.int)(Y.ALPHA_MODE),(0,n.int)(J)).toVar(),c=X(t,e,(0,n.int)(Y.ALBEDO_TRANSFORM_A),(0,n.int)(J)).toVar(),l=X(t,e,(0,n.int)(Y.ALBEDO_TRANSFORM_B),(0,n.int)(J)).toVar();return At({color:(0,n.vec4)(1),ior:r.r,transmission:r.g,attenuationColor:i.rgb,attenuationDistance:i.a,albedoMapIndex:(0,n.int)(a.r),opacity:o.r,transparent:o.b,alphaTest:o.a,alphaMode:(0,n.int)(s.r),albedoTransform:ln({data1:c,data2:l})})}),fn=(0,n.wgslFn)(`
271
+ `),$t=(0,n.Fn)(([e,t])=>{let r=X(t,e,(0,n.int)(Y.COLOR_METALNESS),(0,n.int)(J)).toVar(),i=X(t,e,(0,n.int)(Y.EMISSIVE_ROUGHNESS),(0,n.int)(J)).toVar(),a=X(t,e,(0,n.int)(Y.IOR_TRANSMISSION),(0,n.int)(J)).toVar(),o=X(t,e,(0,n.int)(Y.ATTENUATION),(0,n.int)(J)).toVar(),s=X(t,e,(0,n.int)(Y.DISPERSION_SHEEN),(0,n.int)(J)).toVar(),c=X(t,e,(0,n.int)(Y.SHEEN_COLOR),(0,n.int)(J)).toVar(),l=X(t,e,(0,n.int)(Y.SPECULAR),(0,n.int)(J)).toVar(),u=X(t,e,(0,n.int)(Y.IRIDESCENCE),(0,n.int)(J)).toVar(),d=X(t,e,(0,n.int)(Y.MAP_INDICES_A),(0,n.int)(J)).toVar(),f=X(t,e,(0,n.int)(Y.MAP_INDICES_B),(0,n.int)(J)).toVar(),p=X(t,e,(0,n.int)(Y.OPACITY_ALPHA),(0,n.int)(J)).toVar(),m=X(t,e,(0,n.int)(Y.ALPHA_MODE),(0,n.int)(J)).toVar(),h=X(t,e,(0,n.int)(Y.BUMP_DISPLACEMENT),(0,n.int)(J)).toVar(),g=X(t,e,(0,n.int)(Y.ALBEDO_TRANSFORM_A),(0,n.int)(J)).toVar(),_=X(t,e,(0,n.int)(Y.ALBEDO_TRANSFORM_B),(0,n.int)(J)).toVar(),v=X(t,e,(0,n.int)(Y.NORMAL_TRANSFORM_A),(0,n.int)(J)).toVar(),y=X(t,e,(0,n.int)(Y.NORMAL_TRANSFORM_B),(0,n.int)(J)).toVar(),b=X(t,e,(0,n.int)(Y.ROUGHNESS_TRANSFORM_A),(0,n.int)(J)).toVar(),x=X(t,e,(0,n.int)(Y.ROUGHNESS_TRANSFORM_B),(0,n.int)(J)).toVar(),S=X(t,e,(0,n.int)(Y.METALNESS_TRANSFORM_A),(0,n.int)(J)).toVar(),C=X(t,e,(0,n.int)(Y.METALNESS_TRANSFORM_B),(0,n.int)(J)).toVar(),w=X(t,e,(0,n.int)(Y.EMISSIVE_TRANSFORM_A),(0,n.int)(J)).toVar(),T=X(t,e,(0,n.int)(Y.EMISSIVE_TRANSFORM_B),(0,n.int)(J)).toVar(),E=X(t,e,(0,n.int)(Y.BUMP_TRANSFORM_A),(0,n.int)(J)).toVar(),D=X(t,e,(0,n.int)(Y.BUMP_TRANSFORM_B),(0,n.int)(J)).toVar(),O=X(t,e,(0,n.int)(Y.DISPLACEMENT_TRANSFORM_A),(0,n.int)(J)).toVar(),k=X(t,e,(0,n.int)(Y.DISPLACEMENT_TRANSFORM_B),(0,n.int)(J)).toVar();return _t({color:(0,n.vec4)(r.rgb,1),metalness:r.a,emissive:i.rgb,roughness:i.a,ior:a.r,transmission:a.g,thickness:a.b,emissiveIntensity:a.a,attenuationColor:o.rgb,attenuationDistance:o.a,dispersion:s.r,sheen:s.b,sheenRoughness:s.a,sheenColor:c.rgb,specularIntensity:l.r,specularColor:l.gba,iridescence:u.r,iridescenceIOR:u.g,iridescenceThicknessRange:u.ba,albedoMapIndex:(0,n.int)(d.r),normalMapIndex:(0,n.int)(d.g),roughnessMapIndex:(0,n.int)(d.b),metalnessMapIndex:(0,n.int)(d.a),emissiveMapIndex:(0,n.int)(f.r),bumpMapIndex:(0,n.int)(f.g),clearcoat:f.b,clearcoatRoughness:f.a,opacity:p.r,side:(0,n.int)(p.g),transparent:p.b,alphaTest:p.a,alphaMode:(0,n.int)(m.r),depthWrite:(0,n.int)(m.g),normalScale:(0,n.vec2)(m.b,m.b),bumpScale:h.r,displacementScale:h.g,displacementMapIndex:(0,n.int)(h.b),albedoTransform:Qt({data1:g,data2:_}),normalTransform:Qt({data1:v,data2:y}),roughnessTransform:Qt({data1:b,data2:x}),metalnessTransform:Qt({data1:S,data2:C}),emissiveTransform:Qt({data1:w,data2:T}),bumpTransform:Qt({data1:E,data2:D}),displacementTransform:Qt({data1:O,data2:k})})}),en=(0,n.Fn)(([e,t])=>{let r=X(t,e,(0,n.int)(Y.IOR_TRANSMISSION),(0,n.int)(J)).toVar(),i=X(t,e,(0,n.int)(Y.ATTENUATION),(0,n.int)(J)).toVar(),a=X(t,e,(0,n.int)(Y.MAP_INDICES_A),(0,n.int)(J)).toVar(),o=X(t,e,(0,n.int)(Y.OPACITY_ALPHA),(0,n.int)(J)).toVar(),s=X(t,e,(0,n.int)(Y.ALPHA_MODE),(0,n.int)(J)).toVar(),c=X(t,e,(0,n.int)(Y.ALBEDO_TRANSFORM_A),(0,n.int)(J)).toVar(),l=X(t,e,(0,n.int)(Y.ALBEDO_TRANSFORM_B),(0,n.int)(J)).toVar();return vt({color:(0,n.vec4)(1),ior:r.r,transmission:r.g,attenuationColor:i.rgb,attenuationDistance:i.a,albedoMapIndex:(0,n.int)(a.r),opacity:o.r,transparent:o.b,alphaTest:o.a,alphaMode:(0,n.int)(s.r),albedoTransform:Qt({data1:c,data2:l})})}),tn=(0,n.wgslFn)(`
282
272
  fn normalDepthWeight(
283
273
  n1: vec3f, n2: vec3f,
284
274
  d1: f32, d2: f32,
@@ -290,7 +280,7 @@
290
280
  return normalW * depthW;
291
281
 
292
282
  }
293
- `),pn=32,mn=512,hn=4,gn=8,_n=1e8,vn=()=>(0,n.array)(`int`,pn).toVar(),yn=(0,n.wgslFn)(`
283
+ `),nn=32,rn=512,an=4,on=8,sn=1e8,cn=()=>(0,n.array)(`int`,nn).toVar(),ln=(0,n.wgslFn)(`
294
284
  fn RayTriangleGeometry( rayOrigin: vec3f, rayDir: vec3f, pA: vec3f, pB: vec3f, pC: vec3f, closestHitDst: f32 ) -> vec4f {
295
285
 
296
286
  // Returns vec4(t, u, v, hit) where hit > 0.5 means intersection
@@ -331,7 +321,7 @@
331
321
  return result;
332
322
 
333
323
  }
334
- `),bn=(0,n.wgslFn)(`
324
+ `),un=(0,n.wgslFn)(`
335
325
  fn fastRayAABBDst( rayOrigin: vec3f, invDir: vec3f, boxMin: vec3f, boxMax: vec3f ) -> f32 {
336
326
 
337
327
  let t1 = ( boxMin - rayOrigin ) * invDir;
@@ -347,7 +337,7 @@
347
337
  return select( 1e20f, max( tNear, 0.0f ), isHit );
348
338
 
349
339
  }
350
- `);(0,n.Fn)(([e,t,r,i])=>{let a=(0,n.int)(X(i,e,(0,n.int)(Jt.OPACITY_ALPHA),(0,n.int)(J)).g),o=t.dot(r),s=a.equal((0,n.int)(2)),c=a.equal((0,n.int)(0)).and(o.lessThan(-1e-4)),l=a.equal((0,n.int)(1)).and(o.greaterThan(1e-4));return s.or(c).or(l)});var xn=(0,n.Fn)(([e,t,r,i])=>{let a=jt({didHit:!1,dst:(0,n.float)(0x56bc75e2d63100000),hitPoint:(0,n.vec3)(0),normal:(0,n.vec3)(0),uv:(0,n.vec2)(0),materialIndex:(0,n.int)(-1),meshIndex:(0,n.int)(-1),boxTests:(0,n.int)(0),triTests:(0,n.int)(0)}).toVar(),o=(0,n.int)(-1).toVar(),s=(0,n.float)(0).toVar(),c=(0,n.float)(0).toVar(),l=vn(),u=(0,n.int)(1).toVar();l.element((0,n.int)(0)).assign((0,n.int)(0));let d=(0,n.mix)((0,n.vec3)(1),(0,n.sign)(e.direction),(0,n.notEqual)(e.direction,(0,n.vec3)(0))),f=(0,n.mix)((0,n.vec3)(1).div(e.direction),(0,n.vec3)(_n).mul(d),(0,n.lessThan)((0,n.abs)(e.direction),(0,n.vec3)(1e-8))).toVar(),p=e.origin,m=e.direction,h=(0,n.int)(0).toVar();return(0,n.Loop)(u.greaterThan((0,n.int)(0)).and(h.lessThan((0,n.int)(mn))),()=>{h.addAssign(1),u.subAssign(1);let e=l.element(u).toVar(),i=X(t,e,(0,n.int)(0),(0,n.int)(hn));a.boxTests.addAssign(1),(0,n.If)(i.w.lessThan(0),()=>{(0,n.If)(i.w.greaterThan((0,n.float)(-1.5)),()=>{let e=(0,n.int)(i.x).toVar(),t=(0,n.int)(i.y).toVar();(0,n.Loop)({start:(0,n.int)(0),end:t},({i:t})=>{a.triTests.addAssign(1);let i=e.add(t).toVar(),l=X(r,i,(0,n.int)(0),(0,n.int)(gn)).xyz,u=X(r,i,(0,n.int)(1),(0,n.int)(gn)).xyz,d=X(r,i,(0,n.int)(2),(0,n.int)(gn)).xyz,f=yn({rayOrigin:p,rayDir:m,pA:l,pB:u,pC:d,closestHitDst:a.dst});(0,n.If)(f.w.greaterThan(.5),()=>{let e=f.x,t=f.y,l=f.z,u=X(r,i,(0,n.int)(3),(0,n.int)(gn)).xyz,d=X(r,i,(0,n.int)(4),(0,n.int)(gn)).xyz,p=X(r,i,(0,n.int)(5),(0,n.int)(gn)),h=p.xyz,g=(0,n.int)(p.w).toVar(),_=(0,n.float)(1).sub(t).sub(l),v=(0,n.normalize)(u.mul(_).add(d.mul(t)).add(h.mul(l))).toVar(),y=m.dot(v);(0,n.If)(g.equal((0,n.int)(2)).or(g.equal((0,n.int)(0)).and(y.lessThan(-1e-4))).or(g.equal((0,n.int)(1)).and(y.greaterThan(1e-4))),()=>{a.didHit.assign(!0),a.dst.assign(e),a.normal.assign(v),o.assign(i),s.assign(t),c.assign(l)})})}),(0,n.If)(a.didHit.and(a.dst.lessThan(.001)),()=>{(0,n.Break)()})}).Else(()=>{let e=(0,n.int)(i.x).toVar();(0,n.If)(i.z.greaterThan(.5).and(u.lessThan((0,n.int)(pn))),()=>{l.element(u).assign(e),u.addAssign(1)})})}).Else(()=>{let r=X(t,e,(0,n.int)(1),(0,n.int)(hn)),o=X(t,e,(0,n.int)(2),(0,n.int)(hn)),s=X(t,e,(0,n.int)(3),(0,n.int)(hn)),c=(0,n.int)(i.w).toVar(),d=(0,n.int)(r.w).toVar(),m=bn({rayOrigin:p,invDir:f,boxMin:i.xyz,boxMax:r.xyz}).toVar(),h=bn({rayOrigin:p,invDir:f,boxMin:o.xyz,boxMax:s.xyz}).toVar();(0,n.If)((0,n.min)(m,h).lessThan(a.dst),()=>{let e=m.lessThan(h),t=(0,n.select)(e,c,d).toVar(),r=(0,n.select)(e,d,c).toVar();(0,n.If)((0,n.select)(e,h,m).toVar().lessThan(a.dst).and(u.lessThan((0,n.int)(pn))),()=>{l.element(u).assign(r),u.addAssign(1)}),(0,n.If)(u.lessThan((0,n.int)(pn)),()=>{l.element(u).assign(t),u.addAssign(1)})})})}),(0,n.If)(a.didHit,()=>{a.hitPoint.assign(e.origin.add(e.direction.mul(a.dst)));let t=(0,n.float)(1).sub(s).sub(c),i=X(r,o,(0,n.int)(6),(0,n.int)(gn)),l=X(r,o,(0,n.int)(7),(0,n.int)(gn));a.uv.assign(i.xy.mul(t).add(i.zw.mul(s)).add(l.xy.mul(c))),a.materialIndex.assign((0,n.int)(l.z)),a.meshIndex.assign((0,n.int)(l.w)),a.triangleIndex.assign(o)}),a}),Sn=(0,n.Fn)(([e,t,r,i,a])=>{let o=jt({didHit:!1,dst:a,hitPoint:(0,n.vec3)(0),normal:(0,n.vec3)(0),uv:(0,n.vec2)(0),materialIndex:(0,n.int)(-1),meshIndex:(0,n.int)(-1),boxTests:(0,n.int)(0),triTests:(0,n.int)(0)}).toVar(),s=vn(),c=(0,n.int)(1).toVar();s.element((0,n.int)(0)).assign((0,n.int)(0));let l=(0,n.mix)((0,n.vec3)(1),(0,n.sign)(e.direction),(0,n.notEqual)(e.direction,(0,n.vec3)(0))),u=(0,n.mix)((0,n.vec3)(1).div(e.direction),(0,n.vec3)(_n).mul(l),(0,n.lessThan)((0,n.abs)(e.direction),(0,n.vec3)(1e-8))).toVar(),d=(0,n.int)(0).toVar();return(0,n.Loop)(c.greaterThan((0,n.int)(0)).and(o.didHit.not()).and(d.lessThan((0,n.int)(mn))),()=>{d.addAssign(1),c.subAssign(1);let i=s.element(c).toVar(),a=X(t,i,(0,n.int)(0),(0,n.int)(hn));(0,n.If)(a.w.lessThan(0),()=>{(0,n.If)(a.w.greaterThan((0,n.float)(-1.5)),()=>{let t=(0,n.int)(a.x).toVar(),i=(0,n.int)(a.y).toVar();(0,n.Loop)({start:(0,n.int)(0),end:i},({i})=>{let a=t.add(i).toVar(),s=X(r,a,(0,n.int)(0),(0,n.int)(gn)).xyz,c=X(r,a,(0,n.int)(1),(0,n.int)(gn)).xyz,l=X(r,a,(0,n.int)(2),(0,n.int)(gn)).xyz,u=yn({rayOrigin:e.origin,rayDir:e.direction,pA:s,pB:c,pC:l,closestHitDst:o.dst});(0,n.If)(u.w.greaterThan(.5),()=>{let t=X(r,a,(0,n.int)(7),(0,n.int)(gn));o.didHit.assign(!0),o.dst.assign(u.x),o.materialIndex.assign((0,n.int)(t.z)),o.meshIndex.assign((0,n.int)(t.w)),o.hitPoint.assign(e.origin.add(e.direction.mul(u.x))),o.normal.assign((0,n.normalize)((0,n.cross)(c.sub(s),l.sub(s)))),o.uv.assign((0,n.vec2)(u.y,u.z)),o.triangleIndex.assign(a),(0,n.Break)()})})}).Else(()=>{let e=(0,n.int)(a.x).toVar();(0,n.If)(a.z.greaterThan(.5).and(c.lessThan((0,n.int)(pn))),()=>{s.element(c).assign(e),c.addAssign(1)})})}).Else(()=>{let r=X(t,i,(0,n.int)(1),(0,n.int)(hn)),l=X(t,i,(0,n.int)(2),(0,n.int)(hn)),d=X(t,i,(0,n.int)(3),(0,n.int)(hn)),f=(0,n.int)(a.w).toVar(),p=(0,n.int)(r.w).toVar(),m=bn({rayOrigin:e.origin,invDir:u,boxMin:a.xyz,boxMax:r.xyz}).toVar(),h=bn({rayOrigin:e.origin,invDir:u,boxMin:l.xyz,boxMax:d.xyz}).toVar();(0,n.If)((0,n.min)(m,h).lessThan(o.dst),()=>{let e=m.lessThan(h),t=(0,n.select)(e,f,p).toVar(),r=(0,n.select)(e,p,f).toVar();(0,n.If)((0,n.select)(e,h,m).toVar().lessThan(o.dst).and(c.lessThan((0,n.int)(pn))),()=>{s.element(c).assign(r),c.addAssign(1)}),(0,n.If)(c.lessThan((0,n.int)(pn)),()=>{s.element(c).assign(t),c.addAssign(1)})})})}),o}),Cn=(0,n.Fn)(([e,t,r,i,a,o,s,c,l,u,d])=>{let f=(0,n.vec3)(e.xy,1),p=i.mul((0,n.vec4)(f,1)),m=(0,n.normalize)((0,n.mat3)(r[0].xyz,r[1].xyz,r[2].xyz).mul(p.xyz.div(p.w))).toVar(),h=(0,n.vec3)(r[3]).toVar(),g=h.toVar(),_=m.toVar();return(0,n.If)(a.and(o.greaterThan(0)).and(s.lessThan(64)).and(c.greaterThan(.001)),()=>{let e=h.add(m.mul(c)).toVar(),i=o.div(s).mul(.001).mul(l).mul(u),a=ce(t),f=a.x.mul(d.max(.01)),p=a.y,v=(0,n.normalize)((0,n.vec3)(r[0])),y=(0,n.normalize)((0,n.vec3)(r[1])),b=v.mul(f).add(y.mul(p)).mul(i);g.assign(h.add(b)),_.assign((0,n.normalize)(e.sub(g)))}),Ot({origin:g,direction:_})}),wn=(0,n.wgslFn)(`
340
+ `),dn=(0,n.Fn)(([e,t,r,i])=>{let a=yt({didHit:!1,dst:(0,n.float)(0x56bc75e2d63100000),hitPoint:(0,n.vec3)(0),normal:(0,n.vec3)(0),uv:(0,n.vec2)(0),materialIndex:(0,n.int)(-1),meshIndex:(0,n.int)(-1),boxTests:(0,n.int)(0),triTests:(0,n.int)(0)}).toVar(),o=(0,n.int)(-1).toVar(),s=(0,n.float)(0).toVar(),c=(0,n.float)(0).toVar(),l=cn(),u=(0,n.int)(1).toVar();l.element((0,n.int)(0)).assign((0,n.int)(0));let d=(0,n.mix)((0,n.vec3)(1),(0,n.sign)(e.direction),(0,n.notEqual)(e.direction,(0,n.vec3)(0))),f=(0,n.mix)((0,n.vec3)(1).div(e.direction),(0,n.vec3)(sn).mul(d),(0,n.lessThan)((0,n.abs)(e.direction),(0,n.vec3)(1e-8))).toVar(),p=e.origin,m=e.direction,h=(0,n.int)(0).toVar();return(0,n.Loop)(u.greaterThan((0,n.int)(0)).and(h.lessThan((0,n.int)(rn))),()=>{h.addAssign(1),u.subAssign(1);let e=l.element(u).toVar(),i=X(t,e,(0,n.int)(0),(0,n.int)(an));a.boxTests.addAssign(1),(0,n.If)(i.w.lessThan(0),()=>{(0,n.If)(i.w.greaterThan((0,n.float)(-1.5)),()=>{let e=(0,n.int)(i.x).toVar(),t=(0,n.int)(i.y).toVar();(0,n.Loop)({start:(0,n.int)(0),end:t},({i:t})=>{a.triTests.addAssign(1);let i=e.add(t).toVar(),l=X(r,i,(0,n.int)(0),(0,n.int)(on)).xyz,u=X(r,i,(0,n.int)(1),(0,n.int)(on)).xyz,d=X(r,i,(0,n.int)(2),(0,n.int)(on)).xyz,f=ln({rayOrigin:p,rayDir:m,pA:l,pB:u,pC:d,closestHitDst:a.dst});(0,n.If)(f.w.greaterThan(.5),()=>{let e=f.x,t=f.y,l=f.z,u=X(r,i,(0,n.int)(3),(0,n.int)(on)).xyz,d=X(r,i,(0,n.int)(4),(0,n.int)(on)).xyz,p=X(r,i,(0,n.int)(5),(0,n.int)(on)),h=p.xyz,g=(0,n.int)(p.w).toVar(),_=(0,n.float)(1).sub(t).sub(l),v=(0,n.normalize)(u.mul(_).add(d.mul(t)).add(h.mul(l))).toVar(),y=m.dot(v);(0,n.If)(g.equal((0,n.int)(2)).or(g.equal((0,n.int)(0)).and(y.lessThan(-1e-4))).or(g.equal((0,n.int)(1)).and(y.greaterThan(1e-4))),()=>{a.didHit.assign(!0),a.dst.assign(e),a.normal.assign(v),o.assign(i),s.assign(t),c.assign(l)})})}),(0,n.If)(a.didHit.and(a.dst.lessThan(.001)),()=>{(0,n.Break)()})}).Else(()=>{let e=(0,n.int)(i.x).toVar();(0,n.If)(i.z.greaterThan(.5).and(u.lessThan((0,n.int)(nn))),()=>{l.element(u).assign(e),u.addAssign(1)})})}).Else(()=>{let r=X(t,e,(0,n.int)(1),(0,n.int)(an)),o=X(t,e,(0,n.int)(2),(0,n.int)(an)),s=X(t,e,(0,n.int)(3),(0,n.int)(an)),c=(0,n.int)(i.w).toVar(),d=(0,n.int)(r.w).toVar(),m=un({rayOrigin:p,invDir:f,boxMin:i.xyz,boxMax:r.xyz}).toVar(),h=un({rayOrigin:p,invDir:f,boxMin:o.xyz,boxMax:s.xyz}).toVar();(0,n.If)((0,n.min)(m,h).lessThan(a.dst),()=>{let e=m.lessThan(h),t=(0,n.select)(e,c,d).toVar(),r=(0,n.select)(e,d,c).toVar();(0,n.If)((0,n.select)(e,h,m).toVar().lessThan(a.dst).and(u.lessThan((0,n.int)(nn))),()=>{l.element(u).assign(r),u.addAssign(1)}),(0,n.If)(u.lessThan((0,n.int)(nn)),()=>{l.element(u).assign(t),u.addAssign(1)})})})}),(0,n.If)(a.didHit,()=>{a.hitPoint.assign(e.origin.add(e.direction.mul(a.dst)));let t=(0,n.float)(1).sub(s).sub(c),i=X(r,o,(0,n.int)(6),(0,n.int)(on)),l=X(r,o,(0,n.int)(7),(0,n.int)(on));a.uv.assign(i.xy.mul(t).add(i.zw.mul(s)).add(l.xy.mul(c))),a.materialIndex.assign((0,n.int)(l.z)),a.meshIndex.assign((0,n.int)(l.w)),a.triangleIndex.assign(o)}),a}),fn=(0,n.Fn)(([e,t,r,i,a])=>{let o=yt({didHit:!1,dst:a,hitPoint:(0,n.vec3)(0),normal:(0,n.vec3)(0),uv:(0,n.vec2)(0),materialIndex:(0,n.int)(-1),meshIndex:(0,n.int)(-1),boxTests:(0,n.int)(0),triTests:(0,n.int)(0)}).toVar(),s=cn(),c=(0,n.int)(1).toVar();s.element((0,n.int)(0)).assign((0,n.int)(0));let l=(0,n.mix)((0,n.vec3)(1),(0,n.sign)(e.direction),(0,n.notEqual)(e.direction,(0,n.vec3)(0))),u=(0,n.mix)((0,n.vec3)(1).div(e.direction),(0,n.vec3)(sn).mul(l),(0,n.lessThan)((0,n.abs)(e.direction),(0,n.vec3)(1e-8))).toVar(),d=(0,n.int)(0).toVar();return(0,n.Loop)(c.greaterThan((0,n.int)(0)).and(o.didHit.not()).and(d.lessThan((0,n.int)(rn))),()=>{d.addAssign(1),c.subAssign(1);let i=s.element(c).toVar(),a=X(t,i,(0,n.int)(0),(0,n.int)(an));(0,n.If)(a.w.lessThan(0),()=>{(0,n.If)(a.w.greaterThan((0,n.float)(-1.5)),()=>{let t=(0,n.int)(a.x).toVar(),i=(0,n.int)(a.y).toVar();(0,n.Loop)({start:(0,n.int)(0),end:i},({i})=>{let a=t.add(i).toVar(),s=X(r,a,(0,n.int)(0),(0,n.int)(on)).xyz,c=X(r,a,(0,n.int)(1),(0,n.int)(on)).xyz,l=X(r,a,(0,n.int)(2),(0,n.int)(on)).xyz,u=ln({rayOrigin:e.origin,rayDir:e.direction,pA:s,pB:c,pC:l,closestHitDst:o.dst});(0,n.If)(u.w.greaterThan(.5),()=>{let t=X(r,a,(0,n.int)(7),(0,n.int)(on));o.didHit.assign(!0),o.dst.assign(u.x),o.materialIndex.assign((0,n.int)(t.z)),o.meshIndex.assign((0,n.int)(t.w)),o.hitPoint.assign(e.origin.add(e.direction.mul(u.x))),o.normal.assign((0,n.normalize)((0,n.cross)(c.sub(s),l.sub(s)))),o.uv.assign((0,n.vec2)(u.y,u.z)),o.triangleIndex.assign(a),(0,n.Break)()})})}).Else(()=>{let e=(0,n.int)(a.x).toVar();(0,n.If)(a.z.greaterThan(.5).and(c.lessThan((0,n.int)(nn))),()=>{s.element(c).assign(e),c.addAssign(1)})})}).Else(()=>{let r=X(t,i,(0,n.int)(1),(0,n.int)(an)),l=X(t,i,(0,n.int)(2),(0,n.int)(an)),d=X(t,i,(0,n.int)(3),(0,n.int)(an)),f=(0,n.int)(a.w).toVar(),p=(0,n.int)(r.w).toVar(),m=un({rayOrigin:e.origin,invDir:u,boxMin:a.xyz,boxMax:r.xyz}).toVar(),h=un({rayOrigin:e.origin,invDir:u,boxMin:l.xyz,boxMax:d.xyz}).toVar();(0,n.If)((0,n.min)(m,h).lessThan(o.dst),()=>{let e=m.lessThan(h),t=(0,n.select)(e,f,p).toVar(),r=(0,n.select)(e,p,f).toVar();(0,n.If)((0,n.select)(e,h,m).toVar().lessThan(o.dst).and(c.lessThan((0,n.int)(nn))),()=>{s.element(c).assign(r),c.addAssign(1)}),(0,n.If)(c.lessThan((0,n.int)(nn)),()=>{s.element(c).assign(t),c.addAssign(1)})})})}),o}),pn=(0,n.Fn)(([e,t,r,i,a,o,s,c,l,u,d])=>{let f=(0,n.vec3)(e.xy,1),p=i.mul((0,n.vec4)(f,1)),m=(0,n.normalize)((0,n.mat3)(r[0].xyz,r[1].xyz,r[2].xyz).mul(p.xyz.div(p.w))).toVar(),h=(0,n.vec3)(r[3]).toVar(),g=h.toVar(),_=m.toVar();return(0,n.If)(a.and(o.greaterThan(0)).and(s.lessThan(64)).and(c.greaterThan(.001)),()=>{let e=h.add(m.mul(c)).toVar(),i=o.div(s).mul(.001).mul(l).mul(u),a=P(t),f=a.x.mul(d.max(.01)),p=a.y,v=(0,n.normalize)((0,n.vec3)(r[0])),y=(0,n.normalize)((0,n.vec3)(r[1])),b=v.mul(f).add(y.mul(p)).mul(i);g.assign(h.add(b)),_.assign((0,n.normalize)(e.sub(g)))}),gt({origin:g,direction:_})}),mn=(0,n.wgslFn)(`
351
341
  fn equirectDirectionToUv( direction: vec3f, environmentMatrix: mat4x4f ) -> vec2f {
352
342
  let d = normalize( ( environmentMatrix * vec4f( direction, 0.0f ) ).xyz );
353
343
  var uv = vec2f( atan2( d.z, d.x ), acos( d.y ) );
@@ -356,7 +346,7 @@
356
346
  uv.y = 1.0f - uv.y;
357
347
  return uv;
358
348
  }
359
- `),Tn=(0,n.wgslFn)(`
349
+ `),hn=(0,n.wgslFn)(`
360
350
  fn equirectUvToDirection( uv: vec2f, environmentMatrix: mat4x4f ) -> vec3f {
361
351
  let adjustedUv = vec2f( uv.x - 0.5f, 1.0f - uv.y );
362
352
  let theta = adjustedUv.x * 6.28318530717958647692f;
@@ -365,7 +355,7 @@
365
355
  let localDir = vec3f( sinPhi * cos( theta ), cos( phi ), sinPhi * sin( theta ) );
366
356
  return normalize( ( transpose( environmentMatrix ) * vec4f( localDir, 0.0f ) ).xyz );
367
357
  }
368
- `);(0,n.Fn)(([e,t,r])=>(0,n.texture)(e,wn({direction:t,environmentMatrix:r}),0).rgb);var En=(0,n.wgslFn)(`
358
+ `),gn=(0,n.wgslFn)(`
369
359
  fn equirectDirectionPdf( direction: vec3f, environmentMatrix: mat4x4f ) -> f32 {
370
360
  let uv = equirectDirectionToUv( direction, environmentMatrix );
371
361
  let theta = uv.y * 3.14159265358979323846f;
@@ -373,7 +363,7 @@
373
363
  if ( sinTheta == 0.0f ) { return 0.0f; }
374
364
  return 1.0f / ( 6.28318530717958647692f * 3.14159265358979323846f * sinTheta );
375
365
  }
376
- `,[wn]),Dn=(0,n.Fn)(([e,t,r,i,a,o])=>{let s=(0,n.vec4)(0).toVar();return(0,n.If)(i.equal(0),()=>{s.assign((0,n.vec4)(0))}).Else(()=>{let c=wn({direction:t,environmentMatrix:r}).toVar(),l=(0,n.texture)(e,c,0).rgb.toVar(),u=(0,n.sin)(c.y.mul(Math.PI)).toVar(),d=(0,n.dot)(l,qt).toVar().mul(u).toVar(),f=(0,n.max)((0,n.float)(0),d.sub(a)).toVar().div(i).toVar(),p=En({direction:t,environmentMatrix:r}).toVar(),m=(0,n.float)(o.x).mul((0,n.float)(o.y)).mul(f).mul(p).toVar();s.assign((0,n.vec4)(l,m))}),s}),On=(0,n.Fn)(([e,t,r,i,a,o,s,c,l])=>{let u=(0,n.int)(s.y).toVar(),d=s.y,f=(0,n.clamp)(c.x.mul(d.sub(1)),0,d.sub(1)),p=(0,n.int)((0,n.floor)(f)),m=(0,n.min)(p.add(1),(0,n.int)(d).sub(1)),h=(0,n.fract)(f),g=(0,n.mix)(t.element(p),t.element(m),h).toVar(),_=s.x,v=s.y,y=(0,n.clamp)(c.y.mul(_.sub(1)),0,_.sub(1)),b=(0,n.clamp)(g.mul(v.sub(1)),0,v.sub(1)),x=(0,n.int)((0,n.floor)(y)),S=(0,n.int)((0,n.floor)(b)),C=(0,n.min)(x.add(1),(0,n.int)(_).sub(1)),w=(0,n.min)(S.add(1),(0,n.int)(v).sub(1)),T=(0,n.fract)(y),E=(0,n.fract)(b),D=(0,n.int)(_),O=t.element(u.add(S.mul(D).add(x))),k=t.element(u.add(S.mul(D).add(C))),A=t.element(u.add(w.mul(D).add(x))),j=t.element(u.add(w.mul(D).add(C))),M=(0,n.vec2)((0,n.mix)((0,n.mix)(O,k,T),(0,n.mix)(A,j,T),E).toVar(),g).toVar(),N=Tn({uv:M,environmentMatrix:r}).toVar(),ee=(0,n.texture)(e,M,0).rgb.mul(i).toVar();l.assign(ee);let te=(0,n.sin)(M.y.mul(Math.PI)).toVar(),ne=(0,n.dot)(ee.div(i),qt).toVar().mul(te).toVar(),re=(0,n.max)((0,n.float)(0),ne.sub(o)).toVar().div(a).toVar(),ie=En({direction:N,environmentMatrix:r}).toVar();return(0,n.vec4)(N,(0,n.float)(s.x).mul((0,n.float)(s.y)).mul(re).mul(ie).toVar())}),kn=(0,n.wgslFn)(`
366
+ `,[mn]),_n=(0,n.Fn)(([e,t,r,i,a,o])=>{let s=(0,n.vec4)(0).toVar();return(0,n.If)(i.equal(0),()=>{s.assign((0,n.vec4)(0))}).Else(()=>{let c=mn({direction:t,environmentMatrix:r}).toVar(),l=(0,n.texture)(e,c,0).rgb.toVar(),u=(0,n.sin)(c.y.mul(Math.PI)).toVar(),d=(0,n.dot)(l,Lt).toVar().mul(u).toVar(),f=(0,n.max)((0,n.float)(0),d.sub(a)).toVar().div(i).toVar(),p=gn({direction:t,environmentMatrix:r}).toVar(),m=(0,n.float)(o.x).mul((0,n.float)(o.y)).mul(f).mul(p).toVar();s.assign((0,n.vec4)(l,m))}),s}),vn=(0,n.Fn)(([e,t,r,i,a,o,s,c,l])=>{let u=(0,n.int)(s.y).toVar(),d=s.y,f=(0,n.clamp)(c.x.mul(d.sub(1)),0,d.sub(1)),p=(0,n.int)((0,n.floor)(f)),m=(0,n.min)(p.add(1),(0,n.int)(d).sub(1)),h=(0,n.fract)(f),g=(0,n.mix)(t.element(p),t.element(m),h).toVar(),_=s.x,v=s.y,y=(0,n.clamp)(c.y.mul(_.sub(1)),0,_.sub(1)),b=(0,n.clamp)(g.mul(v.sub(1)),0,v.sub(1)),x=(0,n.int)((0,n.floor)(y)),S=(0,n.int)((0,n.floor)(b)),C=(0,n.min)(x.add(1),(0,n.int)(_).sub(1)),w=(0,n.min)(S.add(1),(0,n.int)(v).sub(1)),T=(0,n.fract)(y),E=(0,n.fract)(b),D=(0,n.int)(_),O=t.element(u.add(S.mul(D).add(x))),k=t.element(u.add(S.mul(D).add(C))),A=t.element(u.add(w.mul(D).add(x))),j=t.element(u.add(w.mul(D).add(C))),M=(0,n.vec2)((0,n.mix)((0,n.mix)(O,k,T),(0,n.mix)(A,j,T),E).toVar(),g).toVar(),N=hn({uv:M,environmentMatrix:r}).toVar(),P=(0,n.texture)(e,M,0).rgb.mul(i).toVar();l.assign(P);let ee=(0,n.sin)(M.y.mul(Math.PI)).toVar(),F=(0,n.dot)(P.div(i),Lt).toVar().mul(ee).toVar(),I=(0,n.max)((0,n.float)(0),F.sub(o)).toVar().div(a).toVar(),te=gn({direction:N,environmentMatrix:r}).toVar();return(0,n.vec4)(N,(0,n.float)(s.x).mul((0,n.float)(s.y)).mul(I).mul(te).toVar())}),yn=(0,n.wgslFn)(`
377
367
  fn sampleEnvironment(
378
368
  tex: texture_2d<f32>,
379
369
  samp: sampler,
@@ -387,7 +377,7 @@
387
377
  let texSample = textureSampleLevel( tex, samp, uv, 0.0 );
388
378
  return texSample * environmentIntensity;
389
379
  }
390
- `,[wn]),An=(0,n.wgslFn)(`
380
+ `,[mn]),bn=(0,n.wgslFn)(`
391
381
  fn isIdentityTransform( transform: mat3x3f ) -> bool {
392
382
  return transform[0][0] == 1.0f
393
383
  && transform[1][1] == 1.0f
@@ -396,7 +386,7 @@
396
386
  && transform[2][0] == 0.0f
397
387
  && transform[2][1] == 0.0f;
398
388
  }
399
- `),jn=(0,n.wgslFn)(`
389
+ `),xn=(0,n.wgslFn)(`
400
390
  fn getTransformedUV( uv: vec2f, transform: mat3x3f ) -> vec2f {
401
391
  if ( !isIdentityTransform( transform ) ) {
402
392
  return fract( vec2f(
@@ -406,11 +396,11 @@
406
396
  }
407
397
  return uv;
408
398
  }
409
- `,[An]),Mn=(0,n.Fn)(([e])=>e.albedoMapIndex.greaterThanEqual((0,n.int)(0)).or(e.normalMapIndex.greaterThanEqual((0,n.int)(0))).or(e.roughnessMapIndex.greaterThanEqual((0,n.int)(0))).or(e.metalnessMapIndex.greaterThanEqual((0,n.int)(0))).or(e.emissiveMapIndex.greaterThanEqual((0,n.int)(0))).or(e.bumpMapIndex.greaterThanEqual((0,n.int)(0))).or(e.displacementMapIndex.greaterThanEqual((0,n.int)(0)))),Nn=(0,n.wgslFn)(`
399
+ `,[bn]),Sn=(0,n.Fn)(([e])=>e.albedoMapIndex.greaterThanEqual((0,n.int)(0)).or(e.normalMapIndex.greaterThanEqual((0,n.int)(0))).or(e.roughnessMapIndex.greaterThanEqual((0,n.int)(0))).or(e.metalnessMapIndex.greaterThanEqual((0,n.int)(0))).or(e.emissiveMapIndex.greaterThanEqual((0,n.int)(0))).or(e.bumpMapIndex.greaterThanEqual((0,n.int)(0))).or(e.displacementMapIndex.greaterThanEqual((0,n.int)(0)))),Cn=(0,n.wgslFn)(`
410
400
  fn hashTransform( t: mat3x3f ) -> f32 {
411
401
  return t[0][0] + t[1][1] * 7.0f + t[2][0] * 13.0f + t[2][1] * 17.0f;
412
402
  }
413
- `),Pn=(0,n.Fn)(([e,t])=>{let r=Nn({t:t.albedoTransform}).toVar(),i=Nn({t:t.normalTransform}).toVar(),a=Nn({t:t.metalnessTransform}).toVar(),o=Nn({t:t.roughnessTransform}).toVar(),s=Nn({t:t.emissiveTransform}).toVar(),c=Nn({t:t.bumpTransform}).toVar(),l=.001,u=(0,n.abs)(r.sub(i)).lessThan(l).toVar(),d=(0,n.abs)(i.sub(c)).lessThan(l).toVar(),f=(0,n.abs)(a.sub(o)).lessThan(l).toVar(),p=(0,n.abs)(r.sub(s)).lessThan(l).toVar(),m=u.and((0,n.abs)(r.sub(a)).lessThan(l)).and((0,n.abs)(r.sub(s)).lessThan(l)).and((0,n.abs)(r.sub(c)).lessThan(l)).toVar(),h=(0,n.vec2)(0).toVar(),g=(0,n.vec2)(0).toVar(),_=(0,n.vec2)(0).toVar(),v=(0,n.vec2)(0).toVar(),y=(0,n.vec2)(0).toVar(),b=(0,n.vec2)(0).toVar(),x=d.or(m).toVar(),S=f.or(m).toVar(),C=p.or(m).toVar();return(0,n.If)(m,()=>{let n=jn({uv:e,transform:t.albedoTransform});h.assign(n),g.assign(n),_.assign(n),v.assign(n),y.assign(n),b.assign(n)}).Else(()=>{h.assign(jn({uv:e,transform:t.albedoTransform})),g.assign(u.select(h,jn({uv:e,transform:t.normalTransform}))),y.assign(p.select(h,jn({uv:e,transform:t.emissiveTransform}))),(0,n.If)(d,()=>{b.assign(g)}).ElseIf((0,n.abs)(c.sub(r)).lessThan(l),()=>{b.assign(h)}).Else(()=>{b.assign(jn({uv:e,transform:t.bumpTransform}))}),(0,n.If)(f,()=>{_.assign(jn({uv:e,transform:t.metalnessTransform})),v.assign(_)}).Else(()=>{(0,n.If)((0,n.abs)(a.sub(r)).lessThan(l),()=>{_.assign(h)}).ElseIf((0,n.abs)(a.sub(i)).lessThan(l),()=>{_.assign(g)}).Else(()=>{_.assign(jn({uv:e,transform:t.metalnessTransform}))}),(0,n.If)((0,n.abs)(o.sub(r)).lessThan(l),()=>{v.assign(h)}).ElseIf((0,n.abs)(o.sub(i)).lessThan(l),()=>{v.assign(g)}).ElseIf((0,n.abs)(o.sub(a)).lessThan(l),()=>{v.assign(_)}).Else(()=>{v.assign(jn({uv:e,transform:t.roughnessTransform}))})})}),Rt({albedoUV:h,normalUV:g,metalnessUV:_,roughnessUV:v,emissiveUV:y,bumpUV:b,allSameUV:m,normalBumpSameUV:x,metalRoughSameUV:S,albedoEmissiveSameUV:C})}),Fn=(0,n.Fn)(([e,t,r])=>{let i=t.color.toVar();return(0,n.If)(t.albedoMapIndex.greaterThanEqual((0,n.int)(0)),()=>{let a=(0,n.texture)(e,r.albedoUV).depth((0,n.int)(t.albedoMapIndex)).toVar();i.assign((0,n.vec4)(t.color.rgb.mul(a.rgb),t.color.a.mul(a.a)))}),i}),In=(0,n.Fn)(([e,t,r,i])=>{let a=r.metalness.toVar(),o=r.roughness.toVar();return(0,n.If)(r.metalnessMapIndex.greaterThanEqual((0,n.int)(0)).and(r.metalnessMapIndex.equal(r.roughnessMapIndex)),()=>{let t=(0,n.texture)(e,i.metalnessUV).depth((0,n.int)(r.metalnessMapIndex));a.assign(r.metalness.mul(t.b)),o.assign(r.roughness.mul(t.g))}).Else(()=>{(0,n.If)(r.metalnessMapIndex.greaterThanEqual((0,n.int)(0)),()=>{let t=(0,n.texture)(e,i.metalnessUV).depth((0,n.int)(r.metalnessMapIndex));a.assign(r.metalness.mul(t.b))}),(0,n.If)(r.roughnessMapIndex.greaterThanEqual((0,n.int)(0)),()=>{let e=(0,n.texture)(t,i.roughnessUV).depth((0,n.int)(r.roughnessMapIndex));o.assign(r.roughness.mul(e.g))})}),(0,n.vec2)(a,o)}),Ln=(0,n.Fn)(([e,t,r,i])=>{let a=t.toVar();return(0,n.If)(r.normalMapIndex.greaterThanEqual((0,n.int)(0)),()=>{let o=(0,n.texture)(e,i.normalUV).depth((0,n.int)(r.normalMapIndex)).xyz.mul(2).sub(1).toVar();o.x.mulAssign(r.normalScale.x),o.y.assign(o.y.negate().mul(r.normalScale.x));let s=(0,n.normalize)((0,n.cross)((0,n.abs)(t.z).lessThan(.999).select((0,n.vec3)(0,0,1),(0,n.vec3)(1,0,0)),t)),c=(0,n.cross)(t,s);a.assign((0,n.normalize)(s.mul(o.x).add(c.mul(o.y)).add(t.mul(o.z))))}),a}),Rn=(0,n.Fn)(([e,t,r,i])=>{let a=t.toVar();return(0,n.If)(r.bumpMapIndex.greaterThanEqual((0,n.int)(0)).and(r.bumpScale.greaterThan(0)),()=>{let o=(0,n.vec2)(1/1024).toVar(),s=(0,n.texture)(e,i.bumpUV).depth((0,n.int)(r.bumpMapIndex)).r,c=(0,n.texture)(e,(0,n.vec2)(i.bumpUV.x.add(o.x),i.bumpUV.y)).depth((0,n.int)(r.bumpMapIndex)).r,l=(0,n.texture)(e,(0,n.vec2)(i.bumpUV.x,i.bumpUV.y.add(o.y))).depth((0,n.int)(r.bumpMapIndex)).r,u=(0,n.vec2)(c.sub(s),l.sub(s)).mul(r.bumpScale),d=(0,n.normalize)((0,n.vec3)(u.x.negate(),u.y.negate(),1)),f=(0,n.normalize)((0,n.cross)((0,n.abs)(t.z).lessThan(.999).select((0,n.vec3)(0,0,1),(0,n.vec3)(1,0,0)),t)),p=(0,n.cross)(t,f),m=f.mul(d.x).add(p.mul(d.y)).add(t.mul(d.z));a.assign((0,n.normalize)((0,n.mix)(t,m,(0,n.clamp)(r.bumpScale,0,1))))}),a}),zn=(0,n.Fn)(([e,t,r,i])=>{let a=t.emissive.mul(t.emissiveIntensity).toVar();return(0,n.If)(t.emissiveMapIndex.greaterThanEqual((0,n.int)(0)),()=>{let r=(0,n.texture)(e,i.emissiveUV).depth((0,n.int)(t.emissiveMapIndex)).toVar();a.assign(a.mul(r.rgb))}),a}),Bn=(0,n.Fn)(([e,t,r,i,a,o,s,c,l])=>{let u=(0,n.vec4)(0).toVar(),d=(0,n.vec3)(0).toVar(),f=(0,n.float)(0).toVar(),p=(0,n.float)(0).toVar(),m=(0,n.vec3)(0).toVar(),h=Mn(s).toVar();return u.assign(s.color),d.assign(s.emissive.mul(s.emissiveIntensity)),f.assign(s.metalness),p.assign(s.roughness),m.assign(l),(0,n.If)(h,()=>{let n=Rt.wrap(Pn(c,s)).toVar();u.assign(Fn(e,s,n));let h=In(i,a,s,n);f.assign(h.x),p.assign(h.y);let g=Ln(t,l,s,n).toVar();m.assign(Rn(r,g,s,n)),d.assign(zn(o,s,u,n))}),It({albedo:u,emissive:d,metalness:f,roughness:p,normal:m,hasTextures:h})});(0,n.Fn)(([e,t,r,i,a,o,s,c])=>It.wrap(Bn(e,t,r,i,a,o,s,c,(0,n.vec3)(0,1,0))).albedo),(0,n.Fn)(([e,t,r,i,a,o,s,c])=>It.wrap(Bn(e,t,r,i,a,o,s,c,(0,n.vec3)(0,1,0))).emissive),(0,n.Fn)(([e,t,r,i,a,o,s,c])=>It.wrap(Bn(e,t,r,i,a,o,s,c,(0,n.vec3)(0,1,0))).metalness),(0,n.Fn)(([e,t,r,i,a,o,s,c])=>It.wrap(Bn(e,t,r,i,a,o,s,c,(0,n.vec3)(0,1,0))).roughness),(0,n.Fn)(([e,t,n,r,i,a,o,s,c])=>It.wrap(Bn(e,t,n,r,i,a,o,s,c)).normal);var Vn=(0,n.Fn)(([e,t,r,i])=>{let a=(0,n.float)(0).toVar();return(0,n.If)(t.greaterThanEqual((0,n.int)(0)),()=>{let o=jn({uv:r,transform:i});a.assign((0,n.texture)(e,o).depth((0,n.int)(t)).r)}),a}),Hn=32,Un=16,Wn=5,Gn=1/1024,Kn=8,qn=D({hitPoint:`vec3`,uv:`vec2`,normal:`vec3`,height:`float`}),Jn=(0,n.Fn)(([e,t,r,i,a,o])=>{let s=t.hitPoint.toVar(),c=t.uv.toVar(),l=t.normal.toVar(),u=(0,n.float)(0).toVar(),d=t.triangleIndex,f=X(r,d,(0,n.int)(0),(0,n.int)(Kn)).xyz.toVar(),p=X(r,d,(0,n.int)(1),(0,n.int)(Kn)).xyz.toVar(),m=X(r,d,(0,n.int)(2),(0,n.int)(Kn)).xyz.toVar(),h=X(r,d,(0,n.int)(6),(0,n.int)(Kn)).toVar(),g=X(r,d,(0,n.int)(7),(0,n.int)(Kn)).toVar(),_=h.xy.toVar(),v=h.zw.toVar(),y=g.xy.toVar(),b=p.sub(f).toVar(),x=m.sub(f).toVar(),S=v.sub(_).toVar(),C=y.sub(_).toVar(),w=S.x.mul(C.y).sub(C.x.mul(S.y)).toVar();return(0,n.If)((0,n.abs)(w).greaterThan(1e-8),()=>{let r=(0,n.float)(1).div(w),d=b.mul(C.y).sub(x.mul(S.y)).mul(r).toVar(),f=x.mul(S.x).sub(b.mul(C.x)).mul(r).toVar(),p=t.normal.toVar(),m=a.displacementScale.div((0,n.float)(10)),h=e.direction,g=(0,n.dot)(h,p).toVar(),_=h.sub(p.mul(g)).toVar(),v=(0,n.dot)(d,d),y=(0,n.dot)(d,f),T=(0,n.dot)(f,f),E=v.mul(T).sub(y.mul(y)).toVar();(0,n.If)((0,n.abs)(E).greaterThan(1e-10),()=>{let e=(0,n.float)(1).div(E),r=(0,n.dot)(_,d),b=(0,n.dot)(_,f),x=(0,n.vec2)(T.mul(r).sub(y.mul(b)).mul(e).toVar(),v.mul(b).sub(y.mul(r)).mul(e).toVar()).toVar(),S=g.toVar(),C=(0,n.max)((0,n.abs)(S),.001).toVar(),w=m.div(C).toVar(),D=(0,n.int)(o.equal((0,n.int)(0)).select((0,n.int)(Hn),(0,n.int)(Un))).toVar(),O=w.negate().toVar(),k=w.toVar().sub(O).div((0,n.float)(D)).toVar(),A=O.toVar(),j=O.toVar(),M=(0,n.int)(0).toVar();(0,n.Loop)({start:(0,n.int)(0),end:D,type:`int`,condition:`<`},({i:e})=>{(0,n.If)(M.equal((0,n.int)(0)),()=>{let r=O.add(k.mul((0,n.float)(e))).toVar(),o=t.uv.add(x.mul(r)).toVar(),s=r.mul(S).toVar(),c=Vn(i,a.displacementMapIndex,o,a.displacementTransform).sub(.5).mul(m);(0,n.If)(s.lessThanEqual(c).and(e.greaterThan((0,n.int)(0))),()=>{M.assign(1),j.assign(r)}).Else(()=>{A.assign(r)})})}),(0,n.If)(M.equal((0,n.int)(1)),()=>{let e=A.toVar(),r=j.toVar();(0,n.Loop)({start:(0,n.int)(0),end:(0,n.int)(Wn),type:`int`,condition:`<`},()=>{let o=e.add(r).mul(.5).toVar(),s=t.uv.add(x.mul(o)).toVar(),c=o.mul(S),l=Vn(i,a.displacementMapIndex,s,a.displacementTransform).sub(.5).mul(m);(0,n.If)(c.lessThanEqual(l),()=>{r.assign(o)}).Else(()=>{e.assign(o)})});let o=e.add(r).mul(.5).toVar(),g=t.uv.add(x.mul(o)).toVar(),_=t.hitPoint.add(h.mul(o)).toVar(),v=Vn(i,a.displacementMapIndex,g,a.displacementTransform),y=v.sub(.5).mul(m),b=(0,n.float)(Gn),C=v,w=Vn(i,a.displacementMapIndex,g.add((0,n.vec2)(b,0)),a.displacementTransform),T=Vn(i,a.displacementMapIndex,g.add((0,n.vec2)(0,b)),a.displacementTransform),E=(0,n.normalize)(d).toVar(),D=(0,n.normalize)(f).toVar(),O=w.sub(C).mul(m),k=T.sub(C).mul(m),M=(0,n.normalize)(p.sub(E.mul(O)).sub(D.mul(k)));s.assign(_),c.assign(g),l.assign(M),u.assign(y)})})}),qn({hitPoint:s,uv:c,normal:l,height:u})}),Yn=1e-6;(0,n.Fn)(([e,t,r])=>{let i=(0,n.max)((0,n.vec3)((0,n.float)(1).sub(r)),e);return e.add(i.sub(e).mul((0,n.pow)((0,n.float)(1).sub(t),5)))});var Xn=(0,n.Fn)(([e,t])=>{let r=(0,n.clamp)(e,0,1);return t.add((0,n.float)(1).sub(t).mul((0,n.pow)((0,n.float)(1).sub(r),5)))}),Zn=(0,n.Fn)(([e,t])=>{let r=(0,n.clamp)(e,0,1);return t.add((0,n.vec3)(1).sub(t).mul((0,n.pow)((0,n.float)(1).sub(r),5)))}),Qn=(0,n.Fn)(([e])=>{let t=(0,n.sqrt)(e);return(0,n.vec3)(1).add(t).div((0,n.max)((0,n.vec3)(1).sub(t),(0,n.vec3)(Yn)))}),$n=(0,n.Fn)(([e,t])=>{let r=e.sub((0,n.vec3)(t)),i=(0,n.max)(e.add((0,n.vec3)(t)),(0,n.vec3)(Yn)),a=r.div(i);return a.mul(a)}),er=(0,n.Fn)(([e,t])=>{let r=e.sub(t),i=(0,n.max)(e.add(t),Yn),a=r.div(i);return a.mul(a)}),tr=e=>(0,n.vec3)(er(e,(0,n.float)(1))),nr=(0,n.Fn)(([e,t])=>{let r=t.mul(t),i=r.mul(r),a=e.mul(e).mul(i.sub(1)).add(1);return i.div((0,n.max)((0,n.float)(G).mul(a).mul(a),K))}),rr=(0,n.Fn)(([e,t])=>{let r=(0,n.max)(t,Gt),i=r.mul(r),a=(0,n.float)(1).div(i),o=e.mul(e).mul(a.mul(a).sub(1)).add(1);return(0,n.min)(a.mul(a).div((0,n.max)((0,n.float)(G).mul(o).mul(o),K)),100)}),ir=(0,n.Fn)(([e,t])=>{let r=t.add(1),i=r.mul(r).div(8);return e.div((0,n.max)(e.mul((0,n.float)(1).sub(i)).add(i),K))}),ar=(0,n.Fn)(([e,t,n])=>{let r=ir(e,n);return ir(t,n).mul(r)}),or=(0,n.Fn)(([e,t,r])=>{let i=(0,n.float)(1).sub(r),a=r.mul(-.0275).add(.0425),o=r.mul(-.572).add(1.04),s=r.mul(.022).sub(.04),c=(0,n.min)(i.mul(i),(0,n.exp)((0,n.float)(-6.4308).mul(t))).mul(i).add(a),l=(0,n.float)(-1.04).mul(c).add(o),u=(0,n.float)(1.04).mul(c).add(s),d=(0,n.max)(l.add(u),.1);return(0,n.vec3)(1).add(e.mul((0,n.float)(1).div(d).sub(1)))}),sr=(0,n.Fn)(([e,t,r])=>{let i=(0,n.float)(1).sub(r),a=r.mul(-.0275).add(.0425),o=r.mul(-.572).add(1.04),s=r.mul(.022).sub(.04),c=(0,n.min)(i.mul(i),(0,n.exp)((0,n.float)(-6.4308).mul(t))).mul(i).add(a),l=(0,n.float)(-1.04).mul(c).add(o),u=(0,n.float)(1.04).mul(c).add(s),d=(0,n.max)(e.mul(l).add((0,n.vec3)(u)),(0,n.vec3)(0)),f=(0,n.max)(l.add(u),.1),p=(0,n.vec3)(1).add(e.mul((0,n.float)(1).div(f).sub(1)));return(0,n.clamp)(d.mul(p),(0,n.vec3)(0),(0,n.vec3)(1))}),cr=(0,n.Fn)(([e,t,r])=>nr(e,r).mul(e).div((0,n.max)((0,n.float)(4).mul(t),K))),lr=(0,n.Fn)(([e,t,r])=>{let i=nr(e,r),a=ir(t,r);return i.mul(a).div((0,n.max)(t.mul(4),K))}),ur=(0,n.Fn)(([e,t])=>{let r=(0,n.float)(Wt).mul(e).mul(1e-9),i=(0,n.vec3)(54856e-17,44201e-17,52481e-17),a=(0,n.vec3)(1681e3,1795300,2208400),o=(0,n.vec3)(43278e5,93046e5,66121e5),s=i.mul((0,n.sqrt)((0,n.float)(Wt).mul(o))).mul((0,n.cos)(a.mul(r).add(t))).mul((0,n.exp)(Xt({x:r}).negate().mul(o))).toVar();return s.x.addAssign((0,n.float)(9747e-17).mul((0,n.sqrt)((0,n.float)(Wt).mul(45282e5))).mul((0,n.cos)((0,n.float)(2239900).mul(r).add(t.x))).mul((0,n.exp)((0,n.float)(-45282e5).mul(Xt({x:r}))))),Yt.mul(s.div(1.0685e-7))}),dr=(0,n.Fn)(([e,t,r,i,a])=>{let o=(0,n.mix)(e,t,(0,n.smoothstep)(0,.03,i)).toVar(),s=Xt({x:e.div(o)}).mul((0,n.float)(1).sub(Xt({x:r}))).toVar(),c=(0,n.float)(1).sub(s).toVar(),l=(0,n.vec3)(0).toVar();return(0,n.If)(c.lessThan(0),()=>{l.assign((0,n.vec3)(1))}).Else(()=>{let t=(0,n.sqrt)(c).toVar(),s=Xn(r,er(o,e).toVar()).toVar(),u=(0,n.float)(1).sub(s).toVar(),d=o.lessThan(e).select((0,n.float)(G),(0,n.float)(0)).toVar(),f=(0,n.float)(G).sub(d).toVar(),p=Qn((0,n.clamp)(a,0,.9999)).toVar(),m=$n(p,o).toVar(),h=(0,n.vec3)(Xn(t,m.x),Xn(t,m.y),Xn(t,m.z)).toVar(),g=(0,n.vec3)(p.x.lessThan(o).select((0,n.float)(G),(0,n.float)(0)),p.y.lessThan(o).select((0,n.float)(G),(0,n.float)(0)),p.z.lessThan(o).select((0,n.float)(G),(0,n.float)(0))).toVar(),_=(0,n.float)(2).mul(o).mul(i).mul(t).toVar(),v=(0,n.vec3)(f).add(g).toVar(),y=(0,n.clamp)((0,n.vec3)(s).mul(h),1e-5,.9999).toVar(),b=(0,n.sqrt)(y).toVar(),x=(0,n.vec3)(u.mul(u)).mul(h).div((0,n.vec3)(1).sub(y)).toVar(),S=(0,n.vec3)(s).add(x).toVar().toVar(),C=x.sub((0,n.vec3)(u)).toVar();C.mulAssign(b),S.addAssign(C.mul((0,n.float)(2).mul(ur((0,n.float)(1).mul(_),(0,n.float)(1).mul(v))))),C.mulAssign(b),S.addAssign(C.mul((0,n.float)(2).mul(ur((0,n.float)(2).mul(_),(0,n.float)(2).mul(v))))),l.assign((0,n.max)(S,(0,n.vec3)(0)))}),l}),fr=(0,n.Fn)(([e,t,r])=>{let i=r.invRoughness,a=r.metalFactor,o=(0,n.float)(0).toVar();(0,n.If)(t.isMetallic,()=>{o.assign((0,n.max)(i.mul(a),.7))}).ElseIf(t.isSmooth,()=>{o.assign(i.mul(a).mul(1.2))}).Else(()=>{o.assign((0,n.max)(i.mul(a),e.metalness.mul(.1)))});let s=o.mul(e.specularIntensity).toVar(),c=(0,n.float)(1).sub(o).mul((0,n.float)(1).sub(e.metalness)).toVar(),l=e.sheen.mul(r.maxSheenColor).toVar(),u=(0,n.float)(0).toVar();(0,n.If)(t.hasClearcoat,()=>{u.assign(e.clearcoat.mul(i).mul(.4))}).Else(()=>{u.assign(e.clearcoat.mul(i).mul(.35))});let d=(0,n.float)(0).toVar();(0,n.If)(t.isTransmissive,()=>{let t=r.iorFactor.mul(i).mul(.8);d.assign(e.transmission.mul(t).mul((0,n.float)(.6).add((0,n.float)(.4).mul(e.ior.div(2)))).mul((0,n.float)(1).add(e.dispersion.mul(.6))))}).Else(()=>{let t=r.iorFactor.mul(i).mul(.7);d.assign(e.transmission.mul(t).mul((0,n.float)(.5).add((0,n.float)(.5).mul(e.ior.div(2)))).mul((0,n.float)(1).add(e.dispersion.mul(.5))))});let f=i.mul(t.isSmooth.select((0,n.float)(.6),(0,n.float)(.5))),p=(0,n.min)(e.iridescence.mul(f).mul((0,n.float)(.5).add((0,n.float)(.5).mul(e.iridescenceThicknessRange.y.sub(e.iridescenceThicknessRange.x).div(1e3)))).mul((0,n.float)(.5).add((0,n.float)(.5).mul(e.iridescenceIOR.div(2)))),c);s.addAssign(p),c.subAssign(p);let m=s.add(c).add(l).add(u).add(d),h=(0,n.float)(1).div((0,n.max)(m,.001));return Nt({specular:s.mul(h),diffuse:c.mul(h),sheen:l.mul(h),clearcoat:u.mul(h),transmission:d.mul(h),iridescence:(0,n.float)(0)})});(0,n.Fn)(([e,t])=>{let r=(0,n.float)(0).toVar();return(0,n.If)(e.transmission.greaterThan(0).or(e.clearcoat.greaterThan(0)),()=>{r.assign(.95)}).Else(()=>{let i=t.complexityScore.toVar(),a=(0,n.float)(0).toVar();(0,n.If)(t.isEmissive,()=>{let t=(0,n.dot)(e.emissive,qt);a.assign((0,n.min)((0,n.float)(.6),t.mul(e.emissiveIntensity).mul(.25)))});let o=(0,n.float)(0).toVar();(0,n.If)(t.isMetallic.and(t.isSmooth),()=>{o.addAssign(.25)}).ElseIf(t.isMetallic,()=>{o.addAssign(.15)}),(0,n.If)(t.isTransmissive,()=>{o.addAssign(.2)}),(0,n.If)(t.hasClearcoat,()=>{o.addAssign(.1)});let s=(0,n.max)(i.add(o),a);r.assign((0,n.clamp)(s,0,1))}),r});var pr=(0,n.Fn)(([e,t,r,i,a,o])=>{let s=(0,n.float)(1).sub(e.roughness),c=(0,n.float)(.5).add((0,n.float)(.5).mul(e.metalness)),l=(0,n.min)((0,n.float)(2).div(e.ior),1),u=(0,n.max)(e.sheenColor.r,(0,n.max)(e.sheenColor.g,e.sheenColor.b)),d=zt({F0:tr(e.ior),NoV:(0,n.float)(.5),diffuseColor:e.color.rgb,isPurelyDiffuse:!1,alpha:e.roughness.mul(e.roughness),k:e.roughness.add(1).mul(e.roughness.add(1)).div(8),alpha2:e.roughness.mul(e.roughness).mul(e.roughness).mul(e.roughness),invRoughness:s,metalFactor:c,iorFactor:l,maxSheenColor:u}),f=Nt.wrap(fr(e,r,d)),p=f.diffuse.toVar(),m=f.specular.toVar(),h=f.transmission.toVar(),g=f.clearcoat.toVar();(0,n.If)(t.greaterThan((0,n.int)(2)),()=>{let e=(0,n.float)(1).div((0,n.float)(t).sub(1));m.mulAssign((0,n.float)(.8).add(e.mul(.2))),g.mulAssign((0,n.float)(.7).add(e.mul(.3))),p.mulAssign((0,n.float)(1).add(e.mul(.2)))}),(0,n.If)(r.isMetallic.and(t.lessThan((0,n.int)(3))),()=>{m.assign((0,n.max)(m,.6)),p.mulAssign(.4)}),(0,n.If)(r.isTransmissive,()=>{h.assign((0,n.max)(h,.8)),p.mulAssign(.2),m.mulAssign(.6)}),(0,n.If)(r.hasClearcoat,()=>{g.assign((0,n.max)(g,.4))});let _=p.add(m).add(h).add(g).toVar();return(0,n.If)(_.greaterThan(.001),()=>{let e=(0,n.float)(1).div(_);p.mulAssign(e),m.mulAssign(e),h.mulAssign(e),g.mulAssign(e)}).Else(()=>{p.assign(1),m.assign(0),h.assign(0),g.assign(0)}),Pt({diffuseImportance:p,specularImportance:m,transmissionImportance:h,clearcoatImportance:g,envmapImportance:(0,n.float)(0)})}),mr=(0,n.Fn)(([e,t,r,i,a])=>{let o=(0,n.max)((0,n.dot)(e,t),.001).toVar(),s=a.isRough.and(a.isMetallic.not()).and(r.transmission.equal(0)).and(r.clearcoat.equal(0)).toVar(),c=i.roughness.mul(i.roughness).toVar(),l=c.mul(c).toVar(),u=i.roughness.add(1),d=u.mul(u).div(8).toVar();return zt({F0:(0,n.mix)(tr(r.ior).mul(r.specularColor),i.albedo.rgb,i.metalness).mul(r.specularIntensity).toVar(),NoV:o,diffuseColor:i.albedo.rgb.mul((0,n.float)(1).sub(i.metalness)).toVar(),isPurelyDiffuse:s,alpha:c,k:d,alpha2:l,invRoughness:(0,n.float)(1).sub(i.roughness).toVar(),metalFactor:(0,n.float)(.5).add((0,n.float)(.5).mul(i.metalness)).toVar(),iorFactor:(0,n.min)((0,n.float)(2).div(r.ior),1).toVar(),maxSheenColor:(0,n.max)(r.sheenColor.r,(0,n.max)(r.sheenColor.g,r.sheenColor.b)).toVar()})}),hr=(0,n.wgslFn)(`
403
+ `),wn=(0,n.Fn)(([e,t])=>{let r=Cn({t:t.albedoTransform}).toVar(),i=Cn({t:t.normalTransform}).toVar(),a=Cn({t:t.metalnessTransform}).toVar(),o=Cn({t:t.roughnessTransform}).toVar(),s=Cn({t:t.emissiveTransform}).toVar(),c=Cn({t:t.bumpTransform}).toVar(),l=.001,u=(0,n.abs)(r.sub(i)).lessThan(l).toVar(),d=(0,n.abs)(i.sub(c)).lessThan(l).toVar(),f=(0,n.abs)(a.sub(o)).lessThan(l).toVar(),p=(0,n.abs)(r.sub(s)).lessThan(l).toVar(),m=u.and((0,n.abs)(r.sub(a)).lessThan(l)).and((0,n.abs)(r.sub(s)).lessThan(l)).and((0,n.abs)(r.sub(c)).lessThan(l)).toVar(),h=(0,n.vec2)(0).toVar(),g=(0,n.vec2)(0).toVar(),_=(0,n.vec2)(0).toVar(),v=(0,n.vec2)(0).toVar(),y=(0,n.vec2)(0).toVar(),b=(0,n.vec2)(0).toVar(),x=d.or(m).toVar(),S=f.or(m).toVar(),C=p.or(m).toVar();return(0,n.If)(m,()=>{let n=xn({uv:e,transform:t.albedoTransform});h.assign(n),g.assign(n),_.assign(n),v.assign(n),y.assign(n),b.assign(n)}).Else(()=>{h.assign(xn({uv:e,transform:t.albedoTransform})),g.assign(u.select(h,xn({uv:e,transform:t.normalTransform}))),y.assign(p.select(h,xn({uv:e,transform:t.emissiveTransform}))),(0,n.If)(d,()=>{b.assign(g)}).ElseIf((0,n.abs)(c.sub(r)).lessThan(l),()=>{b.assign(h)}).Else(()=>{b.assign(xn({uv:e,transform:t.bumpTransform}))}),(0,n.If)(f,()=>{_.assign(xn({uv:e,transform:t.metalnessTransform})),v.assign(_)}).Else(()=>{(0,n.If)((0,n.abs)(a.sub(r)).lessThan(l),()=>{_.assign(h)}).ElseIf((0,n.abs)(a.sub(i)).lessThan(l),()=>{_.assign(g)}).Else(()=>{_.assign(xn({uv:e,transform:t.metalnessTransform}))}),(0,n.If)((0,n.abs)(o.sub(r)).lessThan(l),()=>{v.assign(h)}).ElseIf((0,n.abs)(o.sub(i)).lessThan(l),()=>{v.assign(g)}).ElseIf((0,n.abs)(o.sub(a)).lessThan(l),()=>{v.assign(_)}).Else(()=>{v.assign(xn({uv:e,transform:t.roughnessTransform}))})})}),Et({albedoUV:h,normalUV:g,metalnessUV:_,roughnessUV:v,emissiveUV:y,bumpUV:b,allSameUV:m,normalBumpSameUV:x,metalRoughSameUV:S,albedoEmissiveSameUV:C})}),Tn=(0,n.Fn)(([e,t,r])=>{let i=t.color.toVar();return(0,n.If)(t.albedoMapIndex.greaterThanEqual((0,n.int)(0)),()=>{let a=(0,n.texture)(e,r.albedoUV).depth((0,n.int)(t.albedoMapIndex)).toVar();i.assign((0,n.vec4)(t.color.rgb.mul(a.rgb),t.color.a.mul(a.a)))}),i}),En=(0,n.Fn)(([e,t,r,i])=>{let a=r.metalness.toVar(),o=r.roughness.toVar();return(0,n.If)(r.metalnessMapIndex.greaterThanEqual((0,n.int)(0)).and(r.metalnessMapIndex.equal(r.roughnessMapIndex)),()=>{let t=(0,n.texture)(e,i.metalnessUV).depth((0,n.int)(r.metalnessMapIndex));a.assign(r.metalness.mul(t.b)),o.assign(r.roughness.mul(t.g))}).Else(()=>{(0,n.If)(r.metalnessMapIndex.greaterThanEqual((0,n.int)(0)),()=>{let t=(0,n.texture)(e,i.metalnessUV).depth((0,n.int)(r.metalnessMapIndex));a.assign(r.metalness.mul(t.b))}),(0,n.If)(r.roughnessMapIndex.greaterThanEqual((0,n.int)(0)),()=>{let e=(0,n.texture)(t,i.roughnessUV).depth((0,n.int)(r.roughnessMapIndex));o.assign(r.roughness.mul(e.g))})}),(0,n.vec2)(a,o)}),Dn=(0,n.Fn)(([e,t,r,i])=>{let a=t.toVar();return(0,n.If)(r.normalMapIndex.greaterThanEqual((0,n.int)(0)),()=>{let o=(0,n.texture)(e,i.normalUV).depth((0,n.int)(r.normalMapIndex)).xyz.mul(2).sub(1).toVar();o.x.mulAssign(r.normalScale.x),o.y.assign(o.y.negate().mul(r.normalScale.x));let s=(0,n.normalize)((0,n.cross)((0,n.abs)(t.z).lessThan(.999).select((0,n.vec3)(0,0,1),(0,n.vec3)(1,0,0)),t)),c=(0,n.cross)(t,s);a.assign((0,n.normalize)(s.mul(o.x).add(c.mul(o.y)).add(t.mul(o.z))))}),a}),On=(0,n.Fn)(([e,t,r,i])=>{let a=t.toVar();return(0,n.If)(r.bumpMapIndex.greaterThanEqual((0,n.int)(0)).and(r.bumpScale.greaterThan(0)),()=>{let o=(0,n.vec2)(1/1024).toVar(),s=(0,n.texture)(e,i.bumpUV).depth((0,n.int)(r.bumpMapIndex)).r,c=(0,n.texture)(e,(0,n.vec2)(i.bumpUV.x.add(o.x),i.bumpUV.y)).depth((0,n.int)(r.bumpMapIndex)).r,l=(0,n.texture)(e,(0,n.vec2)(i.bumpUV.x,i.bumpUV.y.add(o.y))).depth((0,n.int)(r.bumpMapIndex)).r,u=(0,n.vec2)(c.sub(s),l.sub(s)).mul(r.bumpScale),d=(0,n.normalize)((0,n.vec3)(u.x.negate(),u.y.negate(),1)),f=(0,n.normalize)((0,n.cross)((0,n.abs)(t.z).lessThan(.999).select((0,n.vec3)(0,0,1),(0,n.vec3)(1,0,0)),t)),p=(0,n.cross)(t,f),m=f.mul(d.x).add(p.mul(d.y)).add(t.mul(d.z));a.assign((0,n.normalize)((0,n.mix)(t,m,(0,n.clamp)(r.bumpScale,0,1))))}),a}),kn=(0,n.Fn)(([e,t,r,i])=>{let a=t.emissive.mul(t.emissiveIntensity).toVar();return(0,n.If)(t.emissiveMapIndex.greaterThanEqual((0,n.int)(0)),()=>{let r=(0,n.texture)(e,i.emissiveUV).depth((0,n.int)(t.emissiveMapIndex)).toVar();a.assign(a.mul(r.rgb))}),a}),An=(0,n.Fn)(([e,t,r,i,a,o,s,c,l])=>{let u=(0,n.vec4)(0).toVar(),d=(0,n.vec3)(0).toVar(),f=(0,n.float)(0).toVar(),p=(0,n.float)(0).toVar(),m=(0,n.vec3)(0).toVar(),h=Sn(s).toVar();return u.assign(s.color),d.assign(s.emissive.mul(s.emissiveIntensity)),f.assign(s.metalness),p.assign(s.roughness),m.assign(l),(0,n.If)(h,()=>{let n=Et.wrap(wn(c,s)).toVar();u.assign(Tn(e,s,n));let h=En(i,a,s,n);f.assign(h.x),p.assign(h.y);let g=Dn(t,l,s,n).toVar();m.assign(On(r,g,s,n)),d.assign(kn(o,s,u,n))}),wt({albedo:u,emissive:d,metalness:f,roughness:p,normal:m,hasTextures:h})}),jn=(0,n.Fn)(([e,t,r,i])=>{let a=(0,n.float)(0).toVar();return(0,n.If)(t.greaterThanEqual((0,n.int)(0)),()=>{let o=xn({uv:r,transform:i});a.assign((0,n.texture)(e,o).depth((0,n.int)(t)).r)}),a}),Mn=32,Nn=16,Pn=5,Fn=1/1024,In=8,Ln=y({hitPoint:`vec3`,uv:`vec2`,normal:`vec3`,height:`float`}),Rn=(0,n.Fn)(([e,t,r,i,a,o])=>{let s=t.hitPoint.toVar(),c=t.uv.toVar(),l=t.normal.toVar(),u=(0,n.float)(0).toVar(),d=t.triangleIndex,f=X(r,d,(0,n.int)(0),(0,n.int)(In)).xyz.toVar(),p=X(r,d,(0,n.int)(1),(0,n.int)(In)).xyz.toVar(),m=X(r,d,(0,n.int)(2),(0,n.int)(In)).xyz.toVar(),h=X(r,d,(0,n.int)(6),(0,n.int)(In)).toVar(),g=X(r,d,(0,n.int)(7),(0,n.int)(In)).toVar(),_=h.xy.toVar(),v=h.zw.toVar(),y=g.xy.toVar(),b=p.sub(f).toVar(),x=m.sub(f).toVar(),S=v.sub(_).toVar(),C=y.sub(_).toVar(),w=S.x.mul(C.y).sub(C.x.mul(S.y)).toVar();return(0,n.If)((0,n.abs)(w).greaterThan(1e-8),()=>{let r=(0,n.float)(1).div(w),d=b.mul(C.y).sub(x.mul(S.y)).mul(r).toVar(),f=x.mul(S.x).sub(b.mul(C.x)).mul(r).toVar(),p=t.normal.toVar(),m=a.displacementScale.div((0,n.float)(10)),h=e.direction,g=(0,n.dot)(h,p).toVar(),_=h.sub(p.mul(g)).toVar(),v=(0,n.dot)(d,d),y=(0,n.dot)(d,f),T=(0,n.dot)(f,f),E=v.mul(T).sub(y.mul(y)).toVar();(0,n.If)((0,n.abs)(E).greaterThan(1e-10),()=>{let e=(0,n.float)(1).div(E),r=(0,n.dot)(_,d),b=(0,n.dot)(_,f),x=(0,n.vec2)(T.mul(r).sub(y.mul(b)).mul(e).toVar(),v.mul(b).sub(y.mul(r)).mul(e).toVar()).toVar(),S=g.toVar(),C=(0,n.max)((0,n.abs)(S),.001).toVar(),w=m.div(C).toVar(),D=(0,n.int)(o.equal((0,n.int)(0)).select((0,n.int)(Mn),(0,n.int)(Nn))).toVar(),O=w.negate().toVar(),k=w.toVar().sub(O).div((0,n.float)(D)).toVar(),A=O.toVar(),j=O.toVar(),M=(0,n.int)(0).toVar();(0,n.Loop)({start:(0,n.int)(0),end:D,type:`int`,condition:`<`},({i:e})=>{(0,n.If)(M.equal((0,n.int)(0)),()=>{let r=O.add(k.mul((0,n.float)(e))).toVar(),o=t.uv.add(x.mul(r)).toVar(),s=r.mul(S).toVar(),c=jn(i,a.displacementMapIndex,o,a.displacementTransform).sub(.5).mul(m);(0,n.If)(s.lessThanEqual(c).and(e.greaterThan((0,n.int)(0))),()=>{M.assign(1),j.assign(r)}).Else(()=>{A.assign(r)})})}),(0,n.If)(M.equal((0,n.int)(1)),()=>{let e=A.toVar(),r=j.toVar();(0,n.Loop)({start:(0,n.int)(0),end:(0,n.int)(Pn),type:`int`,condition:`<`},()=>{let o=e.add(r).mul(.5).toVar(),s=t.uv.add(x.mul(o)).toVar(),c=o.mul(S),l=jn(i,a.displacementMapIndex,s,a.displacementTransform).sub(.5).mul(m);(0,n.If)(c.lessThanEqual(l),()=>{r.assign(o)}).Else(()=>{e.assign(o)})});let o=e.add(r).mul(.5).toVar(),g=t.uv.add(x.mul(o)).toVar(),_=t.hitPoint.add(h.mul(o)).toVar(),v=jn(i,a.displacementMapIndex,g,a.displacementTransform),y=v.sub(.5).mul(m),b=(0,n.float)(Fn),C=v,w=jn(i,a.displacementMapIndex,g.add((0,n.vec2)(b,0)),a.displacementTransform),T=jn(i,a.displacementMapIndex,g.add((0,n.vec2)(0,b)),a.displacementTransform),E=(0,n.normalize)(d).toVar(),D=(0,n.normalize)(f).toVar(),O=w.sub(C).mul(m),k=T.sub(C).mul(m),M=(0,n.normalize)(p.sub(E.mul(O)).sub(D.mul(k)));s.assign(_),c.assign(g),l.assign(M),u.assign(y)})})}),Ln({hitPoint:s,uv:c,normal:l,height:u})}),zn=1e-6;(0,n.Fn)(([e,t,r])=>{let i=(0,n.max)((0,n.vec3)((0,n.float)(1).sub(r)),e);return e.add(i.sub(e).mul((0,n.pow)((0,n.float)(1).sub(t),5)))});var Bn=(0,n.Fn)(([e,t])=>{let r=(0,n.clamp)(e,0,1);return t.add((0,n.float)(1).sub(t).mul((0,n.pow)((0,n.float)(1).sub(r),5)))}),Vn=(0,n.Fn)(([e,t])=>{let r=(0,n.clamp)(e,0,1);return t.add((0,n.vec3)(1).sub(t).mul((0,n.pow)((0,n.float)(1).sub(r),5)))}),Hn=(0,n.Fn)(([e])=>{let t=(0,n.sqrt)(e);return(0,n.vec3)(1).add(t).div((0,n.max)((0,n.vec3)(1).sub(t),(0,n.vec3)(zn)))}),Un=(0,n.Fn)(([e,t])=>{let r=e.sub((0,n.vec3)(t)),i=(0,n.max)(e.add((0,n.vec3)(t)),(0,n.vec3)(zn)),a=r.div(i);return a.mul(a)}),Wn=(0,n.Fn)(([e,t])=>{let r=e.sub(t),i=(0,n.max)(e.add(t),zn),a=r.div(i);return a.mul(a)}),Gn=e=>(0,n.vec3)(Wn(e,(0,n.float)(1))),Kn=(0,n.Fn)(([e,t])=>{let r=t.mul(t),i=r.mul(r),a=e.mul(e).mul(i.sub(1)).add(1);return i.div((0,n.max)((0,n.float)(At).mul(a).mul(a),Nt))}),qn=(0,n.Fn)(([e,t])=>{let r=(0,n.max)(t,Pt),i=r.mul(r),a=(0,n.float)(1).div(i),o=e.mul(e).mul(a.mul(a).sub(1)).add(1);return(0,n.min)(a.mul(a).div((0,n.max)((0,n.float)(At).mul(o).mul(o),Nt)),100)}),Jn=(0,n.Fn)(([e,t])=>{let r=t.add(1),i=r.mul(r).div(8);return e.div((0,n.max)(e.mul((0,n.float)(1).sub(i)).add(i),Nt))}),Yn=(0,n.Fn)(([e,t,n])=>{let r=Jn(e,n);return Jn(t,n).mul(r)}),Xn=(0,n.Fn)(([e,t,r])=>{let i=(0,n.float)(1).sub(r),a=r.mul(-.0275).add(.0425),o=r.mul(-.572).add(1.04),s=r.mul(.022).sub(.04),c=(0,n.min)(i.mul(i),(0,n.exp)((0,n.float)(-6.4308).mul(t))).mul(i).add(a),l=(0,n.float)(-1.04).mul(c).add(o),u=(0,n.float)(1.04).mul(c).add(s),d=(0,n.max)(l.add(u),.1);return(0,n.vec3)(1).add(e.mul((0,n.float)(1).div(d).sub(1)))}),Zn=(0,n.Fn)(([e,t,r])=>{let i=(0,n.float)(1).sub(r),a=r.mul(-.0275).add(.0425),o=r.mul(-.572).add(1.04),s=r.mul(.022).sub(.04),c=(0,n.min)(i.mul(i),(0,n.exp)((0,n.float)(-6.4308).mul(t))).mul(i).add(a),l=(0,n.float)(-1.04).mul(c).add(o),u=(0,n.float)(1.04).mul(c).add(s),d=(0,n.max)(e.mul(l).add((0,n.vec3)(u)),(0,n.vec3)(0)),f=(0,n.max)(l.add(u),.1),p=(0,n.vec3)(1).add(e.mul((0,n.float)(1).div(f).sub(1)));return(0,n.clamp)(d.mul(p),(0,n.vec3)(0),(0,n.vec3)(1))}),Qn=(0,n.Fn)(([e,t,r])=>Kn(e,r).mul(e).div((0,n.max)((0,n.float)(4).mul(t),Nt))),$n=(0,n.Fn)(([e,t,r])=>{let i=Kn(e,r),a=Jn(t,r);return i.mul(a).div((0,n.max)(t.mul(4),Nt))}),er=(0,n.Fn)(([e,t])=>{let r=(0,n.float)(Mt).mul(e).mul(1e-9),i=(0,n.vec3)(54856e-17,44201e-17,52481e-17),a=(0,n.vec3)(1681e3,1795300,2208400),o=(0,n.vec3)(43278e5,93046e5,66121e5),s=i.mul((0,n.sqrt)((0,n.float)(Mt).mul(o))).mul((0,n.cos)(a.mul(r).add(t))).mul((0,n.exp)(Bt({x:r}).negate().mul(o))).toVar();return s.x.addAssign((0,n.float)(9747e-17).mul((0,n.sqrt)((0,n.float)(Mt).mul(45282e5))).mul((0,n.cos)((0,n.float)(2239900).mul(r).add(t.x))).mul((0,n.exp)((0,n.float)(-45282e5).mul(Bt({x:r}))))),zt.mul(s.div(1.0685e-7))}),tr=(0,n.Fn)(([e,t,r,i,a])=>{let o=(0,n.mix)(e,t,(0,n.smoothstep)(0,.03,i)).toVar(),s=Bt({x:e.div(o)}).mul((0,n.float)(1).sub(Bt({x:r}))).toVar(),c=(0,n.float)(1).sub(s).toVar(),l=(0,n.vec3)(0).toVar();return(0,n.If)(c.lessThan(0),()=>{l.assign((0,n.vec3)(1))}).Else(()=>{let t=(0,n.sqrt)(c).toVar(),s=Bn(r,Wn(o,e).toVar()).toVar(),u=(0,n.float)(1).sub(s).toVar(),d=o.lessThan(e).select((0,n.float)(At),(0,n.float)(0)).toVar(),f=(0,n.float)(At).sub(d).toVar(),p=Hn((0,n.clamp)(a,0,.9999)).toVar(),m=Un(p,o).toVar(),h=(0,n.vec3)(Bn(t,m.x),Bn(t,m.y),Bn(t,m.z)).toVar(),g=(0,n.vec3)(p.x.lessThan(o).select((0,n.float)(At),(0,n.float)(0)),p.y.lessThan(o).select((0,n.float)(At),(0,n.float)(0)),p.z.lessThan(o).select((0,n.float)(At),(0,n.float)(0))).toVar(),_=(0,n.float)(2).mul(o).mul(i).mul(t).toVar(),v=(0,n.vec3)(f).add(g).toVar(),y=(0,n.clamp)((0,n.vec3)(s).mul(h),1e-5,.9999).toVar(),b=(0,n.sqrt)(y).toVar(),x=(0,n.vec3)(u.mul(u)).mul(h).div((0,n.vec3)(1).sub(y)).toVar(),S=(0,n.vec3)(s).add(x).toVar().toVar(),C=x.sub((0,n.vec3)(u)).toVar();C.mulAssign(b),S.addAssign(C.mul((0,n.float)(2).mul(er((0,n.float)(1).mul(_),(0,n.float)(1).mul(v))))),C.mulAssign(b),S.addAssign(C.mul((0,n.float)(2).mul(er((0,n.float)(2).mul(_),(0,n.float)(2).mul(v))))),l.assign((0,n.max)(S,(0,n.vec3)(0)))}),l}),nr=(0,n.Fn)(([e,t,r])=>{let i=r.invRoughness,a=r.metalFactor,o=(0,n.float)(0).toVar();(0,n.If)(t.isMetallic,()=>{o.assign((0,n.max)(i.mul(a),.7))}).ElseIf(t.isSmooth,()=>{o.assign(i.mul(a).mul(1.2))}).Else(()=>{o.assign((0,n.max)(i.mul(a),e.metalness.mul(.1)))});let s=o.mul(e.specularIntensity).toVar(),c=(0,n.float)(1).sub(o).mul((0,n.float)(1).sub(e.metalness)).toVar(),l=e.sheen.mul(r.maxSheenColor).toVar(),u=(0,n.float)(0).toVar();(0,n.If)(t.hasClearcoat,()=>{u.assign(e.clearcoat.mul(i).mul(.4))}).Else(()=>{u.assign(e.clearcoat.mul(i).mul(.35))});let d=(0,n.float)(0).toVar();(0,n.If)(t.isTransmissive,()=>{let t=r.iorFactor.mul(i).mul(.8);d.assign(e.transmission.mul(t).mul((0,n.float)(.6).add((0,n.float)(.4).mul(e.ior.div(2)))).mul((0,n.float)(1).add(e.dispersion.mul(.6))))}).Else(()=>{let t=r.iorFactor.mul(i).mul(.7);d.assign(e.transmission.mul(t).mul((0,n.float)(.5).add((0,n.float)(.5).mul(e.ior.div(2)))).mul((0,n.float)(1).add(e.dispersion.mul(.5))))});let f=i.mul(t.isSmooth.select((0,n.float)(.6),(0,n.float)(.5))),p=(0,n.min)(e.iridescence.mul(f).mul((0,n.float)(.5).add((0,n.float)(.5).mul(e.iridescenceThicknessRange.y.sub(e.iridescenceThicknessRange.x).div(1e3)))).mul((0,n.float)(.5).add((0,n.float)(.5).mul(e.iridescenceIOR.div(2)))),c);s.addAssign(p),c.subAssign(p);let m=s.add(c).add(l).add(u).add(d),h=(0,n.float)(1).div((0,n.max)(m,.001));return xt({specular:s.mul(h),diffuse:c.mul(h),sheen:l.mul(h),clearcoat:u.mul(h),transmission:d.mul(h),iridescence:(0,n.float)(0)})}),rr=(0,n.Fn)(([e,t,r,i,a,o])=>{let s=(0,n.float)(1).sub(e.roughness),c=(0,n.float)(.5).add((0,n.float)(.5).mul(e.metalness)),l=(0,n.min)((0,n.float)(2).div(e.ior),1),u=(0,n.max)(e.sheenColor.r,(0,n.max)(e.sheenColor.g,e.sheenColor.b)),d=Dt({F0:Gn(e.ior),NoV:(0,n.float)(.5),diffuseColor:e.color.rgb,isPurelyDiffuse:!1,alpha:e.roughness.mul(e.roughness),k:e.roughness.add(1).mul(e.roughness.add(1)).div(8),alpha2:e.roughness.mul(e.roughness).mul(e.roughness).mul(e.roughness),invRoughness:s,metalFactor:c,iorFactor:l,maxSheenColor:u}),f=xt.wrap(nr(e,r,d)),p=f.diffuse.toVar(),m=f.specular.toVar(),h=f.transmission.toVar(),g=f.clearcoat.toVar();(0,n.If)(t.greaterThan((0,n.int)(2)),()=>{let e=(0,n.float)(1).div((0,n.float)(t).sub(1));m.mulAssign((0,n.float)(.8).add(e.mul(.2))),g.mulAssign((0,n.float)(.7).add(e.mul(.3))),p.mulAssign((0,n.float)(1).add(e.mul(.2)))}),(0,n.If)(r.isMetallic.and(t.lessThan((0,n.int)(3))),()=>{m.assign((0,n.max)(m,.6)),p.mulAssign(.4)}),(0,n.If)(r.isTransmissive,()=>{h.assign((0,n.max)(h,.8)),p.mulAssign(.2),m.mulAssign(.6)}),(0,n.If)(r.hasClearcoat,()=>{g.assign((0,n.max)(g,.4))});let _=p.add(m).add(h).add(g).toVar();return(0,n.If)(_.greaterThan(.001),()=>{let e=(0,n.float)(1).div(_);p.mulAssign(e),m.mulAssign(e),h.mulAssign(e),g.mulAssign(e)}).Else(()=>{p.assign(1),m.assign(0),h.assign(0),g.assign(0)}),St({diffuseImportance:p,specularImportance:m,transmissionImportance:h,clearcoatImportance:g,envmapImportance:(0,n.float)(0)})}),ir=(0,n.Fn)(([e,t,r,i,a])=>{let o=(0,n.max)((0,n.dot)(e,t),.001).toVar(),s=a.isRough.and(a.isMetallic.not()).and(r.transmission.equal(0)).and(r.clearcoat.equal(0)).toVar(),c=i.roughness.mul(i.roughness).toVar(),l=c.mul(c).toVar(),u=i.roughness.add(1),d=u.mul(u).div(8).toVar();return Dt({F0:(0,n.mix)(Gn(r.ior).mul(r.specularColor),i.albedo.rgb,i.metalness).mul(r.specularIntensity).toVar(),NoV:o,diffuseColor:i.albedo.rgb.mul((0,n.float)(1).sub(i.metalness)).toVar(),isPurelyDiffuse:s,alpha:c,k:d,alpha2:l,invRoughness:(0,n.float)(1).sub(i.roughness).toVar(),metalFactor:(0,n.float)(.5).add((0,n.float)(.5).mul(i.metalness)).toVar(),iorFactor:(0,n.min)((0,n.float)(2).div(r.ior),1).toVar(),maxSheenColor:(0,n.max)(r.sheenColor.r,(0,n.max)(r.sheenColor.g,r.sheenColor.b)).toVar()})}),ar=(0,n.wgslFn)(`
414
404
  fn ImportanceSampleGGX( N: vec3f, roughness: f32, Xi: vec2f ) -> vec3f {
415
405
  let alpha = roughness * roughness;
416
406
  let phi = 6.28318530717958647692f * Xi.x;
@@ -423,7 +413,7 @@
423
413
  let bitangent = cross( N, tangent );
424
414
  return normalize( tangent * H.x + bitangent * H.y + N * H.z );
425
415
  }
426
- `),gr=(0,n.wgslFn)(`
416
+ `),or=(0,n.wgslFn)(`
427
417
  fn ImportanceSampleCosine( N: vec3f, xi: vec2f ) -> vec3f {
428
418
  let T = normalize( cross( N, N.yzx + vec3f( 0.1f, 0.2f, 0.3f ) ) );
429
419
  let B = cross( N, T );
@@ -433,7 +423,7 @@
433
423
  let localDir = vec3f( sinTheta * cos( phi ), sinTheta * sin( phi ), cosTheta );
434
424
  return normalize( T * localDir.x + B * localDir.y + N * localDir.z );
435
425
  }
436
- `),_r=(0,n.wgslFn)(`
426
+ `),sr=(0,n.wgslFn)(`
437
427
  fn cosineWeightedSample( N: vec3f, xi: vec2f ) -> vec3f {
438
428
  let T = normalize( cross( N, N.yzx + vec3f( 0.1f, 0.2f, 0.3f ) ) );
439
429
  let B = cross( N, T );
@@ -443,7 +433,7 @@
443
433
  let localDir = vec3f( sinTheta * cos( phi ), sinTheta * sin( phi ), cosTheta );
444
434
  return normalize( T * localDir.x + B * localDir.y + N * localDir.z );
445
435
  }
446
- `);(0,n.Fn)(([e])=>(0,n.max)(e,q).mul(Ut));var vr=(0,n.wgslFn)(`
436
+ `),cr=(0,n.wgslFn)(`
447
437
  fn sampleGGXVNDF( V: vec3f, roughness: f32, Xi: vec2f ) -> vec3f {
448
438
  let alpha = roughness * roughness;
449
439
  // Transform view direction to local space
@@ -464,7 +454,7 @@
464
454
  // Transform the normal back to the ellipsoid configuration
465
455
  return normalize( vec3f( alpha * Nh.x, alpha * Nh.y, max( 0.0f, Nh.z ) ) );
466
456
  }
467
- `),yr=(0,n.Fn)(([e,t,r])=>{let i=Lt.wrap(sn(r)),a=(0,n.float)(1).sub(r.roughness),o=(0,n.float)(.5).add((0,n.float)(.5).mul(r.metalness)),s=(0,n.min)((0,n.float)(2).div(r.ior),1),c=(0,n.max)(r.sheenColor.r,(0,n.max)(r.sheenColor.g,r.sheenColor.b)),l=zt({F0:tr(r.ior),NoV:(0,n.float)(.5),diffuseColor:r.color.rgb,isPurelyDiffuse:!1,alpha:r.roughness.mul(r.roughness),k:r.roughness.add(1).mul(r.roughness.add(1)).div(8),alpha2:r.roughness.mul(r.roughness).mul(r.roughness).mul(r.roughness),invRoughness:a,metalFactor:o,iorFactor:s,maxSheenColor:c}),u=BRDFWeights.wrap(fr(r,i,l)),d=(0,n.max)((0,n.dot)(t,e),0),f=(0,n.pow)((0,n.float)(1).sub(d),5),p=u.diffuse.mul(f),m=u.diffuse.sub(p).toVar(),h=u.specular.add(p).toVar(),g=u.clearcoat.toVar(),_=u.transmission.mul(s).toVar(),v=u.sheen.toVar(),y=u.iridescence.toVar(),b=(0,n.max)(m.add(h).add(g).add(_).add(v).add(y),1e-6).toVar(),x=(0,n.float)(1).div(b);return Ht({diffuse:m.mul(x),specular:h.mul(x),clearcoat:g.mul(x),transmission:_.mul(x),sheen:v.mul(x),iridescence:y.mul(x),totalWeight:b})}),br=(0,n.Fn)(([e,t,r,i,a,o])=>{let s=(0,n.float)(0).toVar(),c=(0,n.float)(0).toVar(),l=(0,n.float)(0).toVar(),u=(0,n.float)(0).toVar(),d=(0,n.float)(0).toVar(),f=(0,n.dot)(r,e);(0,n.If)(f.greaterThan(0),()=>{s.assign(f.div(G))});let p=(0,n.normalize)(t.add(e)).toVar(),m=(0,n.max)((0,n.dot)(r,p),0),h=(0,n.max)((0,n.dot)(t,p),0),g=(0,n.max)((0,n.dot)(r,t),0);(0,n.If)(m.greaterThan(0).and(h.greaterThan(0)).and(g.greaterThan(0)),()=>{c.assign(cr(m,h,i.roughness)),(0,n.If)(i.clearcoat.greaterThan(0),()=>{l.assign(cr(m,h,i.clearcoatRoughness))})}),(0,n.If)(i.transmission.greaterThan(0).and(f.lessThan(0)),()=>{u.assign((0,n.abs)(f).div(G))}),(0,n.If)(i.sheen.greaterThan(0).and(f.greaterThan(0)),()=>{d.assign(f.div(G))});let _=a.diffuse.mul(s),v=a.specular.mul(c),y=a.clearcoat.mul(l),b=a.transmission.mul(u),x=a.sheen.mul(d),S=a.iridescence.mul(s),C=_.mul(_).add(v.mul(v)).add(y.mul(y)).add(b.mul(b)).add(x.mul(x)).add(S.mul(S)),w=(0,n.float)(1).toVar();return(0,n.If)(C.greaterThan(0).and(o.greaterThan(0)),()=>{let e=o.mul(o);w.assign(e.div(C))}),w});(0,n.Fn)(([e,t,r,i,a,o])=>{let s=yr(e,t,r),c=P(a),l=s.diffuse,u=l.add(s.specular),d=u.add(s.clearcoat),f=d.add(s.transmission),p=(0,n.vec3)(0).toVar(),m=(0,n.float)(0).toVar(),h=(0,n.float)(0).toVar();(0,n.If)(c.lessThan(l),()=>{p.assign(gr({N:t,xi:i})),m.assign((0,n.max)((0,n.dot)(t,p),0).div(G)),h.assign(m.mul(s.diffuse))}).ElseIf(c.lessThan(u),()=>{let a=hr({N:t,roughness:r.roughness,Xi:i}).toVar();p.assign((0,n.reflect)(e.negate(),a)),(0,n.If)((0,n.dot)(t,p).greaterThan(0),()=>{let i=(0,n.max)((0,n.dot)(t,a),0),o=(0,n.max)((0,n.dot)(e,a),0);m.assign(cr(i,o,r.roughness))}),h.assign(m.mul(s.specular))}).ElseIf(c.lessThan(d).and(r.clearcoat.greaterThan(0)),()=>{let a=hr({N:t,roughness:r.clearcoatRoughness,Xi:i}).toVar();p.assign((0,n.reflect)(e.negate(),a)),(0,n.If)((0,n.dot)(t,p).greaterThan(0),()=>{let i=(0,n.max)((0,n.dot)(t,a),0),o=(0,n.max)((0,n.dot)(e,a),0);m.assign(cr(i,o,r.clearcoatRoughness))}),h.assign(m.mul(s.clearcoat))}).ElseIf(c.lessThan(f).and(r.transmission.greaterThan(0)),()=>{let a=hr({N:t,roughness:r.roughness,Xi:i}).toVar(),o=(0,n.refract)(e.negate(),a,(0,n.float)(1).div(r.ior)).toVar();(0,n.If)((0,n.dot)(o,o).greaterThan(.001),()=>{p.assign((0,n.normalize)(o));let i=(0,n.max)((0,n.dot)(t,a),0),s=(0,n.max)((0,n.dot)(e,a),0);m.assign(cr(i,s,r.roughness))}).Else(()=>{p.assign((0,n.reflect)(e.negate(),a)),m.assign(.1)}),h.assign(m.mul(s.transmission))}).Else(()=>{p.assign(gr({N:t,xi:i})),m.assign((0,n.max)((0,n.dot)(t,p),0).div(G)),h.assign(m.mul(s.sheen.add(s.iridescence)))});let g=br(p,e,t,r,s,h),_=o(e,p,t,r).toVar();return _.mulAssign(g),Mt({direction:p,value:_,pdf:h})});var xr=D({direction:`vec3`,throughput:`vec3`,didReflect:`bool`}),Sr=D({continueRay:`bool`,isTransmissive:`bool`,isAlphaSkip:`bool`,didReflect:`bool`,entering:`bool`,direction:`vec3`,throughput:`vec3`,alpha:`float`});D({ior:`float`,attenuationColor:`vec3`,attenuationDistance:`float`,dispersion:`float`});var Cr=D({wavelength:`float`,ior:`float`,colorWeight:`vec3`}),wr=D({direction:`vec3`,halfVector:`vec3`,didReflect:`bool`,pdf:`float`});D({m0_ior:`float`,m0_attenuationColor:`vec3`,m0_attenuationDistance:`float`,m0_dispersion:`float`,m1_ior:`float`,m1_attenuationColor:`vec3`,m1_attenuationDistance:`float`,m1_dispersion:`float`,m2_ior:`float`,m2_attenuationColor:`vec3`,m2_attenuationDistance:`float`,m2_dispersion:`float`,m3_ior:`float`,m3_attenuationColor:`vec3`,m3_attenuationDistance:`float`,m3_dispersion:`float`,depth:`int`}),(0,n.Fn)(([e])=>{let t=(0,n.float)(1).toVar();return(0,n.If)(e.depth.greaterThan((0,n.int)(0)),()=>{(0,n.If)(e.depth.equal((0,n.int)(1)),()=>{t.assign(e.m1_ior)}),(0,n.If)(e.depth.equal((0,n.int)(2)),()=>{t.assign(e.m2_ior)}),(0,n.If)(e.depth.equal((0,n.int)(3)),()=>{t.assign(e.m3_ior)})}),t});var Tr=(0,n.Fn)(([e,t,r])=>{let i=(0,n.mix)((0,n.float)(380),(0,n.float)(700),r).toVar(),a=i.div(1e3),o=e,s=t.mul(.03),c=o.add(s.div(a.mul(a))).toVar(),l=(0,n.vec3)(0).toVar();return(0,n.If)(i.greaterThanEqual(380).and(i.lessThan(420)),()=>{l.assign((0,n.vec3)(.9,0,1))}),(0,n.If)(i.greaterThanEqual(420).and(i.lessThan(480)),()=>{l.assign((0,n.vec3)(0,0,1))}),(0,n.If)(i.greaterThanEqual(480).and(i.lessThan(500)),()=>{l.assign((0,n.vec3)(0,1,1))}),(0,n.If)(i.greaterThanEqual(500).and(i.lessThan(530)),()=>{l.assign((0,n.vec3)(0,1,0))}),(0,n.If)(i.greaterThanEqual(530).and(i.lessThan(570)),()=>{l.assign((0,n.vec3)(1,1,0))}),(0,n.If)(i.greaterThanEqual(570).and(i.lessThan(620)),()=>{l.assign((0,n.vec3)(1,.5,0))}),(0,n.If)(i.greaterThanEqual(620).and(i.lessThanEqual(700)),()=>{l.assign((0,n.vec3)(1,0,0))}),l.assign((0,n.pow)(l,(0,n.vec3)(.4))),l.assign((0,n.clamp)(l,(0,n.vec3)(0),(0,n.vec3)(2))),Cr({wavelength:i,ior:c,colorWeight:l})}),Er=(0,n.wgslFn)(`
457
+ `),lr=y({direction:`vec3`,throughput:`vec3`,didReflect:`bool`}),ur=y({continueRay:`bool`,isTransmissive:`bool`,isAlphaSkip:`bool`,didReflect:`bool`,entering:`bool`,direction:`vec3`,throughput:`vec3`,alpha:`float`});y({ior:`float`,attenuationColor:`vec3`,attenuationDistance:`float`,dispersion:`float`});var dr=y({wavelength:`float`,ior:`float`,colorWeight:`vec3`}),fr=y({direction:`vec3`,halfVector:`vec3`,didReflect:`bool`,pdf:`float`});y({m0_ior:`float`,m0_attenuationColor:`vec3`,m0_attenuationDistance:`float`,m0_dispersion:`float`,m1_ior:`float`,m1_attenuationColor:`vec3`,m1_attenuationDistance:`float`,m1_dispersion:`float`,m2_ior:`float`,m2_attenuationColor:`vec3`,m2_attenuationDistance:`float`,m2_dispersion:`float`,m3_ior:`float`,m3_attenuationColor:`vec3`,m3_attenuationDistance:`float`,m3_dispersion:`float`,depth:`int`});var pr=(0,n.Fn)(([e,t,r])=>{let i=(0,n.mix)((0,n.float)(380),(0,n.float)(700),r).toVar(),a=i.div(1e3),o=e,s=t.mul(.03),c=o.add(s.div(a.mul(a))).toVar(),l=(0,n.vec3)(0).toVar();return(0,n.If)(i.greaterThanEqual(380).and(i.lessThan(420)),()=>{l.assign((0,n.vec3)(.9,0,1))}),(0,n.If)(i.greaterThanEqual(420).and(i.lessThan(480)),()=>{l.assign((0,n.vec3)(0,0,1))}),(0,n.If)(i.greaterThanEqual(480).and(i.lessThan(500)),()=>{l.assign((0,n.vec3)(0,1,1))}),(0,n.If)(i.greaterThanEqual(500).and(i.lessThan(530)),()=>{l.assign((0,n.vec3)(0,1,0))}),(0,n.If)(i.greaterThanEqual(530).and(i.lessThan(570)),()=>{l.assign((0,n.vec3)(1,1,0))}),(0,n.If)(i.greaterThanEqual(570).and(i.lessThan(620)),()=>{l.assign((0,n.vec3)(1,.5,0))}),(0,n.If)(i.greaterThanEqual(620).and(i.lessThanEqual(700)),()=>{l.assign((0,n.vec3)(1,0,0))}),l.assign((0,n.pow)(l,(0,n.vec3)(.4))),l.assign((0,n.clamp)(l,(0,n.vec3)(0),(0,n.vec3)(2))),dr({wavelength:i,ior:c,colorWeight:l})}),mr=(0,n.wgslFn)(`
468
458
  fn calculateBeerLawAbsorption( attenuationColor: vec3f, attenuationDistance: f32, thickness: f32 ) -> vec3f {
469
459
  if ( attenuationDistance <= 0.0f ) { return vec3f( 1.0f ); }
470
460
  // Convert RGB attenuation color to absorption coefficients
@@ -472,11 +462,11 @@
472
462
  // Apply Beer's law
473
463
  return exp( -absorption * thickness );
474
464
  }
475
- `),Dr=(0,n.Fn)(([e,t,r,i])=>{let a=(0,n.select)(i,(0,n.float)(1),r.ior).toVar(),o=(0,n.select)(i,r.ior,(0,n.float)(1)).toVar(),s=(0,n.abs)((0,n.dot)(t,e)),c=a.mul(a).div(o.mul(o)).mul((0,n.float)(1).sub(s.mul(s))),l=(0,n.float)(0).toVar();return(0,n.If)(c.lessThanEqual(1),()=>{let e=Xn(s,er(o,a)),t=(0,n.float)(1).sub(e).mul(r.transmission).toVar();(0,n.If)(i.not().and(r.attenuationDistance.greaterThan(0)),()=>{let e=Er({attenuationColor:r.attenuationColor,attenuationDistance:r.attenuationDistance,thickness:r.thickness});t.assign(t.mul(e.x.add(e.y).add(e.z).div(3)))}),l.assign((0,n.clamp)(t,0,1))}),l}),Or=(0,n.Fn)(([e,t,r,i,a,o,s,c])=>{let l=wr({direction:(0,n.vec3)(0),halfVector:(0,n.vec3)(0),didReflect:!1,pdf:(0,n.float)(0)}).toVar();return(0,n.If)(i.lessThanEqual(.05).and(o.greaterThan(0)),()=>{l.halfVector.assign(t),l.didReflect.assign(!1);let i=r,s=(0,n.select)(a,(0,n.float)(1).div(i),i).toVar(),u=Cr.wrap(Tr(r,o,P(c)));s.assign((0,n.select)(a,(0,n.float)(1).div(u.ior),u.ior));let d=(0,n.refract)(e.negate(),t,s).toVar();(0,n.If)((0,n.dot)(d,d).lessThan(.001),()=>{l.direction.assign((0,n.reflect)(e.negate(),t)),l.didReflect.assign(!0),l.pdf.assign(1)}).Else(()=>{l.direction.assign(d),l.pdf.assign(1)})}).Else(()=>{let u=(0,n.max)(Gt,i),d=hr({N:t,roughness:u,Xi:s}).toVar();l.halfVector.assign(d);let f=(0,n.select)(a,(0,n.float)(1).div(r),r).toVar();(0,n.If)(o.greaterThan(0),()=>{let e=Cr.wrap(Tr(r,o,P(c)));f.assign((0,n.select)(a,(0,n.float)(1).div(e.ior),e.ior))});let p=(0,n.clamp)((0,n.dot)(d,e),.001,1),m=(0,n.refract)(e.negate(),d,f).toVar();(0,n.If)((0,n.dot)(m,m).lessThan(.001),()=>{l.direction.assign((0,n.reflect)(e.negate(),d)),l.didReflect.assign(!0);let r=(0,n.clamp)((0,n.dot)(t,d),.001,1),i=(0,n.clamp)((0,n.dot)(e,d),.001,1);l.pdf.assign(cr(r,i,u))}).Else(()=>{l.direction.assign(m),l.didReflect.assign(!1);let e=(0,n.clamp)((0,n.dot)(t,d),.001,1),r=(0,n.clamp)((0,n.dot)(d,m),.001,1),i=nr(e,u),a=p.add(f.mul(r)),o=(0,n.abs)(r).div(a.mul(a));l.pdf.assign(i.mul(e).mul(o))})}),l}),kr=(0,n.Fn)(([e,t,r,i,a,o,s])=>{let c=xr({direction:(0,n.vec3)(0),throughput:(0,n.vec3)(1),didReflect:!1}).toVar(),l=(0,n.select)(i,t,t.negate()).toVar(),u=e.negate().toVar(),d=(0,n.select)(i,o,r.ior).toVar(),f=(0,n.select)(i,r.ior,s).toVar(),p=(0,n.abs)((0,n.dot)(l,e)),m=d.mul(d).div(f.mul(f)).mul((0,n.float)(1).sub(p.mul(p))).greaterThan(1).toVar(),h=er(f,d),g=(0,n.select)(m,(0,n.float)(1),Xn(p,h)).toVar(),_=(0,n.float)(0).toVar();(0,n.If)(m,()=>{_.assign(1)}).Else(()=>{let e=(0,n.mix)(g,(0,n.float)(.95),r.metalness).toVar();_.assign(e)}),_.assign((0,n.clamp)(_,.05,.95));let v=m.or(P(a).lessThan(_)).toVar();c.didReflect.assign(v);let y=(0,n.vec2)(P(a).toVar(),P(a).toVar());return(0,n.If)(v,()=>{(0,n.If)(r.roughness.greaterThan(.05),()=>{let e=wr.wrap(Or(u,l,r.ior,r.roughness,i,(0,n.float)(0),y,a));c.direction.assign(e.direction)}).Else(()=>{c.direction.assign((0,n.reflect)(e,l))}),c.throughput.assign(r.color.xyz.mul(g).div((0,n.max)(_,.05)))}).Else(()=>{(0,n.If)(r.roughness.greaterThan(.05).or(r.dispersion.greaterThan(0)),()=>{let t=wr.wrap(Or(u,l,r.ior,r.roughness,i,r.dispersion,y,a));(0,n.If)(t.didReflect,()=>{c.direction.assign(t.direction),c.didReflect.assign(!0),c.throughput.assign(r.color.xyz.div((0,n.max)((0,n.float)(1).sub(_),.05)))}).Else(()=>{c.direction.assign(t.direction),(0,n.If)(r.dispersion.greaterThan(0),()=>{let t=(0,n.normalize)(e),i=(0,n.normalize)(c.direction),a=(0,n.float)(1).sub((0,n.abs)((0,n.dot)(l,t))),o=(0,n.acos)((0,n.clamp)((0,n.dot)(t,i),-1,1)),s=(0,n.normalize)(t.add(l)),u=(0,n.sin)(s.x.mul(15)).mul((0,n.cos)(s.y.mul(12))).mul((0,n.sin)(s.z.mul(18))),d=(0,n.sin)(i.x.mul(8).add(i.y.mul(6)).add(i.z.mul(10))),f=o.mul(r.dispersion).mul(3),p=u.mul(.3),m=d.mul(.2),h=a.mul(.4),g=(0,n.fract)(f.add(p).add(m).add(h)).toVar(),_=(0,n.vec3)(0).toVar();(0,n.If)(g.lessThan(.143),()=>{let e=g.div(.143);_.assign((0,n.mix)((0,n.vec3)(.8,0,0),(0,n.vec3)(1,0,0),e))}),(0,n.If)(g.greaterThanEqual(.143).and(g.lessThan(.286)),()=>{let e=g.sub(.143).div(.143);_.assign((0,n.mix)((0,n.vec3)(1,0,0),(0,n.vec3)(1,.6,0),e))}),(0,n.If)(g.greaterThanEqual(.286).and(g.lessThan(.429)),()=>{let e=g.sub(.286).div(.143);_.assign((0,n.mix)((0,n.vec3)(1,.6,0),(0,n.vec3)(1,1,0),e))}),(0,n.If)(g.greaterThanEqual(.429).and(g.lessThan(.571)),()=>{let e=g.sub(.429).div(.142);_.assign((0,n.mix)((0,n.vec3)(1,1,0),(0,n.vec3)(0,1,0),e))}),(0,n.If)(g.greaterThanEqual(.571).and(g.lessThan(.714)),()=>{let e=g.sub(.571).div(.143);_.assign((0,n.mix)((0,n.vec3)(0,1,0),(0,n.vec3)(0,.4,1),e))}),(0,n.If)(g.greaterThanEqual(.714).and(g.lessThan(.857)),()=>{let e=g.sub(.714).div(.143);_.assign((0,n.mix)((0,n.vec3)(0,.4,1),(0,n.vec3)(.3,0,.8),e))}),(0,n.If)(g.greaterThanEqual(.857),()=>{let e=g.sub(.857).div(.143);_.assign((0,n.mix)((0,n.vec3)(.3,0,.8),(0,n.vec3)(.6,0,1),e))});let v=(0,n.clamp)(r.dispersion.div(5),0,1),y=(0,n.float)(1).add(a.mul(1.5)),b=v.mul(y),x=u.add(d),S=(0,n.float)(.5).add((0,n.float)(.5).mul((0,n.sin)(x.mul(3.14159)))),C=(0,n.clamp)(b.mul(S),0,.8);c.throughput.assign((0,n.mix)((0,n.vec3)(1),_,C))}).Else(()=>{c.throughput.assign((0,n.vec3)(1))})})}).Else(()=>{c.direction.assign((0,n.refract)(e,l,d.div(f))),c.throughput.assign((0,n.vec3)(1))}),(0,n.If)(c.didReflect.not(),()=>{c.throughput.mulAssign(r.color.xyz),c.throughput.mulAssign(d.mul(d).div((0,n.max)(f.mul(f),K))),(0,n.If)(i.and(r.attenuationDistance.greaterThan(0)),()=>{c.throughput.mulAssign(Er({attenuationColor:r.attenuationColor,attenuationDistance:r.attenuationDistance,thickness:r.thickness}))}),c.throughput.mulAssign((0,n.float)(1).sub(g).div((0,n.max)((0,n.float)(1).sub(_),.05)))})}),c}),Ar=(0,n.Fn)(([e,t,r,i,a,o,s,c])=>{let l=Sr({continueRay:!1,isTransmissive:!1,isAlphaSkip:!1,didReflect:!1,entering:!1,direction:e.direction,throughput:(0,n.vec3)(1),alpha:(0,n.float)(1)}).toVar();return(0,n.If)(i.alphaMode.equal((0,n.int)(0)).and(i.transmission.lessThanEqual(0)),()=>{}).Else(()=>{let t=P(a),u=P(a),d=ae({state:a}),f=(0,n.bool)(!1).toVar();(0,n.If)(i.alphaMode.equal((0,n.int)(2)),()=>{let r=i.color.a.mul(i.opacity);(0,n.If)(t.greaterThan(r),()=>{l.continueRay.assign(!0),l.direction.assign(e.direction),l.throughput.assign((0,n.vec3)(1)),l.alpha.assign(0),l.isAlphaSkip.assign(!0),f.assign(!0)}).Else(()=>{l.alpha.assign(r)})}),(0,n.If)(f.not().and(i.alphaMode.equal((0,n.int)(1))),()=>{let t=(0,n.select)(i.alphaTest.greaterThan(0),i.alphaTest,(0,n.float)(.5));(0,n.If)(i.color.a.lessThan(t),()=>{l.continueRay.assign(!0),l.direction.assign(e.direction),l.throughput.assign((0,n.vec3)(1)),l.alpha.assign(0),l.isAlphaSkip.assign(!0),f.assign(!0)}).Else(()=>{l.alpha.assign(1)})}),(0,n.If)(f.not().and(i.transmission.greaterThan(0)).and(o.greaterThan((0,n.int)(0))),()=>{(0,n.If)(u.lessThan(i.transmission),()=>{let t=(0,n.dot)(e.direction,r).lessThan(0),a=xr.wrap(kr(e.direction,r,i,t,d,s,c));l.direction.assign(a.direction),l.throughput.assign(a.throughput),l.continueRay.assign(!0),l.isTransmissive.assign(!0),l.didReflect.assign(a.didReflect),l.entering.assign(t),l.alpha.assign((0,n.float)(1).sub(i.transmission))})})}),l}),jr=(0,n.Fn)(([e,t,r,i])=>{let a=(0,n.vec3)(0).toVar();return(0,n.If)(i.roughness.greaterThan(.98).and(i.metalness.lessThan(.02)).and(i.transmission.equal(0)).and(i.clearcoat.equal(0)).and(i.iridescence.equal(0)),()=>{a.assign(i.color.rgb.mul((0,n.float)(1).sub(i.metalness)).mul(Ut))}).Else(()=>{let o=Ft.wrap(nn(r,e,t)),s=(0,n.clamp)((0,n.mix)(tr(i.ior).mul(i.specularColor),i.color.rgb,i.metalness).mul(i.specularIntensity),(0,n.vec3)(0),(0,n.vec3)(1)).toVar(),c=i.color.rgb.toVar();(0,n.If)(i.dispersion.greaterThan(0).and(i.transmission.greaterThan(.5)),()=>{let e=(0,n.clamp)(i.dispersion.mul(.1),0,.8),t=(0,n.max)((0,n.max)(c.r,c.g),c.b),r=(0,n.min)((0,n.min)(c.r,c.g),c.b);(0,n.If)(t.greaterThan(r),()=>{let i=c.sub(r).div(t.sub(r));c.assign((0,n.mix)(c,i,e.mul(.3)))})}),(0,n.If)(i.iridescence.greaterThan(0),()=>{let e=i.iridescenceThicknessRange.y,t=dr((0,n.float)(1),i.iridescenceIOR,o.VoH,e,s);s.assign((0,n.mix)(s,t,i.iridescence))});let l=nr(o.NoH,i.roughness),u=ar(o.NoV,o.NoL,i.roughness),d=Zn(o.VoH,s).toVar(),f=l.mul(u).mul(d).div((0,n.max)((0,n.float)(4).mul(o.NoV).mul(o.NoL),K)).mul(or(s,o.NoV,i.roughness)),p=sr(s,o.NoV,i.roughness),m=(0,n.vec3)(1).sub(p).mul((0,n.float)(1).sub(i.metalness)).mul(c).mul(Ut).add(f).toVar();(0,n.If)(i.sheen.greaterThan(0),()=>{let e=rr(o.NoH,i.sheenRoughness),t=i.sheenColor.mul(i.sheen).mul(e).mul(o.NoL),r=(0,n.float)(1).sub(i.sheenRoughness).mul(.5).add(.25),s=(0,n.clamp)(i.sheenColor.mul(i.sheen).mul(r),(0,n.vec3)(0),(0,n.vec3)(1)),c=(0,n.vec3)(1).sub(s);a.assign(m.mul(c).add(t))}).Else(()=>{a.assign(m)})}),a});(0,n.Fn)(([e,t,r,i,a])=>{let o=(0,n.vec3)(0).toVar();return(0,n.If)(a.isPurelyDiffuse,()=>{o.assign(a.diffuseColor)}).Else(()=>{let s=e.add(t).toVar(),c=(0,n.dot)(s,s);s.assign(c.greaterThan(K).select(s.div((0,n.sqrt)(c)),(0,n.vec3)(0,0,1)));let l=(0,n.max)((0,n.dot)(r,t),K),u=(0,n.max)((0,n.dot)(r,s),K),d=(0,n.max)((0,n.dot)(e,s),K);(0,n.If)(a.NoV.mul(l).lessThan(0).and(i.transmission.greaterThan(0)),()=>{o.assign(jr(e,t,r,i))}).Else(()=>{let e=a.F0.toVar();(0,n.If)(i.iridescence.greaterThan(0),()=>{let t=i.iridescenceThicknessRange.y,r=dr((0,n.float)(1),i.iridescenceIOR,d,t,e);e.assign((0,n.clamp)((0,n.mix)(e,r,i.iridescence),(0,n.vec3)(0),(0,n.vec3)(1)))});let t=u.mul(u).mul(a.alpha2.sub(1)).add(1),r=a.alpha2.div((0,n.max)((0,n.float)(G).mul(t).mul(t),K)),s=l.div(l.mul((0,n.float)(1).sub(a.k)).add(a.k)),c=a.NoV.div(a.NoV.mul((0,n.float)(1).sub(a.k)).add(a.k)),f=s.mul(c),p=Zn(d,e).toVar(),m=(0,n.max)((0,n.float)(4).mul(a.NoV).mul(l),K),h=r.mul(f).mul(p).div(m).mul(or(e,a.NoV,i.roughness)),g=sr(e,a.NoV,i.roughness),_=(0,n.vec3)(1).sub(g).mul((0,n.float)(1).sub(i.metalness)).mul(i.color.rgb).mul(Ut).add(h).toVar();(0,n.If)(i.sheen.greaterThan(0),()=>{let e=rr(u,i.sheenRoughness),t=i.sheenColor.mul(i.sheen).mul(e).mul(l),r=(0,n.float)(1).sub(i.sheenRoughness).mul(.5).add(.25),a=(0,n.clamp)(i.sheenColor.mul(i.sheen).mul(r),(0,n.vec3)(0),(0,n.vec3)(1)),s=(0,n.vec3)(1).sub(a);o.assign(_.mul(s).add(t))}).Else(()=>{o.assign(_)})})}),o}),(0,n.Fn)(([e,t])=>{let r=Xn(t,(0,n.float)(.04));return(0,n.float)(1).sub(e.mul(r).mul((0,n.float)(2).sub(r)))});var Mr=(0,n.Fn)(([e,t])=>{let r=(0,n.clamp)((0,n.mix)(tr(t.ior).mul(t.specularColor),t.color.rgb,t.metalness).mul(t.specularIntensity),(0,n.vec3)(0),(0,n.vec3)(1)).toVar(),i=nr(e.NoH,t.roughness),a=ar(e.NoV,e.NoL,t.roughness),o=Zn(e.VoH,r).toVar(),s=i.mul(a).mul(o).div((0,n.max)((0,n.float)(4).mul(e.NoV).mul(e.NoL),K)).mul(or(r,e.NoV,t.roughness)),c=sr(r,e.NoV,t.roughness),l=(0,n.vec3)(1).sub(c).mul((0,n.float)(1).sub(t.metalness)).mul(t.color.rgb).div(G).add(s),u=(0,n.max)(t.clearcoatRoughness,Kt),d=nr(e.NoH,u),f=ar(e.NoV,e.NoL,u),p=Xn(e.VoH,(0,n.float)(.04)),m=d.mul(f).mul(p).div((0,n.max)((0,n.float)(4).mul(e.NoV).mul(e.NoL),K)),h=(0,n.float)(1).sub(t.clearcoat.mul(p).mul((0,n.float)(2).sub(p)));return l.mul(h).add((0,n.vec3)(m).mul(t.clearcoat))}),Nr=D({brdf:`vec3`,L:`vec3`,pdf:`float`}),Pr=(0,n.Fn)(([e,t,r,i,a])=>{let o=t.normal,s=e.direction.negate(),c=(0,n.max)(r.clearcoatRoughness,Kt),l=(0,n.max)(r.roughness,Kt),u=(0,n.float)(1).sub(l).mul((0,n.float)(.5).add((0,n.float)(.5).mul(r.metalness))).toVar(),d=r.clearcoat.mul((0,n.float)(1).sub(c)).toVar(),f=(0,n.float)(1).sub(u).mul((0,n.float)(1).sub(r.metalness)).toVar(),p=u.add(d).add(f);u.divAssign(p),d.divAssign(p),f.divAssign(p);let m=P(a),h=(0,n.vec3)(0).toVar(),g=(0,n.vec3)(0).toVar();(0,n.If)(m.lessThan(d),()=>{g.assign(hr({N:o,roughness:c,Xi:i})),h.assign((0,n.reflect)(s.negate(),g))}).ElseIf(m.lessThan(d.add(u)),()=>{g.assign(hr({N:o,roughness:l,Xi:i})),h.assign((0,n.reflect)(s.negate(),g))}).Else(()=>{h.assign(gr({N:o,xi:i})),g.assign((0,n.normalize)(s.add(h)))});let _=Ft.wrap(nn(o,s,h)),v=nr(_.NoH,c).mul(_.NoH).div((0,n.float)(4).mul(_.VoH)).mul(d),y=nr(_.NoH,l).mul(_.NoH).div((0,n.float)(4).mul(_.VoH)).mul(u),b=_.NoL.div(G).mul(f),x=(0,n.max)(v.add(y).add(b),.001);return Nr({brdf:Mr(_,r),L:h,pdf:x})}),Fr=D({direction:`vec3`,color:`vec3`,intensity:`float`,angle:`float`}),Ir=D({position:`vec3`,u:`vec3`,v:`vec3`,color:`vec3`,intensity:`float`,normal:`vec3`,area:`float`}),Lr=D({position:`vec3`,color:`vec3`,intensity:`float`,distance:`float`,decay:`float`}),Rr=D({position:`vec3`,direction:`vec3`,color:`vec3`,intensity:`float`,angle:`float`,penumbra:`float`,distance:`float`,decay:`float`}),zr=D({direction:`vec3`,emission:`vec3`,pdf:`float`,distance:`float`,lightType:`int`,valid:`bool`}),Br=D({direction:`vec3`,throughput:`vec3`,misWeight:`float`,pdf:`float`,combinedPdf:`float`}),Vr=(0,n.Fn)(([e,t])=>{let r=t.mul(8);return Fr({direction:(0,n.normalize)((0,n.vec3)(e.element(r),e.element(r.add(1)),e.element(r.add(2)))),color:(0,n.vec3)(e.element(r.add(3)),e.element(r.add(4)),e.element(r.add(5))),intensity:e.element(r.add(6)),angle:e.element(r.add(7))})}),Hr=(0,n.Fn)(([e,t])=>{let r=t.mul(13),i=(0,n.vec3)(e.element(r.add(3)),e.element(r.add(4)),e.element(r.add(5))).toVar(),a=(0,n.vec3)(e.element(r.add(6)),e.element(r.add(7)),e.element(r.add(8))).toVar(),o=(0,n.cross)(i,a);return Ir({position:(0,n.vec3)(e.element(r),e.element(r.add(1)),e.element(r.add(2))),u:i,v:a,color:(0,n.vec3)(e.element(r.add(9)),e.element(r.add(10)),e.element(r.add(11))),intensity:e.element(r.add(12)),normal:(0,n.normalize)(o),area:(0,n.length)(o).mul(4)})}),Ur=(0,n.Fn)(([e,t])=>{let r=t.mul(9);return Lr({position:(0,n.vec3)(e.element(r),e.element(r.add(1)),e.element(r.add(2))),color:(0,n.vec3)(e.element(r.add(3)),e.element(r.add(4)),e.element(r.add(5))),intensity:e.element(r.add(6)),distance:e.element(r.add(7)),decay:e.element(r.add(8))})}),Wr=(0,n.Fn)(([e,t])=>{let r=t.mul(14);return Rr({position:(0,n.vec3)(e.element(r),e.element(r.add(1)),e.element(r.add(2))),direction:(0,n.normalize)((0,n.vec3)(e.element(r.add(3)),e.element(r.add(4)),e.element(r.add(5)))),color:(0,n.vec3)(e.element(r.add(6)),e.element(r.add(7)),e.element(r.add(8))),intensity:e.element(r.add(9)),angle:e.element(r.add(10)),penumbra:e.element(r.add(11)),distance:e.element(r.add(12)),decay:e.element(r.add(13))})}),Gr=(0,n.wgslFn)(`
465
+ `);(0,n.Fn)(([e,t,r,i])=>{let a=(0,n.select)(i,(0,n.float)(1),r.ior).toVar(),o=(0,n.select)(i,r.ior,(0,n.float)(1)).toVar(),s=(0,n.abs)((0,n.dot)(t,e)),c=a.mul(a).div(o.mul(o)).mul((0,n.float)(1).sub(s.mul(s))),l=(0,n.float)(0).toVar();return(0,n.If)(c.lessThanEqual(1),()=>{let e=Bn(s,Wn(o,a)),t=(0,n.float)(1).sub(e).mul(r.transmission).toVar();(0,n.If)(i.not().and(r.attenuationDistance.greaterThan(0)),()=>{let e=mr({attenuationColor:r.attenuationColor,attenuationDistance:r.attenuationDistance,thickness:r.thickness});t.assign(t.mul(e.x.add(e.y).add(e.z).div(3)))}),l.assign((0,n.clamp)(t,0,1))}),l});var hr=(0,n.Fn)(([e,t,r,i,a,o,s,c])=>{let l=fr({direction:(0,n.vec3)(0),halfVector:(0,n.vec3)(0),didReflect:!1,pdf:(0,n.float)(0)}).toVar();return(0,n.If)(i.lessThanEqual(.05).and(o.greaterThan(0)),()=>{l.halfVector.assign(t),l.didReflect.assign(!1);let i=r,s=(0,n.select)(a,(0,n.float)(1).div(i),i).toVar(),u=dr.wrap(pr(r,o,N(c)));s.assign((0,n.select)(a,(0,n.float)(1).div(u.ior),u.ior));let d=(0,n.refract)(e.negate(),t,s).toVar();(0,n.If)((0,n.dot)(d,d).lessThan(.001),()=>{l.direction.assign((0,n.reflect)(e.negate(),t)),l.didReflect.assign(!0),l.pdf.assign(1)}).Else(()=>{l.direction.assign(d),l.pdf.assign(1)})}).Else(()=>{let u=(0,n.max)(Pt,i),d=ar({N:t,roughness:u,Xi:s}).toVar();l.halfVector.assign(d);let f=(0,n.select)(a,(0,n.float)(1).div(r),r).toVar();(0,n.If)(o.greaterThan(0),()=>{let e=dr.wrap(pr(r,o,N(c)));f.assign((0,n.select)(a,(0,n.float)(1).div(e.ior),e.ior))});let p=(0,n.clamp)((0,n.dot)(d,e),.001,1),m=(0,n.refract)(e.negate(),d,f).toVar();(0,n.If)((0,n.dot)(m,m).lessThan(.001),()=>{l.direction.assign((0,n.reflect)(e.negate(),d)),l.didReflect.assign(!0);let r=(0,n.clamp)((0,n.dot)(t,d),.001,1),i=(0,n.clamp)((0,n.dot)(e,d),.001,1);l.pdf.assign(Qn(r,i,u))}).Else(()=>{l.direction.assign(m),l.didReflect.assign(!1);let e=(0,n.clamp)((0,n.dot)(t,d),.001,1),r=(0,n.clamp)((0,n.dot)(d,m),.001,1),i=Kn(e,u),a=p.add(f.mul(r)),o=(0,n.abs)(r).div(a.mul(a));l.pdf.assign(i.mul(e).mul(o))})}),l}),gr=(0,n.Fn)(([e,t,r,i,a,o,s])=>{let c=lr({direction:(0,n.vec3)(0),throughput:(0,n.vec3)(1),didReflect:!1}).toVar(),l=(0,n.select)(i,t,t.negate()).toVar(),u=e.negate().toVar(),d=(0,n.select)(i,o,r.ior).toVar(),f=(0,n.select)(i,r.ior,s).toVar(),p=(0,n.abs)((0,n.dot)(l,e)),m=d.mul(d).div(f.mul(f)).mul((0,n.float)(1).sub(p.mul(p))).greaterThan(1).toVar(),h=Wn(f,d),g=(0,n.select)(m,(0,n.float)(1),Bn(p,h)).toVar(),_=(0,n.float)(0).toVar();(0,n.If)(m,()=>{_.assign(1)}).Else(()=>{let e=(0,n.mix)(g,(0,n.float)(.95),r.metalness).toVar();_.assign(e)}),_.assign((0,n.clamp)(_,.05,.95));let v=m.or(N(a).lessThan(_)).toVar();c.didReflect.assign(v);let y=(0,n.vec2)(N(a).toVar(),N(a).toVar());return(0,n.If)(v,()=>{(0,n.If)(r.roughness.greaterThan(.05),()=>{let e=fr.wrap(hr(u,l,r.ior,r.roughness,i,(0,n.float)(0),y,a));c.direction.assign(e.direction)}).Else(()=>{c.direction.assign((0,n.reflect)(e,l))}),c.throughput.assign(r.color.xyz.mul(g).div((0,n.max)(_,.05)))}).Else(()=>{(0,n.If)(r.roughness.greaterThan(.05).or(r.dispersion.greaterThan(0)),()=>{let t=fr.wrap(hr(u,l,r.ior,r.roughness,i,r.dispersion,y,a));(0,n.If)(t.didReflect,()=>{c.direction.assign(t.direction),c.didReflect.assign(!0),c.throughput.assign(r.color.xyz.div((0,n.max)((0,n.float)(1).sub(_),.05)))}).Else(()=>{c.direction.assign(t.direction),(0,n.If)(r.dispersion.greaterThan(0),()=>{let t=(0,n.normalize)(e),i=(0,n.normalize)(c.direction),a=(0,n.float)(1).sub((0,n.abs)((0,n.dot)(l,t))),o=(0,n.acos)((0,n.clamp)((0,n.dot)(t,i),-1,1)),s=(0,n.normalize)(t.add(l)),u=(0,n.sin)(s.x.mul(15)).mul((0,n.cos)(s.y.mul(12))).mul((0,n.sin)(s.z.mul(18))),d=(0,n.sin)(i.x.mul(8).add(i.y.mul(6)).add(i.z.mul(10))),f=o.mul(r.dispersion).mul(3),p=u.mul(.3),m=d.mul(.2),h=a.mul(.4),g=(0,n.fract)(f.add(p).add(m).add(h)).toVar(),_=(0,n.vec3)(0).toVar();(0,n.If)(g.lessThan(.143),()=>{let e=g.div(.143);_.assign((0,n.mix)((0,n.vec3)(.8,0,0),(0,n.vec3)(1,0,0),e))}),(0,n.If)(g.greaterThanEqual(.143).and(g.lessThan(.286)),()=>{let e=g.sub(.143).div(.143);_.assign((0,n.mix)((0,n.vec3)(1,0,0),(0,n.vec3)(1,.6,0),e))}),(0,n.If)(g.greaterThanEqual(.286).and(g.lessThan(.429)),()=>{let e=g.sub(.286).div(.143);_.assign((0,n.mix)((0,n.vec3)(1,.6,0),(0,n.vec3)(1,1,0),e))}),(0,n.If)(g.greaterThanEqual(.429).and(g.lessThan(.571)),()=>{let e=g.sub(.429).div(.142);_.assign((0,n.mix)((0,n.vec3)(1,1,0),(0,n.vec3)(0,1,0),e))}),(0,n.If)(g.greaterThanEqual(.571).and(g.lessThan(.714)),()=>{let e=g.sub(.571).div(.143);_.assign((0,n.mix)((0,n.vec3)(0,1,0),(0,n.vec3)(0,.4,1),e))}),(0,n.If)(g.greaterThanEqual(.714).and(g.lessThan(.857)),()=>{let e=g.sub(.714).div(.143);_.assign((0,n.mix)((0,n.vec3)(0,.4,1),(0,n.vec3)(.3,0,.8),e))}),(0,n.If)(g.greaterThanEqual(.857),()=>{let e=g.sub(.857).div(.143);_.assign((0,n.mix)((0,n.vec3)(.3,0,.8),(0,n.vec3)(.6,0,1),e))});let v=(0,n.clamp)(r.dispersion.div(5),0,1),y=(0,n.float)(1).add(a.mul(1.5)),b=v.mul(y),x=u.add(d),S=(0,n.float)(.5).add((0,n.float)(.5).mul((0,n.sin)(x.mul(3.14159)))),C=(0,n.clamp)(b.mul(S),0,.8);c.throughput.assign((0,n.mix)((0,n.vec3)(1),_,C))}).Else(()=>{c.throughput.assign((0,n.vec3)(1))})})}).Else(()=>{c.direction.assign((0,n.refract)(e,l,d.div(f))),c.throughput.assign((0,n.vec3)(1))}),(0,n.If)(c.didReflect.not(),()=>{c.throughput.mulAssign(r.color.xyz),c.throughput.mulAssign(d.mul(d).div((0,n.max)(f.mul(f),Nt))),(0,n.If)(i.and(r.attenuationDistance.greaterThan(0)),()=>{c.throughput.mulAssign(mr({attenuationColor:r.attenuationColor,attenuationDistance:r.attenuationDistance,thickness:r.thickness}))}),c.throughput.mulAssign((0,n.float)(1).sub(g).div((0,n.max)((0,n.float)(1).sub(_),.05)))})}),c}),_r=(0,n.Fn)(([e,t,r,i,a,o,s,c])=>{let l=ur({continueRay:!1,isTransmissive:!1,isAlphaSkip:!1,didReflect:!1,entering:!1,direction:e.direction,throughput:(0,n.vec3)(1),alpha:(0,n.float)(1)}).toVar();return(0,n.If)(i.alphaMode.equal((0,n.int)(0)).and(i.transmission.lessThanEqual(0)),()=>{}).Else(()=>{let t=N(a),u=N(a),d=A({state:a}),f=(0,n.bool)(!1).toVar();(0,n.If)(i.alphaMode.equal((0,n.int)(2)),()=>{let r=i.color.a.mul(i.opacity);(0,n.If)(t.greaterThan(r),()=>{l.continueRay.assign(!0),l.direction.assign(e.direction),l.throughput.assign((0,n.vec3)(1)),l.alpha.assign(0),l.isAlphaSkip.assign(!0),f.assign(!0)}).Else(()=>{l.alpha.assign(r)})}),(0,n.If)(f.not().and(i.alphaMode.equal((0,n.int)(1))),()=>{let t=(0,n.select)(i.alphaTest.greaterThan(0),i.alphaTest,(0,n.float)(.5));(0,n.If)(i.color.a.lessThan(t),()=>{l.continueRay.assign(!0),l.direction.assign(e.direction),l.throughput.assign((0,n.vec3)(1)),l.alpha.assign(0),l.isAlphaSkip.assign(!0),f.assign(!0)}).Else(()=>{l.alpha.assign(1)})}),(0,n.If)(f.not().and(i.transmission.greaterThan(0)).and(o.greaterThan((0,n.int)(0))),()=>{(0,n.If)(u.lessThan(i.transmission),()=>{let t=(0,n.dot)(e.direction,r).lessThan(0),a=lr.wrap(gr(e.direction,r,i,t,d,s,c));l.direction.assign(a.direction),l.throughput.assign(a.throughput),l.continueRay.assign(!0),l.isTransmissive.assign(!0),l.didReflect.assign(a.didReflect),l.entering.assign(t),l.alpha.assign((0,n.float)(1).sub(i.transmission))})})}),l}),vr=(0,n.Fn)(([e,t,r,i])=>{let a=(0,n.vec3)(0).toVar();return(0,n.If)(i.roughness.greaterThan(.98).and(i.metalness.lessThan(.02)).and(i.transmission.equal(0)).and(i.clearcoat.equal(0)).and(i.iridescence.equal(0)),()=>{a.assign(i.color.rgb.mul((0,n.float)(1).sub(i.metalness)).mul(jt))}).Else(()=>{let o=Ct.wrap(Kt(r,e,t)),s=(0,n.clamp)((0,n.mix)(Gn(i.ior).mul(i.specularColor),i.color.rgb,i.metalness).mul(i.specularIntensity),(0,n.vec3)(0),(0,n.vec3)(1)).toVar(),c=i.color.rgb.toVar();(0,n.If)(i.dispersion.greaterThan(0).and(i.transmission.greaterThan(.5)),()=>{let e=(0,n.clamp)(i.dispersion.mul(.1),0,.8),t=(0,n.max)((0,n.max)(c.r,c.g),c.b),r=(0,n.min)((0,n.min)(c.r,c.g),c.b);(0,n.If)(t.greaterThan(r),()=>{let i=c.sub(r).div(t.sub(r));c.assign((0,n.mix)(c,i,e.mul(.3)))})}),(0,n.If)(i.iridescence.greaterThan(0),()=>{let e=i.iridescenceThicknessRange.y,t=tr((0,n.float)(1),i.iridescenceIOR,o.VoH,e,s);s.assign((0,n.mix)(s,t,i.iridescence))});let l=Kn(o.NoH,i.roughness),u=Yn(o.NoV,o.NoL,i.roughness),d=Vn(o.VoH,s).toVar(),f=l.mul(u).mul(d).div((0,n.max)((0,n.float)(4).mul(o.NoV).mul(o.NoL),Nt)).mul(Xn(s,o.NoV,i.roughness)),p=Zn(s,o.NoV,i.roughness),m=(0,n.vec3)(1).sub(p).mul((0,n.float)(1).sub(i.metalness)).mul(c).mul(jt).add(f).toVar();(0,n.If)(i.sheen.greaterThan(0),()=>{let e=qn(o.NoH,i.sheenRoughness),t=i.sheenColor.mul(i.sheen).mul(e).mul(o.NoL),r=(0,n.float)(1).sub(i.sheenRoughness).mul(.5).add(.25),s=(0,n.clamp)(i.sheenColor.mul(i.sheen).mul(r),(0,n.vec3)(0),(0,n.vec3)(1)),c=(0,n.vec3)(1).sub(s);a.assign(m.mul(c).add(t))}).Else(()=>{a.assign(m)})}),a}),yr=(0,n.Fn)(([e,t])=>{let r=(0,n.clamp)((0,n.mix)(Gn(t.ior).mul(t.specularColor),t.color.rgb,t.metalness).mul(t.specularIntensity),(0,n.vec3)(0),(0,n.vec3)(1)).toVar(),i=Kn(e.NoH,t.roughness),a=Yn(e.NoV,e.NoL,t.roughness),o=Vn(e.VoH,r).toVar(),s=i.mul(a).mul(o).div((0,n.max)((0,n.float)(4).mul(e.NoV).mul(e.NoL),Nt)).mul(Xn(r,e.NoV,t.roughness)),c=Zn(r,e.NoV,t.roughness),l=(0,n.vec3)(1).sub(c).mul((0,n.float)(1).sub(t.metalness)).mul(t.color.rgb).div(At).add(s),u=(0,n.max)(t.clearcoatRoughness,Ft),d=Kn(e.NoH,u),f=Yn(e.NoV,e.NoL,u),p=Bn(e.VoH,(0,n.float)(.04)),m=d.mul(f).mul(p).div((0,n.max)((0,n.float)(4).mul(e.NoV).mul(e.NoL),Nt)),h=(0,n.float)(1).sub(t.clearcoat.mul(p).mul((0,n.float)(2).sub(p)));return l.mul(h).add((0,n.vec3)(m).mul(t.clearcoat))}),br=y({brdf:`vec3`,L:`vec3`,pdf:`float`}),xr=(0,n.Fn)(([e,t,r,i,a])=>{let o=t.normal,s=e.direction.negate(),c=(0,n.max)(r.clearcoatRoughness,Ft),l=(0,n.max)(r.roughness,Ft),u=(0,n.float)(1).sub(l).mul((0,n.float)(.5).add((0,n.float)(.5).mul(r.metalness))).toVar(),d=r.clearcoat.mul((0,n.float)(1).sub(c)).toVar(),f=(0,n.float)(1).sub(u).mul((0,n.float)(1).sub(r.metalness)).toVar(),p=u.add(d).add(f);u.divAssign(p),d.divAssign(p),f.divAssign(p);let m=N(a),h=(0,n.vec3)(0).toVar(),g=(0,n.vec3)(0).toVar();(0,n.If)(m.lessThan(d),()=>{g.assign(ar({N:o,roughness:c,Xi:i})),h.assign((0,n.reflect)(s.negate(),g))}).ElseIf(m.lessThan(d.add(u)),()=>{g.assign(ar({N:o,roughness:l,Xi:i})),h.assign((0,n.reflect)(s.negate(),g))}).Else(()=>{h.assign(or({N:o,xi:i})),g.assign((0,n.normalize)(s.add(h)))});let _=Ct.wrap(Kt(o,s,h)),v=Kn(_.NoH,c).mul(_.NoH).div((0,n.float)(4).mul(_.VoH)).mul(d),y=Kn(_.NoH,l).mul(_.NoH).div((0,n.float)(4).mul(_.VoH)).mul(u),b=_.NoL.div(At).mul(f),x=(0,n.max)(v.add(y).add(b),.001);return br({brdf:yr(_,r),L:h,pdf:x})}),Sr=y({direction:`vec3`,color:`vec3`,intensity:`float`,angle:`float`}),Cr=y({position:`vec3`,u:`vec3`,v:`vec3`,color:`vec3`,intensity:`float`,normal:`vec3`,area:`float`}),wr=y({position:`vec3`,color:`vec3`,intensity:`float`,distance:`float`,decay:`float`}),Tr=y({position:`vec3`,direction:`vec3`,color:`vec3`,intensity:`float`,angle:`float`,penumbra:`float`,distance:`float`,decay:`float`}),Er=y({direction:`vec3`,emission:`vec3`,pdf:`float`,distance:`float`,lightType:`int`,valid:`bool`}),Dr=y({direction:`vec3`,throughput:`vec3`,misWeight:`float`,pdf:`float`,combinedPdf:`float`}),Or=(0,n.Fn)(([e,t])=>{let r=t.mul(8);return Sr({direction:(0,n.normalize)((0,n.vec3)(e.element(r),e.element(r.add(1)),e.element(r.add(2)))),color:(0,n.vec3)(e.element(r.add(3)),e.element(r.add(4)),e.element(r.add(5))),intensity:e.element(r.add(6)),angle:e.element(r.add(7))})}),kr=(0,n.Fn)(([e,t])=>{let r=t.mul(13),i=(0,n.vec3)(e.element(r.add(3)),e.element(r.add(4)),e.element(r.add(5))).toVar(),a=(0,n.vec3)(e.element(r.add(6)),e.element(r.add(7)),e.element(r.add(8))).toVar(),o=(0,n.cross)(i,a);return Cr({position:(0,n.vec3)(e.element(r),e.element(r.add(1)),e.element(r.add(2))),u:i,v:a,color:(0,n.vec3)(e.element(r.add(9)),e.element(r.add(10)),e.element(r.add(11))),intensity:e.element(r.add(12)),normal:(0,n.normalize)(o),area:(0,n.length)(o).mul(4)})}),Ar=(0,n.Fn)(([e,t])=>{let r=t.mul(9);return wr({position:(0,n.vec3)(e.element(r),e.element(r.add(1)),e.element(r.add(2))),color:(0,n.vec3)(e.element(r.add(3)),e.element(r.add(4)),e.element(r.add(5))),intensity:e.element(r.add(6)),distance:e.element(r.add(7)),decay:e.element(r.add(8))})}),jr=(0,n.Fn)(([e,t])=>{let r=t.mul(14);return Tr({position:(0,n.vec3)(e.element(r),e.element(r.add(1)),e.element(r.add(2))),direction:(0,n.normalize)((0,n.vec3)(e.element(r.add(3)),e.element(r.add(4)),e.element(r.add(5)))),color:(0,n.vec3)(e.element(r.add(6)),e.element(r.add(7)),e.element(r.add(8))),intensity:e.element(r.add(9)),angle:e.element(r.add(10)),penumbra:e.element(r.add(11)),distance:e.element(r.add(12)),decay:e.element(r.add(13))})}),Mr=(0,n.wgslFn)(`
476
466
  fn isDirectionValid( direction: vec3f, surfaceNormal: vec3f ) -> bool {
477
467
  return dot( direction, surfaceNormal ) > 0.0f;
478
468
  }
479
- `),Kr=(0,n.wgslFn)(`
469
+ `),Nr=(0,n.wgslFn)(`
480
470
  fn getDistanceAttenuation( lightDistance: f32, cutoffDistance: f32, decayExponent: f32 ) -> f32 {
481
471
  var distanceFalloff = 1.0f / max( pow( lightDistance, decayExponent ), 0.01f );
482
472
  if ( cutoffDistance > 0.0f ) {
@@ -485,50 +475,36 @@
485
475
  }
486
476
  return distanceFalloff;
487
477
  }
488
- `),qr=(0,n.wgslFn)(`
478
+ `),Pr=(0,n.wgslFn)(`
489
479
  fn getSpotAttenuation( coneCosine: f32, penumbraCosine: f32, angleCosine: f32 ) -> f32 {
490
480
  return smoothstep( coneCosine, penumbraCosine, angleCosine );
491
481
  }
492
- `),Jr=(0,n.wgslFn)(`
493
- fn sampleCone( direction: vec3f, halfAngle: f32, xi: vec2f ) -> vec3f {
494
- let cosHalfAngle = cos( halfAngle );
495
- let cosTheta = cosHalfAngle + xi.x * ( 1.0f - cosHalfAngle );
496
- let sinTheta = sqrt( 1.0f - cosTheta * cosTheta );
497
- let phi = 6.28318530717958647692f * xi.y;
498
- // Create local coordinate system
499
- let up = select( vec3f( 1.0f, 0.0f, 0.0f ), vec3f( 0.0f, 0.0f, 1.0f ), abs( direction.z ) < 0.999f );
500
- let tangent = normalize( cross( up, direction ) );
501
- let bitangent = cross( direction, tangent );
502
- // Convert to world space
503
- let localDir = vec3f( sinTheta * cos( phi ), sinTheta * sin( phi ), cosTheta );
504
- return normalize( tangent * localDir.x + bitangent * localDir.y + direction * localDir.z );
505
- }
506
- `),Yr=(0,n.Fn)(([e,t,r])=>{let i=e.normal,a=(0,n.dot)(i,r),o=(0,n.float)(-1).toVar();return(0,n.If)(a.lessThan(-1e-4),()=>{let s=(0,n.float)(1).div(a),c=(0,n.dot)(e.position.sub(t),i).mul(s).toVar();(0,n.If)(c.greaterThan(.001),()=>{let i=t.add(r.mul(c)).sub(e.position),a=(0,n.length)(e.u),s=(0,n.length)(e.v),l=e.u.div(a),u=e.v.div(s),d=(0,n.dot)(i,l),f=(0,n.dot)(i,u);(0,n.If)((0,n.abs)(d).lessThanEqual(a).and((0,n.abs)(f).lessThanEqual(s)),()=>{o.assign(c)})})}),o}),Xr=null,Zr=null;function Qr(e){Xr=e}function $r(e){Zr=e}(0,n.Fn)(([e,t,r])=>{let i=(0,n.float)(1).toVar();return(0,n.If)(e.material.transmission.greaterThan(0),()=>{let r=(0,n.dot)(t,e.normal).lessThan(0),a=Dr(t,e.normal,e.material,r);i.assign((0,n.float)(1).sub(a))}).ElseIf(e.material.transparent,()=>{i.assign(e.material.opacity)}),i});var ei=(0,n.Fn)(([e,t,r,i,a,o,s,c])=>{let l=(0,n.float)(1).toVar(),u=e.toVar(),d=(0,n.float)(r).toVar();return(0,n.Loop)({start:(0,n.int)(0),end:(0,n.int)(8)},()=>{let e=Ot({origin:u,direction:t}),r=jt.wrap(a(e,o,s,c,d));(0,n.If)(r.didHit.not(),()=>{(0,n.Break)()});let i=(0,n.int)(8),f=X(s,r.triangleIndex,(0,n.int)(3),i).w;(0,n.If)(f.greaterThan(.5),()=>{l.assign(0),(0,n.Break)()});let p=At.wrap(dn(r.materialIndex,c)),m=(0,n.bool)(!1).toVar();Zr&&(0,n.If)(Zr.equal((0,n.int)(1)),()=>{let e=(0,n.float)(1).toVar();Xr&&(0,n.If)(p.albedoMapIndex.greaterThanEqual((0,n.int)(0)),()=>{let t=r.uv.x,i=r.uv.y,a=(0,n.float)(1).sub(t).sub(i),o=(0,n.int)(8),c=X(s,r.triangleIndex,(0,n.int)(6),o),l=X(s,r.triangleIndex,(0,n.int)(7),o),u=jn({uv:c.xy.mul(a).add(c.zw.mul(t)).add(l.xy.mul(i)),transform:p.albedoTransform});e.assign((0,n.texture)(Xr,u).depth((0,n.int)(p.albedoMapIndex)).a)}),(0,n.If)(p.alphaMode.equal((0,n.int)(1)),()=>{let t=p.color.a.mul(e),r=(0,n.select)(p.alphaTest.greaterThan(0),p.alphaTest,(0,n.float)(.5));(0,n.If)(t.lessThan(r),()=>{m.assign(!0)})}).ElseIf(p.alphaMode.equal((0,n.int)(2)),()=>{let t=(0,n.clamp)(p.color.a.mul(p.opacity).mul(e),0,1);l.mulAssign((0,n.float)(1).sub(t)),(0,n.If)(l.lessThan(.005),()=>{l.assign(0),(0,n.Break)()}),m.assign(!0)})}),(0,n.If)(m,()=>{let e=(0,n.max)((0,n.float)(1e-5),(0,n.length)(r.hitPoint).mul(1e-6));u.assign(r.hitPoint.add(t.mul(e))),d.subAssign(r.dst.add(e))}).ElseIf(p.transmission.greaterThan(0),()=>{let e=(0,n.dot)(t,r.normal).lessThan(0),i=(0,n.select)(e,r.normal,r.normal.negate());(0,n.If)(e.not().and(p.attenuationDistance.greaterThan(0)),()=>{let e=(0,n.length)(r.hitPoint.sub(u)),t=Er(p.attenuationColor,p.attenuationDistance,e);l.mulAssign(t.x.add(t.y).add(t.z).div(3))});let a=Xn((0,n.abs)((0,n.dot)(t,i)),er(p.ior,(0,n.float)(1))),o=(0,n.float)(1).sub(a).mul(p.transmission);l.mulAssign(o),(0,n.If)(l.lessThan(.005),()=>{l.assign(0),(0,n.Break)()}),u.assign(r.hitPoint.add(t.mul(.001))),d.subAssign(r.dst.add(.001))}).ElseIf(p.transparent,()=>{l.mulAssign((0,n.float)(1).sub(p.opacity)),(0,n.If)(l.lessThan(.005),()=>{l.assign(0),(0,n.Break)()}),u.assign(r.hitPoint.add(t.mul(.001))),d.subAssign(r.dst.add(.001))}).Else(()=>{l.assign(0),(0,n.Break)()})}),l}),ti=(0,n.Fn)(([e,t,r])=>{let i=(0,n.max)((0,n.float)(1e-4),(0,n.length)(e).mul(1e-6)).toVar().toVar();return(0,n.If)(r.transmission.greaterThan(0),()=>{i.mulAssign(2)}),(0,n.If)(r.roughness.lessThan(.1),()=>{i.mulAssign(1.5)}),t.mul(i)}),ni=(0,n.Fn)(([e,t,r,i,a])=>{let o=(0,n.max)((0,n.float)(0),(0,n.dot)(r,e.direction)),s=(0,n.float)(0).toVar();return(0,n.If)(o.greaterThan(0),()=>{let t=e.intensity.mul((0,n.dot)(e.color,qt)),r=(0,n.float)(1).toVar();(0,n.If)(i.metalness.greaterThan(.7),()=>{r.assign(1.5)}).ElseIf(i.roughness.greaterThan(.8),()=>{r.assign(.7)});let c=(0,n.float)(1).div((0,n.float)(1).add((0,n.float)(a).mul(.5)));s.assign(t.mul(o).mul(r).mul(c))}),s}),ri=(0,n.Fn)(([e,t,r,i])=>{let a=e.position.sub(t),o=(0,n.length)(a),s=o.mul(o),c=a.div(o),l=(0,n.max)((0,n.dot)(r,c),0),u=(0,n.float)(0).toVar();return(0,n.If)(l.greaterThan(0),()=>{let t=(0,n.max)((0,n.dot)(c,e.normal).negate(),0);(0,n.If)(t.greaterThan(0),()=>{let r=e.area.div((0,n.max)(s,.1)),a=e.intensity.mul((0,n.dot)(e.color,qt)).mul(e.area),o=(0,n.float)(1).toVar();(0,n.If)(i.metalness.greaterThan(.7),()=>{o.mulAssign(1.5),(0,n.If)(i.roughness.lessThan(.3),()=>{o.mulAssign((0,n.float)(1).add((0,n.float)(1).sub(i.roughness).mul(.5)))})}),(0,n.If)(i.roughness.greaterThan(.6).and(i.metalness.lessThan(.3)),()=>{let t=(0,n.min)(e.area.mul(2),(0,n.float)(2));o.mulAssign(t)}),(0,n.If)(i.transmission.greaterThan(.5),()=>{o.mulAssign((0,n.float)(1).add(i.transmission.mul(.3)))}),u.assign(a.mul(r).mul(l).mul(t).mul(o))})}),u}),ii=(0,n.Fn)(([e,t,r,i])=>{let a=e.position.sub(t),o=(0,n.dot)(a,a),s=(0,n.float)(0).toVar();return(0,n.If)(o.greaterThanEqual(.001),()=>{let t=(0,n.sqrt)(o),c=a.div(t),l=(0,n.max)((0,n.float)(0),(0,n.dot)(r,c));(0,n.If)(l.greaterThan(0),()=>{let t=(0,n.float)(1).div((0,n.max)(o,.1)),r=e.intensity.mul((0,n.dot)(e.color,qt)),a=(0,n.float)(1).toVar();(0,n.If)(i.metalness.greaterThan(.7),()=>{a.mulAssign(1.5),(0,n.If)(i.roughness.lessThan(.3),()=>{a.mulAssign((0,n.float)(1).add((0,n.float)(1).sub(i.roughness).mul(.4)))})}),(0,n.If)(i.roughness.greaterThan(.6),()=>{a.mulAssign(.9)}),(0,n.If)(i.transmission.greaterThan(.5),()=>{a.mulAssign((0,n.float)(1).add(i.transmission.mul(.2)))}),s.assign(r.mul(t).mul(l).mul(a))})}),s}),ai=(0,n.Fn)(([e,t,r,i])=>{let a=e.position.sub(t),o=(0,n.dot)(a,a),s=(0,n.float)(0).toVar();return(0,n.If)(o.greaterThanEqual(.001),()=>{let t=a.div((0,n.sqrt)(o)),c=(0,n.max)((0,n.float)(0),(0,n.dot)(r,t));(0,n.If)(c.greaterThan(0),()=>{let r=(0,n.dot)(t.negate(),e.direction),a=(0,n.cos)(e.angle);(0,n.If)(r.greaterThanEqual(a),()=>{let t=(0,n.float)(1).div((0,n.max)(o,.01)),l=(0,n.smoothstep)(a,a.add(.1),r),u=e.intensity.mul((0,n.dot)(e.color,qt)),d=(0,n.select)(i.metalness.greaterThan(.7),(0,n.float)(1.5),(0,n.select)(i.roughness.greaterThan(.8),(0,n.float)(.8),(0,n.float)(1)));s.assign(u.mul(t).mul(l).mul(c).mul(d))})})}),s}),oi=(0,n.Fn)(([e,t,r,i])=>{let a=(0,n.max)((0,n.float)(0),(0,n.dot)(t,e.direction)),o=(0,n.bool)(!1).toVar();return(0,n.If)(e.intensity.lessThanEqual(.001).or(a.lessThanEqual(.001)),()=>{o.assign(!0)}),(0,n.If)(o.not().and(i.greaterThan((0,n.int)(0))),()=>{(0,n.If)(e.intensity.lessThan(.01),()=>{o.assign(!0)}),(0,n.If)(o.not().and(r.metalness.greaterThan(.9)).and(a.lessThan(.1)),()=>{o.assign(!0)}),(0,n.If)(o.not().and(r.metalness.lessThan(.1)).and(r.roughness.greaterThan(.9)).and(e.intensity.lessThan(.1)),()=>{o.assign(!0)})}),o});(0,n.Fn)(([e,t,r,i,a,o,s,c,l,u,d])=>{let f=(0,n.vec3)(0).toVar();return(0,n.If)(oi(e,r,a,c).not(),()=>{let p=ti(t,r,a),m=t.add(p),h=(0,n.vec3)(0).toVar(),g=(0,n.float)(1e6).toVar();(0,n.If)(e.angle.greaterThan(.001),()=>{let t=(0,n.vec2)(P(l).toVar(),P(l).toVar()),r=e.angle.mul(.5);h.assign(Jr({direction:e.direction,halfAngle:r,xi:t}));let i=(0,n.cos)(r);g.assign((0,n.float)(1).div(Wt.mul((0,n.float)(1).sub(i))))}).Else(()=>{h.assign(e.direction)});let _=(0,n.max)((0,n.float)(0),(0,n.dot)(r,h));(0,n.If)(_.greaterThan(0),()=>{let t=u(m,h,(0,n.float)(1e6),l);(0,n.If)(t.greaterThan(0),()=>{let l=d(i,h,r,a,o),u=e.color.mul(e.intensity).mul(l).mul(_).mul(t);(0,n.If)(c.equal((0,n.int)(0)).and(s.pdf.greaterThan(0)),()=>{(0,n.If)((0,n.max)((0,n.float)(0),(0,n.dot)((0,n.normalize)(s.direction),h)).greaterThan(.996),()=>{let e=$t({pdf1:g,pdf2:s.pdf});f.assign(u.mul(e))}).Else(()=>{f.assign(u)})}).Else(()=>{f.assign(u)})})})}),f}),(0,n.Fn)(([e,t,r,i,a,o,s,c,l,u,d,f,p])=>{let m=(0,n.vec3)(0).toVar(),h=ri(e,t,r,a);return(0,n.If)(h.greaterThanEqual(.001),()=>{let g=ti(t,r,a),_=t.add(g),v=a.roughness.greaterThan(.7).and(a.metalness.lessThan(.3)),y=a.roughness.lessThan(.3).or(a.metalness.greaterThan(.7)),b=l.equal((0,n.int)(0));(0,n.If)(b.or(v).or(h.greaterThan(.1).and(y.not())),()=>{let h=p(c,l,u),g=e.position.add(e.u.mul(h.x.sub(.5))).add(e.v.mul(h.y.sub(.5))).sub(t),v=(0,n.dot)(g,g),y=(0,n.sqrt)(v),x=g.div(y),S=(0,n.max)((0,n.float)(0),(0,n.dot)(r,x)),C=(0,n.max)((0,n.float)(0),(0,n.dot)(x,e.normal).negate());(0,n.If)(S.greaterThan(0).and(C.greaterThan(0)),()=>{let t=d(_,x,y,u);(0,n.If)(t.greaterThan(0),()=>{let c=f(i,x,r,a,o),l=v.div((0,n.max)(e.area.mul(C),K)),u=s.pdf,d=e.area.div((0,n.float)(4).mul(G).mul(v)),p=e.color.mul(e.intensity).mul(d).mul(C),h=(0,n.select)(u.greaterThan(0).and(b),$t({pdf1:l,pdf2:u}),(0,n.float)(1));m.addAssign(p.mul(c).mul(S).mul(t).mul(h))})})}),(0,n.If)(b.or(y).and(s.pdf.greaterThan(0)),()=>{(0,n.If)((0,n.dot)(e.position.sub(_),s.direction).greaterThan(0),()=>{let t=Yr(e,_,s.direction);(0,n.If)(t.greaterThan(0),()=>{let i=d(_,s.direction,t,u);(0,n.If)(i.greaterThan(0),()=>{let a=(0,n.max)((0,n.float)(0),(0,n.dot)(s.direction,e.normal).negate());(0,n.If)(a.greaterThan(0),()=>{let o=t.mul(t).div((0,n.max)(e.area.mul(a),K)),c=$t({pdf1:s.pdf,pdf2:o}),l=e.color.mul(e.intensity),u=(0,n.max)((0,n.float)(0),(0,n.dot)(r,s.direction));m.addAssign(l.mul(s.value).mul(u).mul(i).mul(c))})})})})})}),m}),(0,n.Fn)(([e,t,r,i,a,o,s,c,l,u,d])=>{let f=(0,n.vec3)(0).toVar(),p=e.position.sub(t),m=(0,n.length)(p);return(0,n.If)(m.lessThanEqual(1e3),()=>{let o=p.div(m),s=(0,n.dot)(r,o);(0,n.If)(s.greaterThan(0),()=>{let c=(0,n.float)(1).div(m.mul(m)),p=e.color.mul(e.intensity).mul(c),h=ti(t,r,a),g=u(t.add(h),o,m.sub(.001),l);(0,n.If)(g.greaterThan(0),()=>{let e=d(i,o,r,a);f.assign(e.mul(p).mul(s).mul(g))})})}),f}),(0,n.Fn)(([e,t,r,i,a,o,s,c,l,u,d])=>{let f=(0,n.vec3)(0).toVar(),p=e.position.sub(t),m=(0,n.length)(p);return(0,n.If)(m.lessThanEqual(1e3),()=>{let o=p.div(m),s=(0,n.dot)(r,o);(0,n.If)(s.greaterThan(0),()=>{let c=(0,n.dot)(o.negate(),e.direction),p=(0,n.cos)(e.angle);(0,n.If)(c.greaterThanEqual(p),()=>{let h=(0,n.smoothstep)(p,p.add(.1),c),g=(0,n.float)(1).div(m.mul(m)),_=e.color.mul(e.intensity).mul(g).mul(h),v=ti(t,r,a),y=u(t.add(v),o,m.sub(.001),l);(0,n.If)(y.greaterThan(0),()=>{let e=d(i,o,r,a);f.assign(e.mul(_).mul(s).mul(y))})})})}),f});var si=2*G;(0,n.Fn)(()=>zr({valid:(0,n.bool)(!1),direction:(0,n.vec3)(0,1,0),emission:(0,n.vec3)(0),distance:(0,n.float)(0),pdf:(0,n.float)(0),lightType:(0,n.int)(2)}));var ci=(0,n.Fn)(([e,t,r,i])=>{let a=(0,n.bool)(!1).toVar(),o=(0,n.vec3)(0,1,0).toVar(),s=(0,n.vec3)(0).toVar(),c=(0,n.float)(0).toVar(),l=(0,n.float)(0).toVar(),u=(0,n.int)(2).toVar();return(0,n.If)(e.area.greaterThan(0),()=>{let d=e.position.add(e.u.mul(r.x.mul(2).sub(1))).add(e.v.mul(r.y.mul(2).sub(1))).toVar().sub(t).toVar(),f=(0,n.dot)(d,d).toVar();(0,n.If)(f.greaterThanEqual(1e-10),()=>{let t=(0,n.sqrt)(f).toVar(),r=d.div(t).toVar(),p=(0,n.normalize)((0,n.cross)(e.u,e.v)).toVar(),m=(0,n.dot)(r.negate(),p).toVar();u.assign((0,n.int)(1)),s.assign(e.color.mul(e.intensity)),c.assign(t),o.assign(r),l.assign(f.div((0,n.max)(e.area.mul((0,n.max)(m,.001)),1e-10)).mul(i)),a.assign(m.greaterThan(0))})}),zr({valid:a,direction:o,emission:s,distance:c,pdf:l,lightType:u})});(0,n.Fn)(([e,t,r,i])=>{let a=(0,n.bool)(!1).toVar(),o=(0,n.vec3)(0,1,0).toVar(),s=(0,n.vec3)(0).toVar(),c=(0,n.float)(0).toVar(),l=(0,n.float)(0).toVar(),u=(0,n.int)(2).toVar();return(0,n.If)(e.area.greaterThan(0),()=>{let d=(0,n.float)(.5).mul((0,n.sqrt)(r.x)).toVar(),f=r.y.mul(si).toVar(),p=d.mul((0,n.cos)(f)).toVar(),m=d.mul((0,n.sin)(f)).toVar(),h=e.position.add(e.u.mul(p)).add(e.v.mul(m)).toVar().sub(t).toVar(),g=(0,n.dot)(h,h).toVar();(0,n.If)(g.greaterThanEqual(1e-10),()=>{let t=(0,n.sqrt)(g).toVar(),r=h.div(t).toVar(),d=(0,n.normalize)((0,n.cross)(e.u,e.v)).toVar(),f=(0,n.dot)(r.negate(),d).toVar();u.assign((0,n.int)(1)),s.assign(e.color.mul(e.intensity)),c.assign(t),o.assign(r),l.assign(g.div((0,n.max)(e.area.mul((0,n.max)(f,.001)),1e-10)).mul(i)),a.assign(f.greaterThan(0))})}),zr({valid:a,direction:o,emission:s,distance:c,pdf:l,lightType:u})});var li=(0,n.Fn)(([e,t,r,i])=>{let a=(0,n.bool)(!1).toVar(),o=(0,n.vec3)(0,1,0).toVar(),s=(0,n.vec3)(0).toVar(),c=(0,n.float)(0).toVar(),l=(0,n.float)(0).toVar(),u=(0,n.int)(3).toVar(),d=e.position.sub(t).toVar(),f=(0,n.length)(d).toVar();return(0,n.If)(f.greaterThanEqual(1e-10),()=>{let t=d.div(f).toVar(),r=(0,n.dot)(t.negate(),e.direction).toVar(),u=(0,n.cos)(e.angle).toVar();o.assign(t),c.assign(f),l.assign(i),a.assign(r.greaterThanEqual(u)),(0,n.If)(a,()=>{let t=qr({coneCosine:u,penumbraCosine:(0,n.cos)(e.angle.mul((0,n.float)(1).sub(e.penumbra))).max(u.add(1e-5)).toVar(),angleCosine:r}),i=Kr({lightDistance:f,cutoffDistance:e.distance,decayExponent:e.decay});s.assign(e.color.mul(e.intensity).mul(i).mul(t))})}),zr({valid:a,direction:o,emission:s,distance:c,pdf:l,lightType:u})}),ui=(0,n.Fn)(([e,t,r])=>{let i=(0,n.bool)(!1).toVar(),a=(0,n.vec3)(0,1,0).toVar(),o=(0,n.vec3)(0).toVar(),s=(0,n.float)(0).toVar(),c=(0,n.float)(0).toVar(),l=(0,n.int)(2).toVar(),u=e.position.sub(t).toVar(),d=(0,n.length)(u).toVar();return(0,n.If)(d.greaterThanEqual(1e-10),()=>{let t=u.div(d).toVar(),f=Kr({lightDistance:d,cutoffDistance:e.distance,decayExponent:e.decay});l.assign((0,n.int)(2)),a.assign(t),s.assign(d),o.assign(e.color.mul(e.intensity).mul(f)),c.assign(r),i.assign((0,n.bool)(!0))}),zr({valid:i,direction:a,emission:o,distance:s,pdf:c,lightType:l})}),di=(0,n.Fn)(([e,t,r,i,a,o,s,c,l,u,d,f,p,m])=>{let h=(0,n.bool)(!1).toVar(),g=(0,n.vec3)(0,1,0).toVar(),_=(0,n.vec3)(0).toVar(),v=(0,n.float)(0).toVar(),y=(0,n.float)(0).toVar(),b=(0,n.int)(2).toVar(),x=c.add(u).add(f).add(m).toVar();return(0,n.If)(x.greaterThan((0,n.int)(0)),()=>{let S=(0,n.float)(0).toVar(),C=(0,n.int)(0).toVar();(0,n.If)(c.greaterThan((0,n.int)(0)),()=>{(0,n.Loop)({start:(0,n.int)(0),end:c,type:`int`,condition:`<`},({i})=>{(0,n.If)(C.lessThan((0,n.int)(16)),()=>{let n=Fr.wrap(Vr(s,i));S.addAssign(ni(n,e,t,r,a)),C.addAssign(1)})})}),(0,n.If)(u.greaterThan((0,n.int)(0)),()=>{(0,n.Loop)({start:(0,n.int)(0),end:u,type:`int`,condition:`<`},({i})=>{(0,n.If)(C.lessThan((0,n.int)(16)),()=>{let a=Ir.wrap(Hr(l,i)),o=(0,n.select)(a.intensity.greaterThan(0),ri(a,e,t,r),(0,n.float)(0));S.addAssign(o),C.addAssign(1)})})}),(0,n.If)(f.greaterThan((0,n.int)(0)),()=>{(0,n.Loop)({start:(0,n.int)(0),end:f,type:`int`,condition:`<`},({i})=>{(0,n.If)(C.lessThan((0,n.int)(16)),()=>{let n=Lr.wrap(Ur(d,i));S.addAssign(ii(n,e,t,r)),C.addAssign(1)})})}),(0,n.If)(m.greaterThan((0,n.int)(0)),()=>{(0,n.Loop)({start:(0,n.int)(0),end:m,type:`int`,condition:`<`},({i})=>{(0,n.If)(C.lessThan((0,n.int)(16)),()=>{let n=Rr.wrap(Wr(p,i));S.addAssign(ai(n,e,t,r)),C.addAssign(1)})})}),(0,n.If)(S.lessThanEqual(0),()=>{let t=(0,n.int)(i.x.mul((0,n.float)(x)).toVar()).toVar(),r=(0,n.float)(1).div((0,n.max)((0,n.float)(x),1)).toVar();y.assign(r);let a=(0,n.bool)(!1).toVar(),S=(0,n.int)(0).toVar();(0,n.If)(c.greaterThan((0,n.int)(0)),()=>{(0,n.If)(a.not().and(t.greaterThanEqual(S)).and(t.lessThan(S.add(c))),()=>{let e=Fr.wrap(Vr(s,t.sub(S)));(0,n.If)(e.intensity.greaterThan(0),()=>{g.assign((0,n.normalize)(e.direction)),_.assign(e.color.mul(e.intensity)),v.assign(1e6),b.assign((0,n.int)(0)),h.assign((0,n.bool)(!0)),a.assign((0,n.bool)(!0))})}),S.addAssign(c)}),(0,n.If)(u.greaterThan((0,n.int)(0)),()=>{(0,n.If)(a.not().and(t.greaterThanEqual(S)).and(t.lessThan(S.add(u))),()=>{let s=Ir.wrap(Hr(l,t.sub(S)));(0,n.If)(s.intensity.greaterThan(0),()=>{let t=(0,n.vec2)(i.y,P(o)).toVar(),c=zr.wrap(ci(s,e,t,r));h.assign(c.valid),g.assign(c.direction),_.assign(c.emission),v.assign(c.distance),y.assign(c.pdf),b.assign(c.lightType),a.assign((0,n.bool)(!0))})}),S.addAssign(u)}),(0,n.If)(f.greaterThan((0,n.int)(0)),()=>{(0,n.If)(a.not().and(t.greaterThanEqual(S)).and(t.lessThan(S.add(f))),()=>{let i=Lr.wrap(Ur(d,t.sub(S)));(0,n.If)(i.intensity.greaterThan(0),()=>{let t=zr.wrap(ui(i,e,r));h.assign(t.valid),g.assign(t.direction),_.assign(t.emission),v.assign(t.distance),y.assign(t.pdf),b.assign(t.lightType),a.assign((0,n.bool)(!0))})}),S.addAssign(f)}),(0,n.If)(m.greaterThan((0,n.int)(0)),()=>{(0,n.If)(a.not().and(t.greaterThanEqual(S)).and(t.lessThan(S.add(m))),()=>{let s=Rr.wrap(Wr(p,t.sub(S)));(0,n.If)(s.intensity.greaterThan(0),()=>{let t=(0,n.vec2)(i.y,P(o)).toVar(),c=zr.wrap(li(s,e,t,r));h.assign(c.valid),g.assign(c.direction),_.assign(c.emission),v.assign(c.distance),y.assign(c.pdf),b.assign(c.lightType),a.assign((0,n.bool)(!0))})})})}).Else(()=>{let x=i.x.mul(S).toVar(),w=(0,n.float)(0).toVar();C.assign(0);let T=(0,n.int)(-1).toVar(),E=(0,n.int)(-1).toVar(),D=(0,n.float)(0).toVar();(0,n.If)(c.greaterThan((0,n.int)(0)),()=>{(0,n.Loop)({start:(0,n.int)(0),end:c,type:`int`,condition:`<`},({i})=>{(0,n.If)(C.lessThan((0,n.int)(16)).and(T.lessThan((0,n.int)(0))),()=>{let o=ni(Fr.wrap(Vr(s,i)),e,t,r,a).toVar(),c=w.toVar();w.addAssign(o),(0,n.If)(x.greaterThan(c).and(x.lessThanEqual(w)),()=>{T.assign(0),E.assign(i),D.assign(o)})}),C.addAssign(1)})}),(0,n.If)(u.greaterThan((0,n.int)(0)),()=>{(0,n.Loop)({start:(0,n.int)(0),end:u,type:`int`,condition:`<`},({i})=>{(0,n.If)(C.lessThan((0,n.int)(16)).and(T.lessThan((0,n.int)(0))),()=>{let a=Ir.wrap(Hr(l,i)),o=(0,n.select)(a.intensity.greaterThan(0),ri(a,e,t,r),(0,n.float)(0)).toVar(),s=w.toVar();w.addAssign(o),(0,n.If)(x.greaterThan(s).and(x.lessThanEqual(w)),()=>{T.assign(1),E.assign(i),D.assign(o)})}),C.addAssign(1)})}),(0,n.If)(f.greaterThan((0,n.int)(0)),()=>{(0,n.Loop)({start:(0,n.int)(0),end:f,type:`int`,condition:`<`},({i})=>{(0,n.If)(C.lessThan((0,n.int)(16)).and(T.lessThan((0,n.int)(0))),()=>{let a=ii(Lr.wrap(Ur(d,i)),e,t,r).toVar(),o=w.toVar();w.addAssign(a),(0,n.If)(x.greaterThan(o).and(x.lessThanEqual(w)),()=>{T.assign(2),E.assign(i),D.assign(a)})}),C.addAssign(1)})}),(0,n.If)(m.greaterThan((0,n.int)(0)),()=>{(0,n.Loop)({start:(0,n.int)(0),end:m,type:`int`,condition:`<`},({i})=>{(0,n.If)(C.lessThan((0,n.int)(16)).and(T.lessThan((0,n.int)(0))),()=>{let a=ai(Rr.wrap(Wr(p,i)),e,t,r).toVar(),o=w.toVar();w.addAssign(a),(0,n.If)(x.greaterThan(o).and(x.lessThanEqual(w)),()=>{T.assign(3),E.assign(i),D.assign(a)})}),C.addAssign(1)})});let O=D.div((0,n.max)(S,1e-10)).toVar();(0,n.If)(T.equal((0,n.int)(0)).and(E.greaterThanEqual((0,n.int)(0))),()=>{let e=Fr.wrap(Vr(s,E)),t=(0,n.normalize)(e.direction).toVar(),r=(0,n.float)(1).toVar();(0,n.If)(e.angle.greaterThan(0),()=>{let a=(0,n.cos)(e.angle.mul(.5)).toVar(),s=(0,n.mix)(a,(0,n.float)(1),i.y).toVar(),c=(0,n.sqrt)((0,n.max)((0,n.float)(0),(0,n.float)(1).sub(s.mul(s)))).toVar(),l=(0,n.float)(si).mul(P(o)).toVar(),u=(0,n.normalize)(e.direction).toVar(),d=(0,n.normalize)((0,n.cross)((0,n.select)((0,n.abs)(u.x).greaterThan(.9),(0,n.vec3)(0,1,0),(0,n.vec3)(1,0,0)),u)).toVar(),f=(0,n.cross)(u,d).toVar();t.assign((0,n.normalize)(u.mul(s).add(d.mul((0,n.cos)(l)).add(f.mul((0,n.sin)(l))).mul(c))));let p=(0,n.float)(si).mul((0,n.max)((0,n.float)(1).sub(a),1e-10)).toVar();r.assign((0,n.float)(1).div(p))}),g.assign(t),_.assign(e.color.mul(e.intensity)),v.assign(1e6),y.assign(r.mul(O)),b.assign((0,n.int)(0)),h.assign((0,n.bool)(!0))}),(0,n.If)(T.equal((0,n.int)(1)).and(E.greaterThanEqual((0,n.int)(0))),()=>{let t=Ir.wrap(Hr(l,E)),r=(0,n.vec2)(i.y,P(o)).toVar(),a=zr.wrap(ci(t,e,r,O));h.assign(a.valid),g.assign(a.direction),_.assign(a.emission),v.assign(a.distance),y.assign(a.pdf),b.assign(a.lightType)}),(0,n.If)(T.equal((0,n.int)(2)).and(E.greaterThanEqual((0,n.int)(0))),()=>{let t=Lr.wrap(Ur(d,E)),n=zr.wrap(ui(t,e,O));h.assign(n.valid),g.assign(n.direction),_.assign(n.emission),v.assign(n.distance),y.assign(n.pdf),b.assign(n.lightType)}),(0,n.If)(T.equal((0,n.int)(3)).and(E.greaterThanEqual((0,n.int)(0))),()=>{let t=Rr.wrap(Wr(p,E)),r=(0,n.vec2)(i.y,P(o)).toVar(),a=zr.wrap(li(t,e,r,O));h.assign(a.valid),g.assign(a.direction),_.assign(a.emission),v.assign(a.distance),y.assign(a.pdf),b.assign(a.lightType)})})}),zr({valid:h,direction:g,emission:_,distance:v,pdf:y,lightType:b})}),fi=(0,n.Fn)(([e,t,r,i])=>{let a=(0,n.max)((0,n.float)(0),(0,n.dot)(r,e)).toVar(),o=(0,n.max)((0,n.float)(0),(0,n.dot)(r,t)).toVar(),s=(0,n.normalize)(e.add(t)).toVar(),c=(0,n.max)((0,n.float)(0),(0,n.dot)(r,s)).toVar();(0,n.max)((0,n.float)(0),(0,n.dot)(e,s)).toVar();let l=(0,n.float)(1).sub(i.metalness).mul((0,n.float)(1).sub(i.transmission)).toVar(),u=(0,n.float)(1).sub(l.mul((0,n.float)(1).sub(i.metalness))).toVar(),d=l.add(u).toVar(),f=(0,n.float)(0).toVar();return(0,n.If)(d.greaterThan(0),()=>{let e=(0,n.float)(1).div((0,n.max)(d,1e-10)).toVar();l.mulAssign(e),u.mulAssign(e),(0,n.If)(l.greaterThan(0).and(o.greaterThan(0)),()=>{f.addAssign(l.mul(o).mul(Ut))}),(0,n.If)(u.greaterThan(0).and(o.greaterThan(0)),()=>{let e=(0,n.max)(i.roughness,.02).toVar();f.addAssign(u.mul(lr(c,a,e)))})}),(0,n.max)(f,1e-8)});(0,n.Fn)(([e,t,r,i,a,o,s,c,l,u,d])=>{let f=(0,n.vec3)(0).toVar(),p=(0,n.vec2)(P(c).toVar(),P(c).toVar()).toVar(),m=e.position.add(e.u.mul(p.x.mul(2).sub(1))).add(e.v.mul(p.y.mul(2).sub(1))).toVar().sub(o).toVar(),h=(0,n.dot)(m,m).toVar();return(0,n.If)(h.greaterThanEqual(1e-10),()=>{let r=(0,n.sqrt)(h).toVar(),s=m.div(r).toVar(),p=(0,n.normalize)((0,n.cross)(e.u,e.v)).toVar(),g=(0,n.dot)(s.negate(),p).toVar();(0,n.If)(g.greaterThan(0),()=>{let p=(0,n.dot)(i,s).toVar();(0,n.If)(p.greaterThan(0),()=>{(0,n.If)(Gr({direction:s,surfaceNormal:i}),()=>{let m=ei(o,s,r.sub(.001),c,Sn,l,u,d);(0,n.If)(m.greaterThan(0),()=>{let r=jr(t,s,i,a),o=h.div((0,n.max)(e.area.mul(g),K)).toVar(),c=fi(t,s,i,a).toVar(),l=(0,n.select)(c.greaterThan(0),$t({pdf1:o,pdf2:c}),(0,n.float)(1)).toVar(),u=e.color.mul(e.intensity).toVar();f.assign(u.mul(r).mul(p).mul(m).mul(l).div((0,n.max)(o,q)))})})})})}),f});var pi=(0,n.Fn)(([e,t,r,i,a,o,s,c,l,u,d,f,p,m,h,g,_,v,y,b,x,S,C,w,T,E,D,O,k])=>{let A=(0,n.vec3)(0).toVar(),j=e.add(t.mul(.001)).toVar();return(0,n.If)(r.emissiveIntensity.lessThanEqual(10),()=>{let c=(0,n.vec3)(1).toVar(),M=Vt.wrap(cn(r.roughness,r.metalness,r.transmission,l,c)),N=M.useBRDFSampling.toVar(),ee=M.useLightSampling.toVar(),te=M.brdfWeight.toVar(),ne=M.lightWeight.toVar(),re=f.add(m).add(g).add(v).toVar(),ie=(0,n.float)(.001).mul((0,n.float)(1).add((0,n.float)(l).mul(.5))).toVar(),ae=re.greaterThan((0,n.int)(0)).toVar(),oe=(0,n.float)(0).toVar();(0,n.If)(ee.and(ae),()=>{oe.addAssign(ne)}),(0,n.If)(N,()=>{oe.addAssign(te)}),(0,n.If)(oe.lessThanEqual(0),()=>{oe.assign(1),N.assign((0,n.bool)(!0)),te.assign(1)});let se=P(u).toVar(),ce=P(u).toVar(),le=se,ue=(0,n.bool)(!1).toVar(),de=(0,n.bool)(!1).toVar(),fe=(0,n.select)(ae,ne,(0,n.float)(0)).toVar(),pe=(0,n.float)(1).div((0,n.max)(oe,1e-10)).toVar(),me=fe.mul(pe).toVar();(0,n.If)(le.lessThan(me).and(ee).and(ae),()=>{ue.assign((0,n.bool)(!0))}).ElseIf(N,()=>{de.assign((0,n.bool)(!0))}).ElseIf(ae,()=>{ue.assign((0,n.bool)(!0))}),(0,n.If)(ue,()=>{let e=(0,n.vec2)(ce,P(u)).toVar(),a=zr.wrap(di(j,t,r,e,l,u,d,f,p,m,h,g,_,v));(0,n.If)(a.valid.and(a.pdf.greaterThan(0)),()=>{let e=(0,n.max)((0,n.float)(0),(0,n.dot)(t,a.direction)).toVar(),o=a.emission.x.add(a.emission.y).add(a.emission.z).toVar();(0,n.If)(e.greaterThan(0).and(o.mul(e).greaterThan(ie)).and(Gr({direction:a.direction,surfaceNormal:t})),()=>{let o=(0,n.min)(a.distance.sub(.001),(0,n.float)(1e3)).toVar(),s=ei(j,a.direction,o,u,Sn,y,b,x);(0,n.If)(s.greaterThan(0),()=>{let o=jr(i,a.direction,t,r),c=fi(i,a.direction,t,r).toVar(),l=(0,n.float)(1).toVar();(0,n.If)(c.greaterThan(0).and(N),()=>{let e=a.pdf.mul(ne).toVar(),t=c.mul(te).toVar();(0,n.If)(a.lightType.equal((0,n.int)(1)),()=>{l.assign($t({pdf1:e,pdf2:t}))})});let u=a.emission.mul(o).mul(e).mul(s).mul(l).div((0,n.max)(a.pdf,1e-10));A.addAssign(u.mul(oe).div((0,n.max)(ne,1e-10)))})})})}),(0,n.If)(de,()=>{(0,n.If)(o.greaterThan(0).and(N),()=>{let i=(0,n.max)((0,n.float)(0),(0,n.dot)(t,a)).toVar();(0,n.If)(i.greaterThan(0).and(Gr({direction:a,surfaceNormal:t})),()=>{(0,n.If)(m.greaterThan((0,n.int)(0)),()=>{let c=(0,n.bool)(!1).toVar(),l=(0,n.float)(0).toVar(),d=(0,n.int)(-1).toVar();(0,n.Loop)({start:(0,n.int)(0),end:m,type:`int`,condition:`<`},({i})=>{let o=Ir.wrap(Hr(p,i));(0,n.If)(o.intensity.greaterThan(0),()=>{let s=ri(o,e,t,r).toVar();(0,n.If)(s.greaterThanEqual(ie),()=>{(0,n.If)(Yr(o,j,a).toVar().greaterThan(0),()=>{(0,n.If)(s.greaterThan(l),()=>{l.assign(s),d.assign(i)}),c.assign((0,n.bool)(!0))})})})}),(0,n.If)(c.and(d.greaterThanEqual((0,n.int)(0))),()=>{let e=Ir.wrap(Hr(p,d)),t=Yr(e,j,a).toVar();(0,n.If)(t.greaterThan(0),()=>{let r=ei(j,a,(0,n.min)(t.sub(.001),(0,n.float)(1e3)).toVar(),u,Sn,y,b,x);(0,n.If)(r.greaterThan(0),()=>{let c=(0,n.max)((0,n.float)(0),(0,n.dot)(a,e.normal).negate()).toVar();(0,n.If)(c.greaterThan(0),()=>{let a=t.mul(t).toVar().div((0,n.max)(e.area.mul(c),K)).toVar();a.divAssign((0,n.max)((0,n.float)(re),1));let l=$t({pdf1:o.mul(te).toVar(),pdf2:a.mul(ne).toVar()}).toVar(),u=e.color.mul(e.intensity).toVar().mul(s).mul(i).mul(r).mul(l).div((0,n.max)(o,1e-10));A.addAssign(u.mul(oe).div((0,n.max)(te,1e-10)))})})})})})})})}),(0,n.If)(k,()=>{let e=(0,n.vec2)(P(u).toVar(),P(u).toVar()).toVar(),a=(0,n.vec3)(0).toVar(),o=On(S,T,w,C,E,D,O,e,a).toVar(),s=o.xyz.toVar(),c=o.w.toVar();(0,n.If)(c.greaterThan(0),()=>{let e=(0,n.max)((0,n.float)(0),(0,n.dot)(t,s)).toVar();(0,n.If)(e.greaterThan(0).and(Gr({direction:s,surfaceNormal:t})),()=>{let o=ei(j,s,(0,n.float)(1e3),u,Sn,y,b,x);(0,n.If)(o.greaterThan(0),()=>{let l=jr(i,s,t,r),u=fi(i,s,t,r).toVar(),d=(0,n.select)(u.greaterThan(0),en({pdf1:c,pdf2:u}),(0,n.float)(1)).toVar(),f=a.mul(l).mul(e).mul(o).mul(d).div((0,n.max)(c,1e-10));A.addAssign(f)})})})})}),A}),mi=(0,n.Fn)(([e,t,r,i,a,o])=>{let s=(0,n.select)(o,i,(0,n.float)(1).div(i)).toVar(),c=e.add(t.mul(s)).toVar(),l=(0,n.dot)(c,c).toVar(),u=(0,n.select)(l.greaterThan(K),c.div((0,n.sqrt)(l)),r).toVar();(0,n.If)((0,n.dot)(u,r).lessThan(0),()=>{u.assign(u.negate())});let d=(0,n.abs)((0,n.dot)(e,u)).toVar(),f=(0,n.abs)((0,n.dot)(t,u)).toVar(),p=(0,n.abs)((0,n.dot)(r,u)).toVar(),m=nr(p,a).toVar(),h=d.add(f.mul(s)).toVar(),g=h.mul(h).toVar(),_=f.mul(s).mul(s).div((0,n.max)(g,K)).toVar();return m.mul(p).mul(_)}),hi=(0,n.Fn)(([e,t,r,i])=>{let a=e.add(t).toVar(),o=(0,n.dot)(a,a).toVar();return lr((0,n.max)((0,n.dot)(r,(0,n.select)(o.greaterThan(K),a.div((0,n.sqrt)(o)),r).toVar()),0).toVar(),(0,n.max)((0,n.dot)(r,e),0).toVar(),i)}),gi=(0,n.Fn)(([e,t,r,i,a])=>{let o=e.specularImportance.toVar(),s=o.greaterThan(.001).toVar(),c=e.diffuseImportance.toVar(),l=c.greaterThan(.001).toVar(),u=e.transmissionImportance.toVar(),d=u.greaterThan(.001).toVar(),f=e.clearcoatImportance.toVar(),p=f.greaterThan(.001).toVar(),m=o.add(c).add(u).add(f).toVar();return(0,n.If)(m.lessThan(.001),()=>{o.assign(0),c.assign(1),u.assign(0),f.assign(0),m.assign(1),s.assign((0,n.bool)(!1)),l.assign((0,n.bool)(!0)),d.assign((0,n.bool)(!1)),p.assign((0,n.bool)(!1))}).Else(()=>{let e=(0,n.float)(1).div(m).toVar();o.mulAssign(e),c.mulAssign(e),u.mulAssign(e),f.mulAssign(e),m.assign(1)}),Bt({envWeight:(0,n.float)(0),specularWeight:o,diffuseWeight:c,transmissionWeight:u,clearcoatWeight:f,totalWeight:m,useEnv:(0,n.bool)(!1),useSpecular:s,useDiffuse:l,useTransmission:d,useClearcoat:p})}),_i=(0,n.Fn)(([e,t])=>{let r=(0,n.int)(2).toVar(),i=(0,n.float)(1).toVar(),a=(0,n.float)(0).toVar(),o=(0,n.bool)(!1).toVar();return(0,n.If)(e.useSpecular.and(o.not()),()=>{a.addAssign(e.specularWeight),(0,n.If)(t.lessThan(a),()=>{r.assign(1),i.assign(e.specularWeight),o.assign((0,n.bool)(!0))})}),(0,n.If)(e.useDiffuse.and(o.not()),()=>{a.addAssign(e.diffuseWeight),(0,n.If)(t.lessThan(a),()=>{r.assign(2),i.assign(e.diffuseWeight),o.assign((0,n.bool)(!0))})}),(0,n.If)(e.useTransmission.and(o.not()),()=>{a.addAssign(e.transmissionWeight),(0,n.If)(t.lessThan(a),()=>{r.assign(3),i.assign(e.transmissionWeight),o.assign((0,n.bool)(!0))})}),(0,n.If)(e.useClearcoat.and(o.not()),()=>{r.assign(4),i.assign(e.clearcoatWeight),o.assign((0,n.bool)(!0))}),(0,n.If)(o.not(),()=>{r.assign(2),i.assign((0,n.select)(e.useDiffuse,e.diffuseWeight,(0,n.float)(1)))}),(0,n.vec2)((0,n.float)(r),i)}),vi=(0,n.Fn)(([e])=>(0,n.max)(e,0).mul(Ut)),yi=(0,n.Fn)(([e,t,r,i,a,o,s,c,l,u,d,f,p,m,h,g,_,v])=>{let y=(0,n.vec3)(0).toVar(),b=(0,n.vec3)(0).toVar(),x=(0,n.float)(0).toVar(),S=(0,n.float)(0).toVar(),C=(0,n.float)(0).toVar();return(0,n.If)(u.diffuseImportance.greaterThanEqual(0).and(u.specularImportance.greaterThanEqual(0)).and(u.transmissionImportance.greaterThanEqual(0)).and(u.clearcoatImportance.greaterThanEqual(0)).and(u.envmapImportance.greaterThanEqual(0)).toVar().not(),()=>{let e=(0,n.vec2)(P(l).toVar(),P(l).toVar()).toVar();y.assign(_r(t,e)),b.assign(r.color.xyz),x.assign(1),S.assign(1)}).Else(()=>{let s=Bt.wrap(gi(u,c,r,_,v).toVar()),d=P(l).toVar(),f=(0,n.vec2)(P(l).toVar(),P(l).toVar()).toVar(),p=_i(s,d).toVar(),m=(0,n.int)(p.x).toVar();p.y.toVar();let h=(0,n.vec3)(0).toVar(),g=(0,n.float)(0).toVar(),w=(0,n.vec3)(0).toVar();(0,n.If)(m.equal((0,n.int)(1)),()=>{h.assign(i),g.assign(a),w.assign(o)}).ElseIf(m.equal((0,n.int)(2)),()=>{h.assign(_r(t,f)),g.assign(vi((0,n.max)((0,n.dot)(t,h),0))),w.assign(jr(e,h,t,r))}).ElseIf(m.equal((0,n.int)(3)),()=>{let i=(0,n.dot)(e,t).greaterThan(0).toVar(),a=wr.wrap(Or(e,t,r.ior,r.roughness,i,r.dispersion,f,l).toVar());h.assign(a.direction),g.assign(a.pdf),w.assign(jr(e,h,t,r))}).Else(()=>{h.assign(i),g.assign(a),w.assign(o)});let T=(0,n.dot)(t,h).toVar(),E=(0,n.max)(T,0).toVar(),D=(0,n.abs)(T).toVar(),O=(0,n.float)(0).toVar();(0,n.If)(s.useSpecular,()=>{let i=lr((0,n.max)((0,n.dot)(t,(0,n.normalize)(e.add(h))),.001),(0,n.max)((0,n.dot)(t,e),.001),r.roughness);O.addAssign(s.specularWeight.mul(i))}),(0,n.If)(s.useDiffuse,()=>{let e=vi(E).toVar();O.addAssign(s.diffuseWeight.mul(e))}),(0,n.If)(s.useTransmission.and(r.transmission.greaterThan(0)),()=>{let i=(0,n.dot)(e,t).greaterThan(0).toVar(),a=mi(e,h,t,r.ior,r.roughness,i).toVar();O.addAssign(s.transmissionWeight.mul(a))}),(0,n.If)(s.useClearcoat.and(r.clearcoat.greaterThan(0)),()=>{let n=hi(e,h,t,r.clearcoatRoughness).toVar();O.addAssign(s.clearcoatWeight.mul(n))}),g.assign((0,n.max)(g,q)),O.assign((0,n.max)(O,q));let k=g.div(O).toVar(),A=(0,n.select)(m.equal((0,n.int)(3)),D,E),j=w.mul(A).mul(k).div(g).toVar();y.assign(h),b.assign(j),x.assign(k),S.assign(g),C.assign(O)}),Br({direction:y,throughput:b,misWeight:x,pdf:S,combinedPdf:C})}),bi=D({position:`vec3`,normal:`vec3`,emission:`vec3`,direction:`vec3`,distance:`float`,pdf:`float`,area:`float`,cosThetaLight:`float`,valid:`bool`}),xi=D({contribution:`vec3`,hasEmissive:`bool`,emissionOnly:`vec3`,distance:`float`}),Si=(0,n.Fn)(([e,t,r,i])=>{let a=(0,n.sqrt)(i.x),o=(0,n.float)(1).sub(a),s=i.y.mul(a),c=(0,n.float)(1).sub(o).sub(s);return e.mul(o).add(t.mul(s)).add(r.mul(c))}),Ci=(0,n.Fn)(([e,t,r])=>(0,n.length)((0,n.cross)(t.sub(e),r.sub(e))).mul(.5)),wi=(0,n.Fn)(([e,t,r,i])=>{let a=(0,n.normalize)(e.sub(i)),o=(0,n.normalize)(t.sub(i)),s=(0,n.normalize)(r.sub(i)),c=(0,n.abs)((0,n.dot)(a,(0,n.cross)(o,s))),l=(0,n.float)(1).add((0,n.dot)(o,s)).add((0,n.dot)(a,s)).add((0,n.dot)(a,o));return(0,n.max)((0,n.float)(2).mul((0,n.atan)(c,(0,n.max)(l,(0,n.float)(1e-10)))),(0,n.float)(0))}),Ti=(0,n.Fn)(([e,t,r,i])=>{let a=t.sub(e),o=r.sub(e),s=r.sub(t),c=(0,n.max)((0,n.dot)(a,a),(0,n.max)((0,n.dot)(o,o),(0,n.dot)(s,s))),l=(0,n.cross)(a,o),u=(0,n.dot)(l,l),d=(0,n.bool)(!1).toVar();return(0,n.If)(u.greaterThan(1e-20),()=>{let t=(0,n.dot)(l,i.sub(e)),r=t.mul(t).div(u);d.assign(c.greaterThan(r))}),d}),Ei=D({direction:`vec3`,position:`vec3`,solidAngle:`float`,valid:`bool`}),Di=(0,n.Fn)(([e])=>{let t=(0,n.length)(e);return(0,n.select)(t.greaterThan(1e-10),e.div(t),(0,n.vec3)(0))}),Oi=(0,n.Fn)(([e,t,r,i,a])=>{let o=Ei({direction:(0,n.vec3)(0),position:(0,n.vec3)(0),solidAngle:(0,n.float)(0),valid:!1}).toVar(),s=(0,n.normalize)(e.sub(i)),c=(0,n.normalize)(t.sub(i)),l=(0,n.normalize)(r.sub(i)),u=wi(e,t,r,i);return o.solidAngle.assign(u),(0,n.If)(u.greaterThan(1e-7),()=>{let d=(0,n.clamp)((0,n.dot)(Di((0,n.cross)(s,c)),Di((0,n.cross)(s,l))),-1,1),f=(0,n.sqrt)((0,n.max)((0,n.float)(1).sub(d.mul(d)),0)),p=(0,n.acos)(d),m=a.x.mul(u).sub(p),h=(0,n.sin)(m),g=(0,n.cos)(m),_=(0,n.clamp)((0,n.dot)(s,c),-1,1),v=g.sub(d),y=h.add(f.mul(_)),b=y.mul(g).sub(v.mul(h)).mul(d).sub(y),x=y.mul(h).add(v.mul(g)).mul(f),S=(0,n.clamp)((0,n.select)((0,n.abs)(x).greaterThan(1e-10),b.div(x),(0,n.float)(1)),-1,1),C=(0,n.dot)(l,s),w=Di(l.sub(s.mul(C))),T=(0,n.sqrt)((0,n.max)((0,n.float)(1).sub(S.mul(S)),0)),E=(0,n.normalize)(s.mul(S).add(w.mul(T))),D=(0,n.dot)(E,c),O=(0,n.float)(1).sub(a.y.mul((0,n.float)(1).sub(D))),k=(0,n.sqrt)((0,n.max)((0,n.float)(1).sub(O.mul(O)),0)),A=Di(E.sub(c.mul(D))),j=(0,n.normalize)(c.mul(O).add(A.mul(k))),M=(0,n.normalize)((0,n.cross)(t.sub(e),r.sub(e))),N=(0,n.dot)(M,j);(0,n.If)((0,n.abs)(N).greaterThan(1e-10),()=>{let t=(0,n.dot)(M,e.sub(i)).div(N);(0,n.If)(t.greaterThan(0),()=>{o.direction.assign(j),o.position.assign(i.add(j.mul(t))),o.valid.assign(!0)})})}),o}),ki=(0,n.Fn)(([e,t,r,i])=>{let a=r.sub(t),o=i.sub(t),s=e.sub(t),c=(0,n.dot)(a,a),l=(0,n.dot)(a,o),u=(0,n.dot)(o,o),d=(0,n.dot)(s,a),f=(0,n.dot)(s,o),p=(0,n.float)(1).div((0,n.max)(c.mul(u).sub(l.mul(l)),(0,n.float)(1e-10))),m=u.mul(d).sub(l.mul(f)).mul(p),h=c.mul(f).sub(l.mul(d)).mul(p);return(0,n.vec3)((0,n.float)(1).sub(m).sub(h),m,h)}),Ai=(0,n.Fn)(([e,t,r,i])=>{let a=(0,n.sqrt)(i.x),o=(0,n.float)(1).sub(a),s=i.y.mul(a),c=(0,n.float)(1).sub(o).sub(s);return(0,n.normalize)(e.mul(o).add(t.mul(s)).add(r.mul(c)))}),ji=(0,n.Fn)(([e])=>e.emissiveIntensity.greaterThan(0).and((0,n.length)(e.emissive).greaterThan(0)));(0,n.Fn)(([e,t])=>{let r=(0,n.float)(0).toVar();return(0,n.If)(ji(e),()=>{let n=e.emissive.x.add(e.emissive.y).add(e.emissive.z).div(3);r.assign(n.mul(e.emissiveIntensity).mul(t))}),r});var Mi=8,Ni=2,Pi=D({v0:`vec3`,v1:`vec3`,v2:`vec3`,n0:`vec3`,n1:`vec3`,n2:`vec3`,materialIndex:`int`}),Fi=(0,n.Fn)(([e,t])=>{let r=X(t,e,(0,n.int)(0),(0,n.int)(Mi)),i=X(t,e,(0,n.int)(1),(0,n.int)(Mi)),a=X(t,e,(0,n.int)(2),(0,n.int)(Mi)),o=X(t,e,(0,n.int)(3),(0,n.int)(Mi)),s=X(t,e,(0,n.int)(4),(0,n.int)(Mi)),c=X(t,e,(0,n.int)(5),(0,n.int)(Mi)),l=X(t,e,(0,n.int)(7),(0,n.int)(Mi));return Pi({v0:r.xyz,v1:i.xyz,v2:a.xyz,n0:o.xyz,n1:s.xyz,n2:c.xyz,materialIndex:(0,n.int)(l.z)})}),Ii=(0,n.Fn)(([e,t,r,i,a,o,s])=>{let c=Pi.wrap(Fi(e,a)),l=Ci(c.v0,c.v1,c.v2),u=X(o,c.materialIndex,(0,n.int)(Jt.EMISSIVE_ROUGHNESS),J),d=X(o,c.materialIndex,(0,n.int)(Jt.IOR_TRANSMISSION),J),f=(0,n.max)(u.x.add(u.y).add(u.z).div(3).mul(d.a).mul(l),(0,n.float)(1e-10)).div((0,n.max)(s,(0,n.float)(1e-10))),p=(0,n.float)(0).toVar();return(0,n.If)(Ti(c.v0,c.v1,c.v2,i),()=>{let e=wi(c.v0,c.v1,c.v2,i);p.assign(f.div((0,n.max)(e,(0,n.float)(1e-10))))}).Else(()=>{let e=(0,n.normalize)((0,n.cross)(c.v1.sub(c.v0),c.v2.sub(c.v0))),i=(0,n.max)((0,n.dot)(r.negate(),e),.001),a=t.mul(t),o=f.div(l);p.assign(o.mul(a).div(i))}),(0,n.max)(p,q)}),Li=(0,n.Fn)(([e,t,r,i])=>{let a=(0,n.int)(0).toVar(),o=r.sub(1).toVar();return(0,n.Loop)(a.lessThan(o),()=>{let r=a.add(o).div(2).toVar(),s=e.element(t.add(r.mul((0,n.int)(Ni)))).b;(0,n.If)(s.lessThan(i),()=>{a.assign(r.add(1))}).Else(()=>{o.assign(r)})}),a}),Ri=(0,n.Fn)(([e,t,r,i,a,o,s,c,l])=>{let u=bi({position:(0,n.vec3)(0),normal:(0,n.vec3)(0),emission:(0,n.vec3)(0),direction:(0,n.vec3)(0),distance:(0,n.float)(0),pdf:(0,n.float)(0),area:(0,n.float)(0),cosThetaLight:(0,n.float)(0),valid:!1}).toVar();return(0,n.If)(s.greaterThan((0,n.int)(0)),()=>{let r=Li(a,o,s,P(i)).toVar(),d=o.add(r.mul((0,n.int)(Ni))),f=a.element(d),p=a.element(d.add(1)),m=(0,n.int)(f.r),h=(0,n.max)(f.g,(0,n.float)(1e-10)),g=p.xyz,_=p.w,v=Pi.wrap(Fi(m,l)),y=(0,n.vec2)(P(i).toVar(),P(i).toVar()),b=(0,n.normalize)((0,n.cross)(v.v1.sub(v.v0),v.v2.sub(v.v0)));(0,n.If)(Ti(v.v0,v.v1,v.v2,e),()=>{let r=Ei.wrap(Oi(v.v0,v.v1,v.v2,e,y));(0,n.If)(r.valid.and(r.solidAngle.greaterThan(1e-7)),()=>{let i=r.direction,a=r.position,o=(0,n.dot)(i,t),s=(0,n.dot)(i,b.negate());(0,n.If)(o.greaterThan(0).and(s.greaterThan(0)),()=>{let t=ki(a,v.v0,v.v1,v.v2),o=(0,n.normalize)(v.n0.mul(t.x).add(v.n1.mul(t.y)).add(v.n2.mul(t.z))),l=(0,n.length)(a.sub(e)),d=h.div((0,n.max)(c,(0,n.float)(1e-10))).div(r.solidAngle);u.position.assign(a),u.normal.assign(o),u.emission.assign(g),u.direction.assign(i),u.distance.assign(l),u.pdf.assign((0,n.max)(d,q)),u.area.assign(_),u.cosThetaLight.assign(s),u.valid.assign(!0)})})}).Else(()=>{let r=Si(v.v0,v.v1,v.v2,y),i=Ai(v.n0,v.n1,v.n2,y),a=r.sub(e),o=(0,n.dot)(a,a),s=(0,n.sqrt)(o),l=a.div(s),d=(0,n.dot)(l,t),f=(0,n.dot)(l,i.negate());(0,n.If)(d.greaterThan(0).and(f.greaterThan(0)),()=>{let e=h.div((0,n.max)(c,(0,n.float)(1e-10)).mul(_)).mul(o).div(f);u.position.assign(r),u.normal.assign(i),u.emission.assign(g),u.direction.assign(l),u.distance.assign(s),u.pdf.assign((0,n.max)(e,q)),u.area.assign(_),u.cosThetaLight.assign(f),u.valid.assign(!0)})})}),u}),zi=(0,n.Fn)(([e,t,r,i,a,o,s,c,l,u,d,f,p,m,h,g])=>{let _=xi({contribution:(0,n.vec3)(0),hasEmissive:!1,emissionOnly:(0,n.vec3)(0),distance:(0,n.float)(0)}).toVar();return(0,n.If)(o.greaterThan((0,n.int)(1)).and(i.roughness.greaterThan(.9)).and(i.metalness.lessThan(.1)).not(),()=>{let o=bi.wrap(Ri(e,t,a,s,l,u,d,f,p));(0,n.If)(o.valid.and(o.pdf.greaterThan(0)),()=>{_.hasEmissive.assign(!0),_.emissionOnly.assign(o.emission),_.distance.assign(o.distance);let a=(0,n.max)((0,n.float)(0),(0,n.dot)(t,o.direction));(0,n.If)(a.greaterThan(0),()=>{let l=g(e,t,i),u=e.add(l),d=o.distance.sub(.001),f=m(u,o.direction,d,s);(0,n.If)(f.greaterThan(0),()=>{let e=h(r,o.direction,t,i),s=fi(r,o.direction,t,i),l=(0,n.select)(s.greaterThan(0),$t({pdf1:o.pdf,pdf2:s}),(0,n.float)(1));_.contribution.assign(o.emission.mul(e).mul(a).div(o.pdf).mul(f).mul(c).mul(l))})})})}),_}),Bi=(0,n.Fn)(([e,t,n,r,i,a,o,s,c,l,u,d,f,p,m,h])=>xi.wrap(zi(e,t,n,r,i,a,o,s,c,l,u,d,f,p,m,h)).contribution),Vi=4,Hi=2,Ui=32,Wi=(0,n.Fn)(([e,t,r,i,a,o,s])=>{let c=bi({position:(0,n.vec3)(0),normal:(0,n.vec3)(0),emission:(0,n.vec3)(0),direction:(0,n.vec3)(0),distance:(0,n.float)(0),pdf:(0,n.float)(0),area:(0,n.float)(0),cosThetaLight:(0,n.float)(0),valid:!1}).toVar(),l=(0,n.float)(1).toVar(),u=(0,n.int)(0).toVar(),d=(0,n.bool)(!1).toVar();return(0,n.Loop)(Ui,()=>{let t=u.mul((0,n.int)(Vi)),a=i.element(t.add((0,n.int)(1))),o=i.element(t.add((0,n.int)(2)));(0,n.If)(a.w.greaterThan(.5),()=>{d.assign((0,n.bool)(!0)),(0,n.Break)()});let s=(0,n.int)(o.x),c=(0,n.int)(o.y),f=s.mul((0,n.int)(Vi)),p=i.element(f),m=i.element(f.add((0,n.int)(1))),h=c.mul((0,n.int)(Vi)),g=i.element(h),_=i.element(h.add((0,n.int)(1))),v=(0,n.vec3)(p.x.add(m.x).mul(.5),p.y.add(m.y).mul(.5),p.z.add(m.z).mul(.5)),y=(0,n.vec3)(g.x.add(_.x).mul(.5),g.y.add(_.y).mul(.5),g.z.add(_.z).mul(.5)),b=v.sub(e),x=y.sub(e),S=(0,n.max)((0,n.dot)(b,b),(0,n.float)(.01)),C=(0,n.max)((0,n.dot)(x,x),(0,n.float)(.01)),w=(0,n.max)(p.w,(0,n.float)(0)),T=(0,n.max)(g.w,(0,n.float)(0)),E=w.div(S),D=T.div(C),O=E.add(D);(0,n.If)(O.lessThanEqual((0,n.float)(0)),()=>{u.assign(s)}).Else(()=>{let e=E.div(O);(0,n.If)(P(r).lessThan(e),()=>{l.mulAssign(e),u.assign(s)}).Else(()=>{l.mulAssign((0,n.float)(1).sub(e)),u.assign(c)})})}),(0,n.If)(d,()=>{let d=u.mul((0,n.int)(Vi)),f=i.element(d),p=i.element(d.add((0,n.int)(2))),m=(0,n.int)(p.x),h=(0,n.int)(p.y),g=(0,n.max)(f.w,(0,n.float)(1e-10)),_=P(r).mul(g),v=(0,n.float)(0).toVar(),y=m.add(h.sub((0,n.int)(1))).toVar(),b=(0,n.float)(1e-10).toVar();(0,n.Loop)({start:(0,n.int)(0),end:h},({i:e})=>{let t=m.add(e),r=o.add(t.mul((0,n.int)(Hi))),i=(0,n.max)(a.element(r).g,(0,n.float)(0));v.addAssign(i),(0,n.If)(v.greaterThanEqual(_).and(i.greaterThan((0,n.float)(0))),()=>{y.assign(t),b.assign(i),(0,n.Break)()})}),l.mulAssign(b.div(g));let x=o.add(y.mul((0,n.int)(Hi))),S=a.element(x),C=a.element(x.add((0,n.int)(1))),w=(0,n.int)(S.r),T=C.xyz,E=C.w,D=Pi.wrap(Fi(w,s)),O=(0,n.vec2)(P(r).toVar(),P(r).toVar()),k=(0,n.normalize)((0,n.cross)(D.v1.sub(D.v0),D.v2.sub(D.v0)));(0,n.If)(Ti(D.v0,D.v1,D.v2,e),()=>{let r=Ei.wrap(Oi(D.v0,D.v1,D.v2,e,O));(0,n.If)(r.valid.and(r.solidAngle.greaterThan((0,n.float)(1e-7))),()=>{let i=r.direction,a=r.position,o=(0,n.dot)(i,t),s=(0,n.dot)(i,k.negate());(0,n.If)(o.greaterThan((0,n.float)(0)).and(s.greaterThan((0,n.float)(0))),()=>{let t=ki(a,D.v0,D.v1,D.v2),o=(0,n.normalize)(D.n0.mul(t.x).add(D.n1.mul(t.y)).add(D.n2.mul(t.z))),u=(0,n.length)(a.sub(e)),d=l.div((0,n.max)(r.solidAngle,(0,n.float)(1e-10)));c.position.assign(a),c.normal.assign(o),c.emission.assign(T),c.direction.assign(i),c.distance.assign(u),c.pdf.assign((0,n.max)(d,q)),c.area.assign(E),c.cosThetaLight.assign(s),c.valid.assign(!0)})})}).Else(()=>{let r=Si(D.v0,D.v1,D.v2,O),i=Ai(D.n0,D.n1,D.n2,O),a=r.sub(e),o=(0,n.dot)(a,a),s=(0,n.sqrt)(o),u=a.div(s),d=(0,n.dot)(u,t),f=(0,n.dot)(u,i.negate());(0,n.If)(d.greaterThan((0,n.float)(0)).and(f.greaterThan((0,n.float)(0))),()=>{let e=l.div((0,n.max)(E,(0,n.float)(1e-10))).mul(o).div(f);c.position.assign(r),c.normal.assign(i),c.emission.assign(T),c.direction.assign(u),c.distance.assign(s),c.pdf.assign((0,n.max)(e,q)),c.area.assign(E),c.cosThetaLight.assign(f),c.valid.assign(!0)})})}),c}),Gi=0,Ki=1,qi=2,Ji=3,Yi=D({radiance:`vec4`,objectNormal:`vec3`,objectColor:`vec3`,objectID:`float`,firstHitPoint:`vec3`,firstHitDistance:`float`}),Xi=(0,n.Fn)(([e,t,r,i,a])=>{let o=a.toVar();return(0,n.If)(r.not().or(i.notEqual(t)),()=>{o.assign(sn(e.metalness,e.roughness,e.transmission,e.clearcoat,e.emissive))}),o}),Zi=(0,n.Fn)(([e,t,r,i,a,o,s,c,l,u,d,f,p])=>{let m=(0,n.vec3)(0).toVar(),h=(0,n.vec3)(0).toVar(),g=(0,n.float)(0).toVar(),_=Lt.wrap(Xi(r,i,s,c,l)).toVar(),v=d.toVar();(0,n.If)(u.not(),()=>{(0,n.If)(f,()=>{v.assign(fr(r,_,p))}).Else(()=>{let e=zt({F0:tr(r.ior),NoV:(0,n.float)(1),diffuseColor:(0,n.vec3)(0),isPurelyDiffuse:!1,alpha:(0,n.float)(0),k:(0,n.float)(0),alpha2:(0,n.float)(0),invRoughness:(0,n.float)(1).sub(r.roughness),metalFactor:(0,n.float)(.5).add((0,n.float)(.5).mul(r.metalness)),iorFactor:(0,n.min)((0,n.float)(2).div(r.ior),1),maxSheenColor:(0,n.max)(r.sheenColor.x,(0,n.max)(r.sheenColor.y,r.sheenColor.z))}).toVar();v.assign(fr(r,_,e))})});let y=a.x.toVar(),b=(0,n.vec2)(a.y,P(o)).toVar(),x=(0,n.vec3)(0).toVar(),S=v.diffuse.toVar(),C=S.add(v.specular).toVar(),w=C.add(v.sheen).toVar(),T=w.add(v.clearcoat).toVar(),E=(0,n.bool)(!1).toVar();(0,n.If)(y.lessThan(S).and(E.not()),()=>{m.assign(gr({N:t,xi:b}));let i=(0,n.clamp)((0,n.dot)(t,m),0,1);g.assign(i.mul(Ut)),h.assign(jr(e,m,t,r)),E.assign((0,n.bool)(!0))});let D=(0,n.clamp)((0,n.dot)(t,e),.001,1).toVar();return(0,n.If)(y.lessThan(C).and(E.not()),()=>{let i=tn({N:t}),o=vr({V:i.transpose().mul(e).toVar(),roughness:r.roughness,Xi:a});x.assign(i.mul(o));let s=(0,n.clamp)((0,n.dot)(t,x),.001,1);m.assign((0,n.reflect)(e.negate(),x)),g.assign(lr(s,D,r.roughness)),h.assign(jr(e,m,t,r)),E.assign((0,n.bool)(!0))}),(0,n.If)(y.lessThan(w).and(E.not()),()=>{x.assign(hr({N:t,roughness:r.sheenRoughness,Xi:a}));let i=(0,n.clamp)((0,n.dot)(t,x),.001,1),o=(0,n.clamp)((0,n.dot)(e,x),.001,1);m.assign((0,n.reflect)(e.negate(),x));let s=(0,n.dot)(t,m).toVar();(0,n.If)(s.lessThanEqual(0),()=>{m.assign(gr({N:t,xi:a})),s.assign((0,n.clamp)((0,n.dot)(t,m),0,1)),g.assign(s.mul(Ut)),h.assign(jr(e,m,t,r))}).Else(()=>{g.assign(rr(i,r.sheenRoughness).mul(i).div((0,n.float)(4).mul(o))),g.assign((0,n.max)(g,q)),h.assign(jr(e,m,t,r))}),E.assign((0,n.bool)(!0))}),(0,n.If)(y.lessThan(T).and(E.not()),()=>{let i=(0,n.clamp)(r.clearcoatRoughness,Kt,1);x.assign(hr({N:t,roughness:i,Xi:a}));let o=(0,n.clamp)((0,n.dot)(t,x),0,1);m.assign((0,n.reflect)(e.negate(),x)),g.assign(lr(o,D,i)),g.assign((0,n.max)(g,q)),h.assign(jr(e,m,t,r)),E.assign((0,n.bool)(!0))}),(0,n.If)(E.not(),()=>{let i=(0,n.dot)(e,t).greaterThan(0).toVar(),s=wr.wrap(Or(e,t,r.ior,r.roughness,i,r.dispersion,a,o));m.assign(s.direction),g.assign((0,n.max)(s.pdf,q)),h.assign(jr(e,m,t,r))}),g.assign((0,n.max)(g,q)),Mt({direction:m,value:h,pdf:g})}),Qi=(0,n.Fn)(([e,t,r,i,a,o,s,c,l])=>{let u=(0,n.max)(Zt({v:e}),0).toVar(),d=Lt.wrap(Xi(r,i,a,o,s)).toVar(),f=d.complexityScore.toVar();(0,n.If)(d.isMetallic.and(d.isSmooth),()=>{f.addAssign(.15)}),(0,n.If)(d.isTransmissive.and(d.hasClearcoat),()=>{f.addAssign(.12)}),(0,n.If)(d.isEmissive,()=>{f.addAssign(.1)}),f.assign((0,n.clamp)(f,0,1));let p=(0,n.float)(.5).toVar();(0,n.If)(c.and(l).and(u.greaterThan(.01)),()=>{let e=(0,n.clamp)(t.y,0,1);p.assign((0,n.mix)((0,n.float)(.3),(0,n.float)(.8),e.mul(e)))});let m=(0,n.smoothstep)((0,n.float)(.001),(0,n.float)(.1),u);return u.mul((0,n.mix)(f.mul(.7),p,.3)).mul(m)}),$i=(0,n.Fn)(([e,t,r,i,a,o,s,c,l,u,d,f,p])=>{let m=(0,n.float)(1).toVar();return(0,n.If)(e.greaterThanEqual((0,n.int)(3)),()=>{let h=(0,n.max)(Zt({v:t}),0).toVar();(0,n.If)(h.lessThan(8e-4).and(e.greaterThan((0,n.int)(4))),()=>{let e=(0,n.max)(h.mul(125),.01),t=P(o);m.assign((0,n.select)(t.lessThan(e),e,(0,n.float)(0)))}).Else(()=>{let g=Lt.wrap(Xi(r,i,s,c,l)).toVar(),_=g.complexityScore.toVar();(0,n.If)(g.isMetallic.and(g.isSmooth).and(e.lessThan((0,n.int)(7))),()=>{_.addAssign(.3)}),(0,n.If)(g.isTransmissive.and(e.lessThan((0,n.int)(6))),()=>{_.addAssign(.25)}),(0,n.If)(g.isEmissive.and(e.lessThan((0,n.int)(4))),()=>{_.addAssign(.15)}),_.assign((0,n.clamp)(_,0,1));let v=(0,n.int)(3).toVar();(0,n.If)(_.greaterThan(.6),()=>{v.assign(5)}).ElseIf(_.greaterThan(.4),()=>{v.assign(4)}),(0,n.If)(e.lessThan(v),()=>{m.assign(1)}).Else(()=>{let y=(0,n.float)(0).toVar();(0,n.If)(s.and(u),()=>{y.assign(d)}).Else(()=>{y.assign(Qi(t,a,r,i,s,c,l,f,p))});let b=(0,n.mix)((0,n.clamp)(_.mul(.4).add(h.mul(.6)).mul(1.2),.15,.95),(0,n.clamp)(h.mul(.4).add(_.mul(.1)),.03,.6),(0,n.clamp)((0,n.float)(e.sub(v)).div(10),0,1)).toVar();b.assign((0,n.mix)(b,(0,n.max)(b,y),.4)),(0,n.If)(_.greaterThan(.5),()=>{let e=_.sub(.5).mul(.6);b.assign((0,n.mix)(b,(0,n.float)(1),e))});let x=(0,n.float)(.12).add(_.mul(.08)),S=(0,n.exp)((0,n.float)(e.sub(v)).negate().mul(x));b.mulAssign(S);let C=(0,n.select)(g.isEmissive,(0,n.float)(.04),(0,n.float)(.02));b.assign((0,n.max)(b,C));let w=P(o);m.assign((0,n.select)(w.lessThan(b),b,(0,n.float)(0)))})})}),m}),ea=(0,n.Fn)(([e,t,r,i,a,o,s,c])=>{let l=(0,n.vec4)(0).toVar();return(0,n.If)(e.and(s.not()),()=>{l.assign((0,n.vec4)(0))}).Else(()=>{let s=kn({tex:r,samp:(0,n.sampler)(r),direction:t,environmentMatrix:i,environmentIntensity:a,enableEnvironmentLight:o});(0,n.If)(e,()=>{l.assign(s.mul(c))}).Else(()=>{l.assign(s)})}),l}),ta=(0,n.wgslFn)(`
482
+ `),Fr=(0,n.Fn)(([e,t,r])=>{let i=e.normal,a=(0,n.dot)(i,r),o=(0,n.float)(-1).toVar();return(0,n.If)(a.lessThan(-1e-4),()=>{let s=(0,n.float)(1).div(a),c=(0,n.dot)(e.position.sub(t),i).mul(s).toVar();(0,n.If)(c.greaterThan(.001),()=>{let i=t.add(r.mul(c)).sub(e.position),a=(0,n.length)(e.u),s=(0,n.length)(e.v),l=e.u.div(a),u=e.v.div(s),d=(0,n.dot)(i,l),f=(0,n.dot)(i,u);(0,n.If)((0,n.abs)(d).lessThanEqual(a).and((0,n.abs)(f).lessThanEqual(s)),()=>{o.assign(c)})})}),o}),Ir=null,Lr=null;function Rr(e){Ir=e}function zr(e){Lr=e}var Br=(0,n.Fn)(([e,t,r,i,a,o,s,c])=>{let l=(0,n.float)(1).toVar(),u=e.toVar(),d=(0,n.float)(r).toVar();return(0,n.Loop)({start:(0,n.int)(0),end:(0,n.int)(8)},()=>{let e=gt({origin:u,direction:t}),r=yt.wrap(a(e,o,s,c,d));(0,n.If)(r.didHit.not(),()=>{(0,n.Break)()});let i=(0,n.int)(8),f=X(s,r.triangleIndex,(0,n.int)(3),i).w;(0,n.If)(f.greaterThan(.5),()=>{l.assign(0),(0,n.Break)()});let p=vt.wrap(en(r.materialIndex,c)),m=(0,n.bool)(!1).toVar();Lr&&(0,n.If)(Lr.equal((0,n.int)(1)),()=>{let e=(0,n.float)(1).toVar();Ir&&(0,n.If)(p.albedoMapIndex.greaterThanEqual((0,n.int)(0)),()=>{let t=r.uv.x,i=r.uv.y,a=(0,n.float)(1).sub(t).sub(i),o=(0,n.int)(8),c=X(s,r.triangleIndex,(0,n.int)(6),o),l=X(s,r.triangleIndex,(0,n.int)(7),o),u=xn({uv:c.xy.mul(a).add(c.zw.mul(t)).add(l.xy.mul(i)),transform:p.albedoTransform});e.assign((0,n.texture)(Ir,u).depth((0,n.int)(p.albedoMapIndex)).a)}),(0,n.If)(p.alphaMode.equal((0,n.int)(1)),()=>{let t=p.color.a.mul(e),r=(0,n.select)(p.alphaTest.greaterThan(0),p.alphaTest,(0,n.float)(.5));(0,n.If)(t.lessThan(r),()=>{m.assign(!0)})}).ElseIf(p.alphaMode.equal((0,n.int)(2)),()=>{let t=(0,n.clamp)(p.color.a.mul(p.opacity).mul(e),0,1);l.mulAssign((0,n.float)(1).sub(t)),(0,n.If)(l.lessThan(.005),()=>{l.assign(0),(0,n.Break)()}),m.assign(!0)})}),(0,n.If)(m,()=>{let e=(0,n.max)((0,n.float)(1e-5),(0,n.length)(r.hitPoint).mul(1e-6));u.assign(r.hitPoint.add(t.mul(e))),d.subAssign(r.dst.add(e))}).ElseIf(p.transmission.greaterThan(0),()=>{let e=(0,n.dot)(t,r.normal).lessThan(0),i=(0,n.select)(e,r.normal,r.normal.negate());(0,n.If)(e.not().and(p.attenuationDistance.greaterThan(0)),()=>{let e=(0,n.length)(r.hitPoint.sub(u)),t=mr(p.attenuationColor,p.attenuationDistance,e);l.mulAssign(t.x.add(t.y).add(t.z).div(3))});let a=Bn((0,n.abs)((0,n.dot)(t,i)),Wn(p.ior,(0,n.float)(1))),o=(0,n.float)(1).sub(a).mul(p.transmission);l.mulAssign(o),(0,n.If)(l.lessThan(.005),()=>{l.assign(0),(0,n.Break)()}),u.assign(r.hitPoint.add(t.mul(.001))),d.subAssign(r.dst.add(.001))}).ElseIf(p.transparent,()=>{l.mulAssign((0,n.float)(1).sub(p.opacity)),(0,n.If)(l.lessThan(.005),()=>{l.assign(0),(0,n.Break)()}),u.assign(r.hitPoint.add(t.mul(.001))),d.subAssign(r.dst.add(.001))}).Else(()=>{l.assign(0),(0,n.Break)()})}),l}),Vr=(0,n.Fn)(([e,t,r])=>{let i=(0,n.max)((0,n.float)(1e-4),(0,n.length)(e).mul(1e-6)).toVar().toVar();return(0,n.If)(r.transmission.greaterThan(0),()=>{i.mulAssign(2)}),(0,n.If)(r.roughness.lessThan(.1),()=>{i.mulAssign(1.5)}),t.mul(i)}),Hr=(0,n.Fn)(([e,t,r,i,a])=>{let o=(0,n.max)((0,n.float)(0),(0,n.dot)(r,e.direction)),s=(0,n.float)(0).toVar();return(0,n.If)(o.greaterThan(0),()=>{let t=e.intensity.mul((0,n.dot)(e.color,Lt)),r=(0,n.float)(1).toVar();(0,n.If)(i.metalness.greaterThan(.7),()=>{r.assign(1.5)}).ElseIf(i.roughness.greaterThan(.8),()=>{r.assign(.7)});let c=(0,n.float)(1).div((0,n.float)(1).add((0,n.float)(a).mul(.5)));s.assign(t.mul(o).mul(r).mul(c))}),s}),Ur=(0,n.Fn)(([e,t,r,i])=>{let a=e.position.sub(t),o=(0,n.length)(a),s=o.mul(o),c=a.div(o),l=(0,n.max)((0,n.dot)(r,c),0),u=(0,n.float)(0).toVar();return(0,n.If)(l.greaterThan(0),()=>{let t=(0,n.max)((0,n.dot)(c,e.normal).negate(),0);(0,n.If)(t.greaterThan(0),()=>{let r=e.area.div((0,n.max)(s,.1)),a=e.intensity.mul((0,n.dot)(e.color,Lt)).mul(e.area),o=(0,n.float)(1).toVar();(0,n.If)(i.metalness.greaterThan(.7),()=>{o.mulAssign(1.5),(0,n.If)(i.roughness.lessThan(.3),()=>{o.mulAssign((0,n.float)(1).add((0,n.float)(1).sub(i.roughness).mul(.5)))})}),(0,n.If)(i.roughness.greaterThan(.6).and(i.metalness.lessThan(.3)),()=>{let t=(0,n.min)(e.area.mul(2),(0,n.float)(2));o.mulAssign(t)}),(0,n.If)(i.transmission.greaterThan(.5),()=>{o.mulAssign((0,n.float)(1).add(i.transmission.mul(.3)))}),u.assign(a.mul(r).mul(l).mul(t).mul(o))})}),u}),Wr=(0,n.Fn)(([e,t,r,i])=>{let a=e.position.sub(t),o=(0,n.dot)(a,a),s=(0,n.float)(0).toVar();return(0,n.If)(o.greaterThanEqual(.001),()=>{let t=(0,n.sqrt)(o),c=a.div(t),l=(0,n.max)((0,n.float)(0),(0,n.dot)(r,c));(0,n.If)(l.greaterThan(0),()=>{let t=(0,n.float)(1).div((0,n.max)(o,.1)),r=e.intensity.mul((0,n.dot)(e.color,Lt)),a=(0,n.float)(1).toVar();(0,n.If)(i.metalness.greaterThan(.7),()=>{a.mulAssign(1.5),(0,n.If)(i.roughness.lessThan(.3),()=>{a.mulAssign((0,n.float)(1).add((0,n.float)(1).sub(i.roughness).mul(.4)))})}),(0,n.If)(i.roughness.greaterThan(.6),()=>{a.mulAssign(.9)}),(0,n.If)(i.transmission.greaterThan(.5),()=>{a.mulAssign((0,n.float)(1).add(i.transmission.mul(.2)))}),s.assign(r.mul(t).mul(l).mul(a))})}),s}),Gr=(0,n.Fn)(([e,t,r,i])=>{let a=e.position.sub(t),o=(0,n.dot)(a,a),s=(0,n.float)(0).toVar();return(0,n.If)(o.greaterThanEqual(.001),()=>{let t=a.div((0,n.sqrt)(o)),c=(0,n.max)((0,n.float)(0),(0,n.dot)(r,t));(0,n.If)(c.greaterThan(0),()=>{let r=(0,n.dot)(t.negate(),e.direction),a=(0,n.cos)(e.angle);(0,n.If)(r.greaterThanEqual(a),()=>{let t=(0,n.float)(1).div((0,n.max)(o,.01)),l=(0,n.smoothstep)(a,a.add(.1),r),u=e.intensity.mul((0,n.dot)(e.color,Lt)),d=(0,n.select)(i.metalness.greaterThan(.7),(0,n.float)(1.5),(0,n.select)(i.roughness.greaterThan(.8),(0,n.float)(.8),(0,n.float)(1)));s.assign(u.mul(t).mul(l).mul(c).mul(d))})})}),s}),Kr=2*At,qr=(0,n.Fn)(([e,t,r,i])=>{let a=(0,n.bool)(!1).toVar(),o=(0,n.vec3)(0,1,0).toVar(),s=(0,n.vec3)(0).toVar(),c=(0,n.float)(0).toVar(),l=(0,n.float)(0).toVar(),u=(0,n.int)(2).toVar();return(0,n.If)(e.area.greaterThan(0),()=>{let d=e.position.add(e.u.mul(r.x.mul(2).sub(1))).add(e.v.mul(r.y.mul(2).sub(1))).toVar().sub(t).toVar(),f=(0,n.dot)(d,d).toVar();(0,n.If)(f.greaterThanEqual(1e-10),()=>{let t=(0,n.sqrt)(f).toVar(),r=d.div(t).toVar(),p=(0,n.normalize)((0,n.cross)(e.u,e.v)).toVar(),m=(0,n.dot)(r.negate(),p).toVar();u.assign((0,n.int)(1)),s.assign(e.color.mul(e.intensity)),c.assign(t),o.assign(r),l.assign(f.div((0,n.max)(e.area.mul((0,n.max)(m,.001)),1e-10)).mul(i)),a.assign(m.greaterThan(0))})}),Er({valid:a,direction:o,emission:s,distance:c,pdf:l,lightType:u})}),Jr=(0,n.Fn)(([e,t,r,i])=>{let a=(0,n.bool)(!1).toVar(),o=(0,n.vec3)(0,1,0).toVar(),s=(0,n.vec3)(0).toVar(),c=(0,n.float)(0).toVar(),l=(0,n.float)(0).toVar(),u=(0,n.int)(3).toVar(),d=e.position.sub(t).toVar(),f=(0,n.length)(d).toVar();return(0,n.If)(f.greaterThanEqual(1e-10),()=>{let t=d.div(f).toVar(),r=(0,n.dot)(t.negate(),e.direction).toVar(),u=(0,n.cos)(e.angle).toVar();o.assign(t),c.assign(f),l.assign(i),a.assign(r.greaterThanEqual(u)),(0,n.If)(a,()=>{let t=Pr({coneCosine:u,penumbraCosine:(0,n.cos)(e.angle.mul((0,n.float)(1).sub(e.penumbra))).max(u.add(1e-5)).toVar(),angleCosine:r}),i=Nr({lightDistance:f,cutoffDistance:e.distance,decayExponent:e.decay});s.assign(e.color.mul(e.intensity).mul(i).mul(t))})}),Er({valid:a,direction:o,emission:s,distance:c,pdf:l,lightType:u})}),Yr=(0,n.Fn)(([e,t,r])=>{let i=(0,n.bool)(!1).toVar(),a=(0,n.vec3)(0,1,0).toVar(),o=(0,n.vec3)(0).toVar(),s=(0,n.float)(0).toVar(),c=(0,n.float)(0).toVar(),l=(0,n.int)(2).toVar(),u=e.position.sub(t).toVar(),d=(0,n.length)(u).toVar();return(0,n.If)(d.greaterThanEqual(1e-10),()=>{let t=u.div(d).toVar(),f=Nr({lightDistance:d,cutoffDistance:e.distance,decayExponent:e.decay});l.assign((0,n.int)(2)),a.assign(t),s.assign(d),o.assign(e.color.mul(e.intensity).mul(f)),c.assign(r),i.assign((0,n.bool)(!0))}),Er({valid:i,direction:a,emission:o,distance:s,pdf:c,lightType:l})}),Xr=(0,n.Fn)(([e,t,r,i,a,o,s,c,l,u,d,f,p,m])=>{let h=(0,n.bool)(!1).toVar(),g=(0,n.vec3)(0,1,0).toVar(),_=(0,n.vec3)(0).toVar(),v=(0,n.float)(0).toVar(),y=(0,n.float)(0).toVar(),b=(0,n.int)(2).toVar(),x=c.add(u).add(f).add(m).toVar();return(0,n.If)(x.greaterThan((0,n.int)(0)),()=>{let S=(0,n.float)(0).toVar(),C=(0,n.int)(0).toVar();(0,n.If)(c.greaterThan((0,n.int)(0)),()=>{(0,n.Loop)({start:(0,n.int)(0),end:c,type:`int`,condition:`<`},({i})=>{(0,n.If)(C.lessThan((0,n.int)(16)),()=>{let n=Sr.wrap(Or(s,i));S.addAssign(Hr(n,e,t,r,a)),C.addAssign(1)})})}),(0,n.If)(u.greaterThan((0,n.int)(0)),()=>{(0,n.Loop)({start:(0,n.int)(0),end:u,type:`int`,condition:`<`},({i})=>{(0,n.If)(C.lessThan((0,n.int)(16)),()=>{let a=Cr.wrap(kr(l,i)),o=(0,n.select)(a.intensity.greaterThan(0),Ur(a,e,t,r),(0,n.float)(0));S.addAssign(o),C.addAssign(1)})})}),(0,n.If)(f.greaterThan((0,n.int)(0)),()=>{(0,n.Loop)({start:(0,n.int)(0),end:f,type:`int`,condition:`<`},({i})=>{(0,n.If)(C.lessThan((0,n.int)(16)),()=>{let n=wr.wrap(Ar(d,i));S.addAssign(Wr(n,e,t,r)),C.addAssign(1)})})}),(0,n.If)(m.greaterThan((0,n.int)(0)),()=>{(0,n.Loop)({start:(0,n.int)(0),end:m,type:`int`,condition:`<`},({i})=>{(0,n.If)(C.lessThan((0,n.int)(16)),()=>{let n=Tr.wrap(jr(p,i));S.addAssign(Gr(n,e,t,r)),C.addAssign(1)})})}),(0,n.If)(S.lessThanEqual(0),()=>{let t=(0,n.int)(i.x.mul((0,n.float)(x)).toVar()).toVar(),r=(0,n.float)(1).div((0,n.max)((0,n.float)(x),1)).toVar();y.assign(r);let a=(0,n.bool)(!1).toVar(),S=(0,n.int)(0).toVar();(0,n.If)(c.greaterThan((0,n.int)(0)),()=>{(0,n.If)(a.not().and(t.greaterThanEqual(S)).and(t.lessThan(S.add(c))),()=>{let e=Sr.wrap(Or(s,t.sub(S)));(0,n.If)(e.intensity.greaterThan(0),()=>{g.assign((0,n.normalize)(e.direction)),_.assign(e.color.mul(e.intensity)),v.assign(1e6),b.assign((0,n.int)(0)),h.assign((0,n.bool)(!0)),a.assign((0,n.bool)(!0))})}),S.addAssign(c)}),(0,n.If)(u.greaterThan((0,n.int)(0)),()=>{(0,n.If)(a.not().and(t.greaterThanEqual(S)).and(t.lessThan(S.add(u))),()=>{let s=Cr.wrap(kr(l,t.sub(S)));(0,n.If)(s.intensity.greaterThan(0),()=>{let t=(0,n.vec2)(i.y,N(o)).toVar(),c=Er.wrap(qr(s,e,t,r));h.assign(c.valid),g.assign(c.direction),_.assign(c.emission),v.assign(c.distance),y.assign(c.pdf),b.assign(c.lightType),a.assign((0,n.bool)(!0))})}),S.addAssign(u)}),(0,n.If)(f.greaterThan((0,n.int)(0)),()=>{(0,n.If)(a.not().and(t.greaterThanEqual(S)).and(t.lessThan(S.add(f))),()=>{let i=wr.wrap(Ar(d,t.sub(S)));(0,n.If)(i.intensity.greaterThan(0),()=>{let t=Er.wrap(Yr(i,e,r));h.assign(t.valid),g.assign(t.direction),_.assign(t.emission),v.assign(t.distance),y.assign(t.pdf),b.assign(t.lightType),a.assign((0,n.bool)(!0))})}),S.addAssign(f)}),(0,n.If)(m.greaterThan((0,n.int)(0)),()=>{(0,n.If)(a.not().and(t.greaterThanEqual(S)).and(t.lessThan(S.add(m))),()=>{let s=Tr.wrap(jr(p,t.sub(S)));(0,n.If)(s.intensity.greaterThan(0),()=>{let t=(0,n.vec2)(i.y,N(o)).toVar(),c=Er.wrap(Jr(s,e,t,r));h.assign(c.valid),g.assign(c.direction),_.assign(c.emission),v.assign(c.distance),y.assign(c.pdf),b.assign(c.lightType),a.assign((0,n.bool)(!0))})})})}).Else(()=>{let x=i.x.mul(S).toVar(),w=(0,n.float)(0).toVar();C.assign(0);let T=(0,n.int)(-1).toVar(),E=(0,n.int)(-1).toVar(),D=(0,n.float)(0).toVar();(0,n.If)(c.greaterThan((0,n.int)(0)),()=>{(0,n.Loop)({start:(0,n.int)(0),end:c,type:`int`,condition:`<`},({i})=>{(0,n.If)(C.lessThan((0,n.int)(16)).and(T.lessThan((0,n.int)(0))),()=>{let o=Hr(Sr.wrap(Or(s,i)),e,t,r,a).toVar(),c=w.toVar();w.addAssign(o),(0,n.If)(x.greaterThan(c).and(x.lessThanEqual(w)),()=>{T.assign(0),E.assign(i),D.assign(o)})}),C.addAssign(1)})}),(0,n.If)(u.greaterThan((0,n.int)(0)),()=>{(0,n.Loop)({start:(0,n.int)(0),end:u,type:`int`,condition:`<`},({i})=>{(0,n.If)(C.lessThan((0,n.int)(16)).and(T.lessThan((0,n.int)(0))),()=>{let a=Cr.wrap(kr(l,i)),o=(0,n.select)(a.intensity.greaterThan(0),Ur(a,e,t,r),(0,n.float)(0)).toVar(),s=w.toVar();w.addAssign(o),(0,n.If)(x.greaterThan(s).and(x.lessThanEqual(w)),()=>{T.assign(1),E.assign(i),D.assign(o)})}),C.addAssign(1)})}),(0,n.If)(f.greaterThan((0,n.int)(0)),()=>{(0,n.Loop)({start:(0,n.int)(0),end:f,type:`int`,condition:`<`},({i})=>{(0,n.If)(C.lessThan((0,n.int)(16)).and(T.lessThan((0,n.int)(0))),()=>{let a=Wr(wr.wrap(Ar(d,i)),e,t,r).toVar(),o=w.toVar();w.addAssign(a),(0,n.If)(x.greaterThan(o).and(x.lessThanEqual(w)),()=>{T.assign(2),E.assign(i),D.assign(a)})}),C.addAssign(1)})}),(0,n.If)(m.greaterThan((0,n.int)(0)),()=>{(0,n.Loop)({start:(0,n.int)(0),end:m,type:`int`,condition:`<`},({i})=>{(0,n.If)(C.lessThan((0,n.int)(16)).and(T.lessThan((0,n.int)(0))),()=>{let a=Gr(Tr.wrap(jr(p,i)),e,t,r).toVar(),o=w.toVar();w.addAssign(a),(0,n.If)(x.greaterThan(o).and(x.lessThanEqual(w)),()=>{T.assign(3),E.assign(i),D.assign(a)})}),C.addAssign(1)})});let O=D.div((0,n.max)(S,1e-10)).toVar();(0,n.If)(T.equal((0,n.int)(0)).and(E.greaterThanEqual((0,n.int)(0))),()=>{let e=Sr.wrap(Or(s,E)),t=(0,n.normalize)(e.direction).toVar(),r=(0,n.float)(1).toVar();(0,n.If)(e.angle.greaterThan(0),()=>{let a=(0,n.cos)(e.angle.mul(.5)).toVar(),s=(0,n.mix)(a,(0,n.float)(1),i.y).toVar(),c=(0,n.sqrt)((0,n.max)((0,n.float)(0),(0,n.float)(1).sub(s.mul(s)))).toVar(),l=(0,n.float)(Kr).mul(N(o)).toVar(),u=(0,n.normalize)(e.direction).toVar(),d=(0,n.normalize)((0,n.cross)((0,n.select)((0,n.abs)(u.x).greaterThan(.9),(0,n.vec3)(0,1,0),(0,n.vec3)(1,0,0)),u)).toVar(),f=(0,n.cross)(u,d).toVar();t.assign((0,n.normalize)(u.mul(s).add(d.mul((0,n.cos)(l)).add(f.mul((0,n.sin)(l))).mul(c))));let p=(0,n.float)(Kr).mul((0,n.max)((0,n.float)(1).sub(a),1e-10)).toVar();r.assign((0,n.float)(1).div(p))}),g.assign(t),_.assign(e.color.mul(e.intensity)),v.assign(1e6),y.assign(r.mul(O)),b.assign((0,n.int)(0)),h.assign((0,n.bool)(!0))}),(0,n.If)(T.equal((0,n.int)(1)).and(E.greaterThanEqual((0,n.int)(0))),()=>{let t=Cr.wrap(kr(l,E)),r=(0,n.vec2)(i.y,N(o)).toVar(),a=Er.wrap(qr(t,e,r,O));h.assign(a.valid),g.assign(a.direction),_.assign(a.emission),v.assign(a.distance),y.assign(a.pdf),b.assign(a.lightType)}),(0,n.If)(T.equal((0,n.int)(2)).and(E.greaterThanEqual((0,n.int)(0))),()=>{let t=wr.wrap(Ar(d,E)),n=Er.wrap(Yr(t,e,O));h.assign(n.valid),g.assign(n.direction),_.assign(n.emission),v.assign(n.distance),y.assign(n.pdf),b.assign(n.lightType)}),(0,n.If)(T.equal((0,n.int)(3)).and(E.greaterThanEqual((0,n.int)(0))),()=>{let t=Tr.wrap(jr(p,E)),r=(0,n.vec2)(i.y,N(o)).toVar(),a=Er.wrap(Jr(t,e,r,O));h.assign(a.valid),g.assign(a.direction),_.assign(a.emission),v.assign(a.distance),y.assign(a.pdf),b.assign(a.lightType)})})}),Er({valid:h,direction:g,emission:_,distance:v,pdf:y,lightType:b})}),Zr=(0,n.Fn)(([e,t,r,i])=>{let a=(0,n.max)((0,n.float)(0),(0,n.dot)(r,e)).toVar(),o=(0,n.max)((0,n.float)(0),(0,n.dot)(r,t)).toVar(),s=(0,n.normalize)(e.add(t)).toVar(),c=(0,n.max)((0,n.float)(0),(0,n.dot)(r,s)).toVar();(0,n.max)((0,n.float)(0),(0,n.dot)(e,s)).toVar();let l=(0,n.float)(1).sub(i.metalness).mul((0,n.float)(1).sub(i.transmission)).toVar(),u=(0,n.float)(1).sub(l.mul((0,n.float)(1).sub(i.metalness))).toVar(),d=l.add(u).toVar(),f=(0,n.float)(0).toVar();return(0,n.If)(d.greaterThan(0),()=>{let e=(0,n.float)(1).div((0,n.max)(d,1e-10)).toVar();l.mulAssign(e),u.mulAssign(e),(0,n.If)(l.greaterThan(0).and(o.greaterThan(0)),()=>{f.addAssign(l.mul(o).mul(jt))}),(0,n.If)(u.greaterThan(0).and(o.greaterThan(0)),()=>{let e=(0,n.max)(i.roughness,.02).toVar();f.addAssign(u.mul($n(c,a,e)))})}),(0,n.max)(f,1e-8)}),Qr=(0,n.Fn)(([e,t,r,i,a,o,s,c,l,u,d,f,p,m,h,g,_,v,y,b,x,S,C,w,T,E,D,O,k])=>{let A=(0,n.vec3)(0).toVar(),j=e.add(t.mul(.001)).toVar();return(0,n.If)(r.emissiveIntensity.lessThanEqual(10),()=>{let c=(0,n.vec3)(1).toVar(),M=kt.wrap(Zt(r.roughness,r.metalness,r.transmission,l,c)),P=M.useBRDFSampling.toVar(),ee=M.useLightSampling.toVar(),F=M.brdfWeight.toVar(),I=M.lightWeight.toVar(),te=f.add(m).add(g).add(v).toVar(),ne=(0,n.float)(.001).mul((0,n.float)(1).add((0,n.float)(l).mul(.5))).toVar(),re=te.greaterThan((0,n.int)(0)).toVar(),ie=(0,n.float)(0).toVar();(0,n.If)(ee.and(re),()=>{ie.addAssign(I)}),(0,n.If)(P,()=>{ie.addAssign(F)}),(0,n.If)(ie.lessThanEqual(0),()=>{ie.assign(1),P.assign((0,n.bool)(!0)),F.assign(1)});let ae=N(u).toVar(),oe=N(u).toVar(),L=ae,R=(0,n.bool)(!1).toVar(),se=(0,n.bool)(!1).toVar(),ce=(0,n.select)(re,I,(0,n.float)(0)).toVar(),z=(0,n.float)(1).div((0,n.max)(ie,1e-10)).toVar(),le=ce.mul(z).toVar();(0,n.If)(L.lessThan(le).and(ee).and(re),()=>{R.assign((0,n.bool)(!0))}).ElseIf(P,()=>{se.assign((0,n.bool)(!0))}).ElseIf(re,()=>{R.assign((0,n.bool)(!0))}),(0,n.If)(R,()=>{let e=(0,n.vec2)(oe,N(u)).toVar(),a=Er.wrap(Xr(j,t,r,e,l,u,d,f,p,m,h,g,_,v));(0,n.If)(a.valid.and(a.pdf.greaterThan(0)),()=>{let e=(0,n.max)((0,n.float)(0),(0,n.dot)(t,a.direction)).toVar(),o=a.emission.x.add(a.emission.y).add(a.emission.z).toVar();(0,n.If)(e.greaterThan(0).and(o.mul(e).greaterThan(ne)).and(Mr({direction:a.direction,surfaceNormal:t})),()=>{let o=(0,n.min)(a.distance.sub(.001),(0,n.float)(1e3)).toVar(),s=Br(j,a.direction,o,u,fn,y,b,x);(0,n.If)(s.greaterThan(0),()=>{let o=vr(i,a.direction,t,r),c=Zr(i,a.direction,t,r).toVar(),l=(0,n.float)(1).toVar();(0,n.If)(c.greaterThan(0).and(P),()=>{let e=a.pdf.mul(I).toVar(),t=c.mul(F).toVar();(0,n.If)(a.lightType.equal((0,n.int)(1)),()=>{l.assign(Ut({pdf1:e,pdf2:t}))})});let u=a.emission.mul(o).mul(e).mul(s).mul(l).div((0,n.max)(a.pdf,1e-10));A.addAssign(u.mul(ie).div((0,n.max)(I,1e-10)))})})})}),(0,n.If)(se,()=>{(0,n.If)(o.greaterThan(0).and(P),()=>{let i=(0,n.max)((0,n.float)(0),(0,n.dot)(t,a)).toVar();(0,n.If)(i.greaterThan(0).and(Mr({direction:a,surfaceNormal:t})),()=>{(0,n.If)(m.greaterThan((0,n.int)(0)),()=>{let c=(0,n.bool)(!1).toVar(),l=(0,n.float)(0).toVar(),d=(0,n.int)(-1).toVar();(0,n.Loop)({start:(0,n.int)(0),end:m,type:`int`,condition:`<`},({i})=>{let o=Cr.wrap(kr(p,i));(0,n.If)(o.intensity.greaterThan(0),()=>{let s=Ur(o,e,t,r).toVar();(0,n.If)(s.greaterThanEqual(ne),()=>{(0,n.If)(Fr(o,j,a).toVar().greaterThan(0),()=>{(0,n.If)(s.greaterThan(l),()=>{l.assign(s),d.assign(i)}),c.assign((0,n.bool)(!0))})})})}),(0,n.If)(c.and(d.greaterThanEqual((0,n.int)(0))),()=>{let e=Cr.wrap(kr(p,d)),t=Fr(e,j,a).toVar();(0,n.If)(t.greaterThan(0),()=>{let r=Br(j,a,(0,n.min)(t.sub(.001),(0,n.float)(1e3)).toVar(),u,fn,y,b,x);(0,n.If)(r.greaterThan(0),()=>{let c=(0,n.max)((0,n.float)(0),(0,n.dot)(a,e.normal).negate()).toVar();(0,n.If)(c.greaterThan(0),()=>{let a=t.mul(t).toVar().div((0,n.max)(e.area.mul(c),Nt)).toVar();a.divAssign((0,n.max)((0,n.float)(te),1));let l=Ut({pdf1:o.mul(F).toVar(),pdf2:a.mul(I).toVar()}).toVar(),u=e.color.mul(e.intensity).toVar().mul(s).mul(i).mul(r).mul(l).div((0,n.max)(o,1e-10));A.addAssign(u.mul(ie).div((0,n.max)(F,1e-10)))})})})})})})})}),(0,n.If)(k,()=>{let e=(0,n.vec2)(N(u).toVar(),N(u).toVar()).toVar(),a=(0,n.vec3)(0).toVar(),o=vn(S,T,w,C,E,D,O,e,a).toVar(),s=o.xyz.toVar(),c=o.w.toVar();(0,n.If)(c.greaterThan(0),()=>{let e=(0,n.max)((0,n.float)(0),(0,n.dot)(t,s)).toVar();(0,n.If)(e.greaterThan(0).and(Mr({direction:s,surfaceNormal:t})),()=>{let o=Br(j,s,(0,n.float)(1e3),u,fn,y,b,x);(0,n.If)(o.greaterThan(0),()=>{let l=vr(i,s,t,r),u=Zr(i,s,t,r).toVar(),d=(0,n.select)(u.greaterThan(0),Wt({pdf1:c,pdf2:u}),(0,n.float)(1)).toVar(),f=a.mul(l).mul(e).mul(o).mul(d).div((0,n.max)(c,1e-10));A.addAssign(f)})})})})}),A}),$r=(0,n.Fn)(([e,t,r,i,a,o])=>{let s=(0,n.select)(o,i,(0,n.float)(1).div(i)).toVar(),c=e.add(t.mul(s)).toVar(),l=(0,n.dot)(c,c).toVar(),u=(0,n.select)(l.greaterThan(Nt),c.div((0,n.sqrt)(l)),r).toVar();(0,n.If)((0,n.dot)(u,r).lessThan(0),()=>{u.assign(u.negate())});let d=(0,n.abs)((0,n.dot)(e,u)).toVar(),f=(0,n.abs)((0,n.dot)(t,u)).toVar(),p=(0,n.abs)((0,n.dot)(r,u)).toVar(),m=Kn(p,a).toVar(),h=d.add(f.mul(s)).toVar(),g=h.mul(h).toVar(),_=f.mul(s).mul(s).div((0,n.max)(g,Nt)).toVar();return m.mul(p).mul(_)}),ei=(0,n.Fn)(([e,t,r,i])=>{let a=e.add(t).toVar(),o=(0,n.dot)(a,a).toVar();return $n((0,n.max)((0,n.dot)(r,(0,n.select)(o.greaterThan(Nt),a.div((0,n.sqrt)(o)),r).toVar()),0).toVar(),(0,n.max)((0,n.dot)(r,e),0).toVar(),i)}),ti=(0,n.Fn)(([e,t,r,i,a])=>{let o=e.specularImportance.toVar(),s=o.greaterThan(.001).toVar(),c=e.diffuseImportance.toVar(),l=c.greaterThan(.001).toVar(),u=e.transmissionImportance.toVar(),d=u.greaterThan(.001).toVar(),f=e.clearcoatImportance.toVar(),p=f.greaterThan(.001).toVar(),m=o.add(c).add(u).add(f).toVar();return(0,n.If)(m.lessThan(.001),()=>{o.assign(0),c.assign(1),u.assign(0),f.assign(0),m.assign(1),s.assign((0,n.bool)(!1)),l.assign((0,n.bool)(!0)),d.assign((0,n.bool)(!1)),p.assign((0,n.bool)(!1))}).Else(()=>{let e=(0,n.float)(1).div(m).toVar();o.mulAssign(e),c.mulAssign(e),u.mulAssign(e),f.mulAssign(e),m.assign(1)}),Ot({envWeight:(0,n.float)(0),specularWeight:o,diffuseWeight:c,transmissionWeight:u,clearcoatWeight:f,totalWeight:m,useEnv:(0,n.bool)(!1),useSpecular:s,useDiffuse:l,useTransmission:d,useClearcoat:p})}),ni=(0,n.Fn)(([e,t])=>{let r=(0,n.int)(2).toVar(),i=(0,n.float)(1).toVar(),a=(0,n.float)(0).toVar(),o=(0,n.bool)(!1).toVar();return(0,n.If)(e.useSpecular.and(o.not()),()=>{a.addAssign(e.specularWeight),(0,n.If)(t.lessThan(a),()=>{r.assign(1),i.assign(e.specularWeight),o.assign((0,n.bool)(!0))})}),(0,n.If)(e.useDiffuse.and(o.not()),()=>{a.addAssign(e.diffuseWeight),(0,n.If)(t.lessThan(a),()=>{r.assign(2),i.assign(e.diffuseWeight),o.assign((0,n.bool)(!0))})}),(0,n.If)(e.useTransmission.and(o.not()),()=>{a.addAssign(e.transmissionWeight),(0,n.If)(t.lessThan(a),()=>{r.assign(3),i.assign(e.transmissionWeight),o.assign((0,n.bool)(!0))})}),(0,n.If)(e.useClearcoat.and(o.not()),()=>{r.assign(4),i.assign(e.clearcoatWeight),o.assign((0,n.bool)(!0))}),(0,n.If)(o.not(),()=>{r.assign(2),i.assign((0,n.select)(e.useDiffuse,e.diffuseWeight,(0,n.float)(1)))}),(0,n.vec2)((0,n.float)(r),i)}),ri=(0,n.Fn)(([e])=>(0,n.max)(e,0).mul(jt)),ii=(0,n.Fn)(([e,t,r,i,a,o,s,c,l,u,d,f,p,m,h,g,_,v])=>{let y=(0,n.vec3)(0).toVar(),b=(0,n.vec3)(0).toVar(),x=(0,n.float)(0).toVar(),S=(0,n.float)(0).toVar(),C=(0,n.float)(0).toVar();return(0,n.If)(u.diffuseImportance.greaterThanEqual(0).and(u.specularImportance.greaterThanEqual(0)).and(u.transmissionImportance.greaterThanEqual(0)).and(u.clearcoatImportance.greaterThanEqual(0)).and(u.envmapImportance.greaterThanEqual(0)).toVar().not(),()=>{let e=(0,n.vec2)(N(l).toVar(),N(l).toVar()).toVar();y.assign(sr(t,e)),b.assign(r.color.xyz),x.assign(1),S.assign(1)}).Else(()=>{let s=Ot.wrap(ti(u,c,r,_,v).toVar()),d=N(l).toVar(),f=(0,n.vec2)(N(l).toVar(),N(l).toVar()).toVar(),p=ni(s,d).toVar(),m=(0,n.int)(p.x).toVar();p.y.toVar();let h=(0,n.vec3)(0).toVar(),g=(0,n.float)(0).toVar(),w=(0,n.vec3)(0).toVar();(0,n.If)(m.equal((0,n.int)(1)),()=>{h.assign(i),g.assign(a),w.assign(o)}).ElseIf(m.equal((0,n.int)(2)),()=>{h.assign(sr(t,f)),g.assign(ri((0,n.max)((0,n.dot)(t,h),0))),w.assign(vr(e,h,t,r))}).ElseIf(m.equal((0,n.int)(3)),()=>{let i=(0,n.dot)(e,t).greaterThan(0).toVar(),a=fr.wrap(hr(e,t,r.ior,r.roughness,i,r.dispersion,f,l).toVar());h.assign(a.direction),g.assign(a.pdf),w.assign(vr(e,h,t,r))}).Else(()=>{h.assign(i),g.assign(a),w.assign(o)});let T=(0,n.dot)(t,h).toVar(),E=(0,n.max)(T,0).toVar(),D=(0,n.abs)(T).toVar(),O=(0,n.float)(0).toVar();(0,n.If)(s.useSpecular,()=>{let i=$n((0,n.max)((0,n.dot)(t,(0,n.normalize)(e.add(h))),.001),(0,n.max)((0,n.dot)(t,e),.001),r.roughness);O.addAssign(s.specularWeight.mul(i))}),(0,n.If)(s.useDiffuse,()=>{let e=ri(E).toVar();O.addAssign(s.diffuseWeight.mul(e))}),(0,n.If)(s.useTransmission.and(r.transmission.greaterThan(0)),()=>{let i=(0,n.dot)(e,t).greaterThan(0).toVar(),a=$r(e,h,t,r.ior,r.roughness,i).toVar();O.addAssign(s.transmissionWeight.mul(a))}),(0,n.If)(s.useClearcoat.and(r.clearcoat.greaterThan(0)),()=>{let n=ei(e,h,t,r.clearcoatRoughness).toVar();O.addAssign(s.clearcoatWeight.mul(n))}),g.assign((0,n.max)(g,It)),O.assign((0,n.max)(O,It));let k=g.div(O).toVar(),A=(0,n.select)(m.equal((0,n.int)(3)),D,E),j=w.mul(A).mul(k).div(g).toVar();y.assign(h),b.assign(j),x.assign(k),S.assign(g),C.assign(O)}),Dr({direction:y,throughput:b,misWeight:x,pdf:S,combinedPdf:C})}),ai=y({position:`vec3`,normal:`vec3`,emission:`vec3`,direction:`vec3`,distance:`float`,pdf:`float`,area:`float`,cosThetaLight:`float`,valid:`bool`}),oi=y({contribution:`vec3`,hasEmissive:`bool`,emissionOnly:`vec3`,distance:`float`}),si=(0,n.Fn)(([e,t,r,i])=>{let a=(0,n.sqrt)(i.x),o=(0,n.float)(1).sub(a),s=i.y.mul(a),c=(0,n.float)(1).sub(o).sub(s);return e.mul(o).add(t.mul(s)).add(r.mul(c))}),ci=(0,n.Fn)(([e,t,r])=>(0,n.length)((0,n.cross)(t.sub(e),r.sub(e))).mul(.5)),li=(0,n.Fn)(([e,t,r,i])=>{let a=(0,n.normalize)(e.sub(i)),o=(0,n.normalize)(t.sub(i)),s=(0,n.normalize)(r.sub(i)),c=(0,n.abs)((0,n.dot)(a,(0,n.cross)(o,s))),l=(0,n.float)(1).add((0,n.dot)(o,s)).add((0,n.dot)(a,s)).add((0,n.dot)(a,o));return(0,n.max)((0,n.float)(2).mul((0,n.atan)(c,(0,n.max)(l,(0,n.float)(1e-10)))),(0,n.float)(0))}),ui=(0,n.Fn)(([e,t,r,i])=>{let a=t.sub(e),o=r.sub(e),s=r.sub(t),c=(0,n.max)((0,n.dot)(a,a),(0,n.max)((0,n.dot)(o,o),(0,n.dot)(s,s))),l=(0,n.cross)(a,o),u=(0,n.dot)(l,l),d=(0,n.bool)(!1).toVar();return(0,n.If)(u.greaterThan(1e-20),()=>{let t=(0,n.dot)(l,i.sub(e)),r=t.mul(t).div(u);d.assign(c.greaterThan(r))}),d}),di=y({direction:`vec3`,position:`vec3`,solidAngle:`float`,valid:`bool`}),fi=(0,n.Fn)(([e])=>{let t=(0,n.length)(e);return(0,n.select)(t.greaterThan(1e-10),e.div(t),(0,n.vec3)(0))}),pi=(0,n.Fn)(([e,t,r,i,a])=>{let o=di({direction:(0,n.vec3)(0),position:(0,n.vec3)(0),solidAngle:(0,n.float)(0),valid:!1}).toVar(),s=(0,n.normalize)(e.sub(i)),c=(0,n.normalize)(t.sub(i)),l=(0,n.normalize)(r.sub(i)),u=li(e,t,r,i);return o.solidAngle.assign(u),(0,n.If)(u.greaterThan(1e-7),()=>{let d=(0,n.clamp)((0,n.dot)(fi((0,n.cross)(s,c)),fi((0,n.cross)(s,l))),-1,1),f=(0,n.sqrt)((0,n.max)((0,n.float)(1).sub(d.mul(d)),0)),p=(0,n.acos)(d),m=a.x.mul(u).sub(p),h=(0,n.sin)(m),g=(0,n.cos)(m),_=(0,n.clamp)((0,n.dot)(s,c),-1,1),v=g.sub(d),y=h.add(f.mul(_)),b=y.mul(g).sub(v.mul(h)).mul(d).sub(y),x=y.mul(h).add(v.mul(g)).mul(f),S=(0,n.clamp)((0,n.select)((0,n.abs)(x).greaterThan(1e-10),b.div(x),(0,n.float)(1)),-1,1),C=(0,n.dot)(l,s),w=fi(l.sub(s.mul(C))),T=(0,n.sqrt)((0,n.max)((0,n.float)(1).sub(S.mul(S)),0)),E=(0,n.normalize)(s.mul(S).add(w.mul(T))),D=(0,n.dot)(E,c),O=(0,n.float)(1).sub(a.y.mul((0,n.float)(1).sub(D))),k=(0,n.sqrt)((0,n.max)((0,n.float)(1).sub(O.mul(O)),0)),A=fi(E.sub(c.mul(D))),j=(0,n.normalize)(c.mul(O).add(A.mul(k))),M=(0,n.normalize)((0,n.cross)(t.sub(e),r.sub(e))),N=(0,n.dot)(M,j);(0,n.If)((0,n.abs)(N).greaterThan(1e-10),()=>{let t=(0,n.dot)(M,e.sub(i)).div(N);(0,n.If)(t.greaterThan(0),()=>{o.direction.assign(j),o.position.assign(i.add(j.mul(t))),o.valid.assign(!0)})})}),o}),mi=(0,n.Fn)(([e,t,r,i])=>{let a=r.sub(t),o=i.sub(t),s=e.sub(t),c=(0,n.dot)(a,a),l=(0,n.dot)(a,o),u=(0,n.dot)(o,o),d=(0,n.dot)(s,a),f=(0,n.dot)(s,o),p=(0,n.float)(1).div((0,n.max)(c.mul(u).sub(l.mul(l)),(0,n.float)(1e-10))),m=u.mul(d).sub(l.mul(f)).mul(p),h=c.mul(f).sub(l.mul(d)).mul(p);return(0,n.vec3)((0,n.float)(1).sub(m).sub(h),m,h)}),hi=(0,n.Fn)(([e,t,r,i])=>{let a=(0,n.sqrt)(i.x),o=(0,n.float)(1).sub(a),s=i.y.mul(a),c=(0,n.float)(1).sub(o).sub(s);return(0,n.normalize)(e.mul(o).add(t.mul(s)).add(r.mul(c)))});(0,n.Fn)(([e])=>e.emissiveIntensity.greaterThan(0).and((0,n.length)(e.emissive).greaterThan(0)));var gi=8,_i=2,vi=y({v0:`vec3`,v1:`vec3`,v2:`vec3`,n0:`vec3`,n1:`vec3`,n2:`vec3`,materialIndex:`int`}),yi=(0,n.Fn)(([e,t])=>{let r=X(t,e,(0,n.int)(0),(0,n.int)(gi)),i=X(t,e,(0,n.int)(1),(0,n.int)(gi)),a=X(t,e,(0,n.int)(2),(0,n.int)(gi)),o=X(t,e,(0,n.int)(3),(0,n.int)(gi)),s=X(t,e,(0,n.int)(4),(0,n.int)(gi)),c=X(t,e,(0,n.int)(5),(0,n.int)(gi)),l=X(t,e,(0,n.int)(7),(0,n.int)(gi));return vi({v0:r.xyz,v1:i.xyz,v2:a.xyz,n0:o.xyz,n1:s.xyz,n2:c.xyz,materialIndex:(0,n.int)(l.z)})}),bi=(0,n.Fn)(([e,t,r,i,a,o,s])=>{let c=vi.wrap(yi(e,a)),l=ci(c.v0,c.v1,c.v2),u=X(o,c.materialIndex,(0,n.int)(Rt.EMISSIVE_ROUGHNESS),J),d=X(o,c.materialIndex,(0,n.int)(Rt.IOR_TRANSMISSION),J),f=(0,n.max)(u.x.add(u.y).add(u.z).div(3).mul(d.a).mul(l),(0,n.float)(1e-10)).div((0,n.max)(s,(0,n.float)(1e-10))),p=(0,n.float)(0).toVar();return(0,n.If)(ui(c.v0,c.v1,c.v2,i),()=>{let e=li(c.v0,c.v1,c.v2,i);p.assign(f.div((0,n.max)(e,(0,n.float)(1e-10))))}).Else(()=>{let e=(0,n.normalize)((0,n.cross)(c.v1.sub(c.v0),c.v2.sub(c.v0))),i=(0,n.max)((0,n.dot)(r.negate(),e),.001),a=t.mul(t),o=f.div(l);p.assign(o.mul(a).div(i))}),(0,n.max)(p,It)}),xi=(0,n.Fn)(([e,t,r,i])=>{let a=(0,n.int)(0).toVar(),o=r.sub(1).toVar();return(0,n.Loop)(a.lessThan(o),()=>{let r=a.add(o).div(2).toVar(),s=e.element(t.add(r.mul((0,n.int)(_i)))).b;(0,n.If)(s.lessThan(i),()=>{a.assign(r.add(1))}).Else(()=>{o.assign(r)})}),a}),Si=(0,n.Fn)(([e,t,r,i,a,o,s,c,l])=>{let u=ai({position:(0,n.vec3)(0),normal:(0,n.vec3)(0),emission:(0,n.vec3)(0),direction:(0,n.vec3)(0),distance:(0,n.float)(0),pdf:(0,n.float)(0),area:(0,n.float)(0),cosThetaLight:(0,n.float)(0),valid:!1}).toVar();return(0,n.If)(s.greaterThan((0,n.int)(0)),()=>{let r=xi(a,o,s,N(i)).toVar(),d=o.add(r.mul((0,n.int)(_i))),f=a.element(d),p=a.element(d.add(1)),m=(0,n.int)(f.r),h=(0,n.max)(f.g,(0,n.float)(1e-10)),g=p.xyz,_=p.w,v=vi.wrap(yi(m,l)),y=(0,n.vec2)(N(i).toVar(),N(i).toVar()),b=(0,n.normalize)((0,n.cross)(v.v1.sub(v.v0),v.v2.sub(v.v0)));(0,n.If)(ui(v.v0,v.v1,v.v2,e),()=>{let r=di.wrap(pi(v.v0,v.v1,v.v2,e,y));(0,n.If)(r.valid.and(r.solidAngle.greaterThan(1e-7)),()=>{let i=r.direction,a=r.position,o=(0,n.dot)(i,t),s=(0,n.dot)(i,b.negate());(0,n.If)(o.greaterThan(0).and(s.greaterThan(0)),()=>{let t=mi(a,v.v0,v.v1,v.v2),o=(0,n.normalize)(v.n0.mul(t.x).add(v.n1.mul(t.y)).add(v.n2.mul(t.z))),l=(0,n.length)(a.sub(e)),d=h.div((0,n.max)(c,(0,n.float)(1e-10))).div(r.solidAngle);u.position.assign(a),u.normal.assign(o),u.emission.assign(g),u.direction.assign(i),u.distance.assign(l),u.pdf.assign((0,n.max)(d,It)),u.area.assign(_),u.cosThetaLight.assign(s),u.valid.assign(!0)})})}).Else(()=>{let r=si(v.v0,v.v1,v.v2,y),i=hi(v.n0,v.n1,v.n2,y),a=r.sub(e),o=(0,n.dot)(a,a),s=(0,n.sqrt)(o),l=a.div(s),d=(0,n.dot)(l,t),f=(0,n.dot)(l,i.negate());(0,n.If)(d.greaterThan(0).and(f.greaterThan(0)),()=>{let e=h.div((0,n.max)(c,(0,n.float)(1e-10)).mul(_)).mul(o).div(f);u.position.assign(r),u.normal.assign(i),u.emission.assign(g),u.direction.assign(l),u.distance.assign(s),u.pdf.assign((0,n.max)(e,It)),u.area.assign(_),u.cosThetaLight.assign(f),u.valid.assign(!0)})})}),u}),Ci=(0,n.Fn)(([e,t,r,i,a,o,s,c,l,u,d,f,p,m,h,g])=>{let _=oi({contribution:(0,n.vec3)(0),hasEmissive:!1,emissionOnly:(0,n.vec3)(0),distance:(0,n.float)(0)}).toVar();return(0,n.If)(o.greaterThan((0,n.int)(1)).and(i.roughness.greaterThan(.9)).and(i.metalness.lessThan(.1)).not(),()=>{let o=ai.wrap(Si(e,t,a,s,l,u,d,f,p));(0,n.If)(o.valid.and(o.pdf.greaterThan(0)),()=>{_.hasEmissive.assign(!0),_.emissionOnly.assign(o.emission),_.distance.assign(o.distance);let a=(0,n.max)((0,n.float)(0),(0,n.dot)(t,o.direction));(0,n.If)(a.greaterThan(0),()=>{let l=g(e,t,i),u=e.add(l),d=o.distance.sub(.001),f=m(u,o.direction,d,s);(0,n.If)(f.greaterThan(0),()=>{let e=h(r,o.direction,t,i),s=Zr(r,o.direction,t,i),l=(0,n.select)(s.greaterThan(0),Ut({pdf1:o.pdf,pdf2:s}),(0,n.float)(1));_.contribution.assign(o.emission.mul(e).mul(a).div(o.pdf).mul(f).mul(c).mul(l))})})})}),_}),wi=(0,n.Fn)(([e,t,n,r,i,a,o,s,c,l,u,d,f,p,m,h])=>oi.wrap(Ci(e,t,n,r,i,a,o,s,c,l,u,d,f,p,m,h)).contribution),Ti=4,Ei=2,Di=32,Oi=(0,n.Fn)(([e,t,r,i,a,o,s])=>{let c=ai({position:(0,n.vec3)(0),normal:(0,n.vec3)(0),emission:(0,n.vec3)(0),direction:(0,n.vec3)(0),distance:(0,n.float)(0),pdf:(0,n.float)(0),area:(0,n.float)(0),cosThetaLight:(0,n.float)(0),valid:!1}).toVar(),l=(0,n.float)(1).toVar(),u=(0,n.int)(0).toVar(),d=(0,n.bool)(!1).toVar();return(0,n.Loop)(Di,()=>{let t=u.mul((0,n.int)(Ti)),a=i.element(t.add((0,n.int)(1))),o=i.element(t.add((0,n.int)(2)));(0,n.If)(a.w.greaterThan(.5),()=>{d.assign((0,n.bool)(!0)),(0,n.Break)()});let s=(0,n.int)(o.x),c=(0,n.int)(o.y),f=s.mul((0,n.int)(Ti)),p=i.element(f),m=i.element(f.add((0,n.int)(1))),h=c.mul((0,n.int)(Ti)),g=i.element(h),_=i.element(h.add((0,n.int)(1))),v=(0,n.vec3)(p.x.add(m.x).mul(.5),p.y.add(m.y).mul(.5),p.z.add(m.z).mul(.5)),y=(0,n.vec3)(g.x.add(_.x).mul(.5),g.y.add(_.y).mul(.5),g.z.add(_.z).mul(.5)),b=v.sub(e),x=y.sub(e),S=(0,n.max)((0,n.dot)(b,b),(0,n.float)(.01)),C=(0,n.max)((0,n.dot)(x,x),(0,n.float)(.01)),w=(0,n.max)(p.w,(0,n.float)(0)),T=(0,n.max)(g.w,(0,n.float)(0)),E=w.div(S),D=T.div(C),O=E.add(D);(0,n.If)(O.lessThanEqual((0,n.float)(0)),()=>{u.assign(s)}).Else(()=>{let e=E.div(O);(0,n.If)(N(r).lessThan(e),()=>{l.mulAssign(e),u.assign(s)}).Else(()=>{l.mulAssign((0,n.float)(1).sub(e)),u.assign(c)})})}),(0,n.If)(d,()=>{let d=u.mul((0,n.int)(Ti)),f=i.element(d),p=i.element(d.add((0,n.int)(2))),m=(0,n.int)(p.x),h=(0,n.int)(p.y),g=(0,n.max)(f.w,(0,n.float)(1e-10)),_=N(r).mul(g),v=(0,n.float)(0).toVar(),y=m.add(h.sub((0,n.int)(1))).toVar(),b=(0,n.float)(1e-10).toVar();(0,n.Loop)({start:(0,n.int)(0),end:h},({i:e})=>{let t=m.add(e),r=o.add(t.mul((0,n.int)(Ei))),i=(0,n.max)(a.element(r).g,(0,n.float)(0));v.addAssign(i),(0,n.If)(v.greaterThanEqual(_).and(i.greaterThan((0,n.float)(0))),()=>{y.assign(t),b.assign(i),(0,n.Break)()})}),l.mulAssign(b.div(g));let x=o.add(y.mul((0,n.int)(Ei))),S=a.element(x),C=a.element(x.add((0,n.int)(1))),w=(0,n.int)(S.r),T=C.xyz,E=C.w,D=vi.wrap(yi(w,s)),O=(0,n.vec2)(N(r).toVar(),N(r).toVar()),k=(0,n.normalize)((0,n.cross)(D.v1.sub(D.v0),D.v2.sub(D.v0)));(0,n.If)(ui(D.v0,D.v1,D.v2,e),()=>{let r=di.wrap(pi(D.v0,D.v1,D.v2,e,O));(0,n.If)(r.valid.and(r.solidAngle.greaterThan((0,n.float)(1e-7))),()=>{let i=r.direction,a=r.position,o=(0,n.dot)(i,t),s=(0,n.dot)(i,k.negate());(0,n.If)(o.greaterThan((0,n.float)(0)).and(s.greaterThan((0,n.float)(0))),()=>{let t=mi(a,D.v0,D.v1,D.v2),o=(0,n.normalize)(D.n0.mul(t.x).add(D.n1.mul(t.y)).add(D.n2.mul(t.z))),u=(0,n.length)(a.sub(e)),d=l.div((0,n.max)(r.solidAngle,(0,n.float)(1e-10)));c.position.assign(a),c.normal.assign(o),c.emission.assign(T),c.direction.assign(i),c.distance.assign(u),c.pdf.assign((0,n.max)(d,It)),c.area.assign(E),c.cosThetaLight.assign(s),c.valid.assign(!0)})})}).Else(()=>{let r=si(D.v0,D.v1,D.v2,O),i=hi(D.n0,D.n1,D.n2,O),a=r.sub(e),o=(0,n.dot)(a,a),s=(0,n.sqrt)(o),u=a.div(s),d=(0,n.dot)(u,t),f=(0,n.dot)(u,i.negate());(0,n.If)(d.greaterThan((0,n.float)(0)).and(f.greaterThan((0,n.float)(0))),()=>{let e=l.div((0,n.max)(E,(0,n.float)(1e-10))).mul(o).div(f);c.position.assign(r),c.normal.assign(i),c.emission.assign(T),c.direction.assign(u),c.distance.assign(s),c.pdf.assign((0,n.max)(e,It)),c.area.assign(E),c.cosThetaLight.assign(f),c.valid.assign(!0)})})}),c}),ki=0,Ai=1,ji=2,Mi=3,Ni=y({radiance:`vec4`,objectNormal:`vec3`,objectColor:`vec3`,objectID:`float`,firstHitPoint:`vec3`,firstHitDistance:`float`}),Pi=(0,n.Fn)(([e,t,r,i,a])=>{let o=a.toVar();return(0,n.If)(r.not().or(i.notEqual(t)),()=>{o.assign(Xt(e.metalness,e.roughness,e.transmission,e.clearcoat,e.emissive))}),o}),Fi=(0,n.Fn)(([e,t,r,i,a,o,s,c,l,u,d,f,p])=>{let m=(0,n.vec3)(0).toVar(),h=(0,n.vec3)(0).toVar(),g=(0,n.float)(0).toVar(),_=Tt.wrap(Pi(r,i,s,c,l)).toVar(),v=d.toVar();(0,n.If)(u.not(),()=>{(0,n.If)(f,()=>{v.assign(nr(r,_,p))}).Else(()=>{let e=Dt({F0:Gn(r.ior),NoV:(0,n.float)(1),diffuseColor:(0,n.vec3)(0),isPurelyDiffuse:!1,alpha:(0,n.float)(0),k:(0,n.float)(0),alpha2:(0,n.float)(0),invRoughness:(0,n.float)(1).sub(r.roughness),metalFactor:(0,n.float)(.5).add((0,n.float)(.5).mul(r.metalness)),iorFactor:(0,n.min)((0,n.float)(2).div(r.ior),1),maxSheenColor:(0,n.max)(r.sheenColor.x,(0,n.max)(r.sheenColor.y,r.sheenColor.z))}).toVar();v.assign(nr(r,_,e))})});let y=a.x.toVar(),b=(0,n.vec2)(a.y,N(o)).toVar(),x=(0,n.vec3)(0).toVar(),S=v.diffuse.toVar(),C=S.add(v.specular).toVar(),w=C.add(v.sheen).toVar(),T=w.add(v.clearcoat).toVar(),E=(0,n.bool)(!1).toVar();(0,n.If)(y.lessThan(S).and(E.not()),()=>{m.assign(or({N:t,xi:b}));let i=(0,n.clamp)((0,n.dot)(t,m),0,1);g.assign(i.mul(jt)),h.assign(vr(e,m,t,r)),E.assign((0,n.bool)(!0))});let D=(0,n.clamp)((0,n.dot)(t,e),.001,1).toVar();return(0,n.If)(y.lessThan(C).and(E.not()),()=>{let i=Gt({N:t}),o=cr({V:i.transpose().mul(e).toVar(),roughness:r.roughness,Xi:a});x.assign(i.mul(o));let s=(0,n.clamp)((0,n.dot)(t,x),.001,1);m.assign((0,n.reflect)(e.negate(),x)),g.assign($n(s,D,r.roughness)),h.assign(vr(e,m,t,r)),E.assign((0,n.bool)(!0))}),(0,n.If)(y.lessThan(w).and(E.not()),()=>{x.assign(ar({N:t,roughness:r.sheenRoughness,Xi:a}));let i=(0,n.clamp)((0,n.dot)(t,x),.001,1),o=(0,n.clamp)((0,n.dot)(e,x),.001,1);m.assign((0,n.reflect)(e.negate(),x));let s=(0,n.dot)(t,m).toVar();(0,n.If)(s.lessThanEqual(0),()=>{m.assign(or({N:t,xi:a})),s.assign((0,n.clamp)((0,n.dot)(t,m),0,1)),g.assign(s.mul(jt)),h.assign(vr(e,m,t,r))}).Else(()=>{g.assign(qn(i,r.sheenRoughness).mul(i).div((0,n.float)(4).mul(o))),g.assign((0,n.max)(g,It)),h.assign(vr(e,m,t,r))}),E.assign((0,n.bool)(!0))}),(0,n.If)(y.lessThan(T).and(E.not()),()=>{let i=(0,n.clamp)(r.clearcoatRoughness,Ft,1);x.assign(ar({N:t,roughness:i,Xi:a}));let o=(0,n.clamp)((0,n.dot)(t,x),0,1);m.assign((0,n.reflect)(e.negate(),x)),g.assign($n(o,D,i)),g.assign((0,n.max)(g,It)),h.assign(vr(e,m,t,r)),E.assign((0,n.bool)(!0))}),(0,n.If)(E.not(),()=>{let i=(0,n.dot)(e,t).greaterThan(0).toVar(),s=fr.wrap(hr(e,t,r.ior,r.roughness,i,r.dispersion,a,o));m.assign(s.direction),g.assign((0,n.max)(s.pdf,It)),h.assign(vr(e,m,t,r))}),g.assign((0,n.max)(g,It)),bt({direction:m,value:h,pdf:g})}),Ii=(0,n.Fn)(([e,t,r,i,a,o,s,c,l])=>{let u=(0,n.max)(Vt({v:e}),0).toVar(),d=Tt.wrap(Pi(r,i,a,o,s)).toVar(),f=d.complexityScore.toVar();(0,n.If)(d.isMetallic.and(d.isSmooth),()=>{f.addAssign(.15)}),(0,n.If)(d.isTransmissive.and(d.hasClearcoat),()=>{f.addAssign(.12)}),(0,n.If)(d.isEmissive,()=>{f.addAssign(.1)}),f.assign((0,n.clamp)(f,0,1));let p=(0,n.float)(.5).toVar();(0,n.If)(c.and(l).and(u.greaterThan(.01)),()=>{let e=(0,n.clamp)(t.y,0,1);p.assign((0,n.mix)((0,n.float)(.3),(0,n.float)(.8),e.mul(e)))});let m=(0,n.smoothstep)((0,n.float)(.001),(0,n.float)(.1),u);return u.mul((0,n.mix)(f.mul(.7),p,.3)).mul(m)}),Li=(0,n.Fn)(([e,t,r,i,a,o,s,c,l,u,d,f,p])=>{let m=(0,n.float)(1).toVar();return(0,n.If)(e.greaterThanEqual((0,n.int)(3)),()=>{let h=(0,n.max)(Vt({v:t}),0).toVar();(0,n.If)(h.lessThan(8e-4).and(e.greaterThan((0,n.int)(4))),()=>{let e=(0,n.max)(h.mul(125),.01),t=N(o);m.assign((0,n.select)(t.lessThan(e),e,(0,n.float)(0)))}).Else(()=>{let g=Tt.wrap(Pi(r,i,s,c,l)).toVar(),_=g.complexityScore.toVar();(0,n.If)(g.isMetallic.and(g.isSmooth).and(e.lessThan((0,n.int)(7))),()=>{_.addAssign(.3)}),(0,n.If)(g.isTransmissive.and(e.lessThan((0,n.int)(6))),()=>{_.addAssign(.25)}),(0,n.If)(g.isEmissive.and(e.lessThan((0,n.int)(4))),()=>{_.addAssign(.15)}),_.assign((0,n.clamp)(_,0,1));let v=(0,n.int)(3).toVar();(0,n.If)(_.greaterThan(.6),()=>{v.assign(5)}).ElseIf(_.greaterThan(.4),()=>{v.assign(4)}),(0,n.If)(e.lessThan(v),()=>{m.assign(1)}).Else(()=>{let y=(0,n.float)(0).toVar();(0,n.If)(s.and(u),()=>{y.assign(d)}).Else(()=>{y.assign(Ii(t,a,r,i,s,c,l,f,p))});let b=(0,n.mix)((0,n.clamp)(_.mul(.4).add(h.mul(.6)).mul(1.2),.15,.95),(0,n.clamp)(h.mul(.4).add(_.mul(.1)),.03,.6),(0,n.clamp)((0,n.float)(e.sub(v)).div(10),0,1)).toVar();b.assign((0,n.mix)(b,(0,n.max)(b,y),.4)),(0,n.If)(_.greaterThan(.5),()=>{let e=_.sub(.5).mul(.6);b.assign((0,n.mix)(b,(0,n.float)(1),e))});let x=(0,n.float)(.12).add(_.mul(.08)),S=(0,n.exp)((0,n.float)(e.sub(v)).negate().mul(x));b.mulAssign(S);let C=(0,n.select)(g.isEmissive,(0,n.float)(.04),(0,n.float)(.02));b.assign((0,n.max)(b,C));let w=N(o);m.assign((0,n.select)(w.lessThan(b),b,(0,n.float)(0)))})})}),m}),Ri=(0,n.Fn)(([e,t,r,i,a,o,s,c])=>{let l=(0,n.vec4)(0).toVar();return(0,n.If)(e.and(s.not()),()=>{l.assign((0,n.vec4)(0))}).Else(()=>{let s=yn({tex:r,samp:(0,n.sampler)(r),direction:t,environmentMatrix:i,environmentIntensity:a,enableEnvironmentLight:o});(0,n.If)(e,()=>{l.assign(s.mul(c))}).Else(()=>{l.assign(s)})}),l}),zi=(0,n.wgslFn)(`
507
483
  fn regularizePathContribution( contribution: vec3f, pathLength: f32, fireflyThreshold: f32, frame: i32 ) -> vec3f {
508
484
  let threshold = calculateFireflyThreshold( fireflyThreshold, i32( pathLength ), frame );
509
485
  return applySoftSuppressionRGB( contribution, threshold, 0.5f );
510
486
  }
511
- `,[rn,on]),na=(0,n.Fn)(([e,t,r,i,a,o,s,c,l,u,d,f,p,m,h,g,_,v,y,b,x,S,C,w,T,E,D,O,k,A,j,M,N,ee,te,ne,re,ie,ae,oe,se,P,ce,le,ue,de,fe,pe,me,ge])=>{let _e=(0,n.vec3)(0).toVar(),F=(0,n.vec3)(1).toVar(),I=(0,n.float)(1).toVar(),ve=(0,n.bool)(!1).toVar(),ye=(0,n.float)(0).toVar(),L=(0,n.vec3)(0).toVar(),be=(0,n.vec3)(0).toVar(),xe=(0,n.float)(-1e3).toVar(),Se=e.origin.toVar(),R=(0,n.float)(1e10).toVar(),Ce=(0,n.bool)(!1).toVar(),we=(0,n.int)(0).toVar(),Te=(0,n.float)(1).toVar(),Ee=(0,n.float)(1).toVar(),De=(0,n.float)(1).toVar(),Oe=M.toVar(),ke=N.toVar(),Ae=(0,n.int)(Gi).toVar(),je=(0,n.bool)(!0).toVar(),Me=(0,n.bool)(!1).toVar(),Ne=(0,n.bool)(!1).toVar(),z=(0,n.bool)(!1).toVar();(0,n.bool)(!1).toVar();let Pe=(0,n.float)(0).toVar(),Fe=(0,n.int)(-1).toVar(),Ie=Lt({isMetallic:!1,isRough:!1,isSmooth:!1,isTransmissive:!1,hasClearcoat:!1,isEmissive:!1,complexityScore:(0,n.float)(0)}).toVar(),Le=Nt({specular:(0,n.float)(.5),diffuse:(0,n.float)(.5),sheen:(0,n.float)(0),clearcoat:(0,n.float)(0),transmission:(0,n.float)(0),iridescence:(0,n.float)(0)}).toVar(),Re=zt({F0:(0,n.vec3)(.04),NoV:(0,n.float)(1),diffuseColor:(0,n.vec3)(0),isPurelyDiffuse:!1,alpha:(0,n.float)(0),k:(0,n.float)(0),alpha2:(0,n.float)(0),invRoughness:(0,n.float)(1),metalFactor:(0,n.float)(.5),iorFactor:(0,n.float)(1),maxSheenColor:(0,n.float)(0)}).toVar(),ze=(0,n.int)(0).toVar(),B=e.origin.toVar(),V=e.direction.toVar();return(0,n.Loop)({start:(0,n.int)(0),end:M.add(N).add(1),type:`int`,condition:`<`},({i:e})=>{Oe.assign(M.sub(ze)),je.assign(e.equal((0,n.int)(0))),(0,n.If)(ze.greaterThan(M),()=>{(0,n.Break)()});let i=(0,n.select)(e.greaterThan((0,n.int)(0)),ie,(0,n.float)(1)),N=Ot({origin:B,direction:V}),H=jt.wrap(xn(N,a,o,s)).toVar();(0,n.If)(H.didHit.not(),()=>{let t=ea(je,V,C,T,w,A,te,ee),r=(0,n.float)(1).toVar();(0,n.If)(ye.greaterThan(0).and(A).and(j),()=>{let e=Dn(C,V,T,D,O,k).w.toVar();(0,n.If)(e.greaterThan(0),()=>{r.assign(en({pdf1:ye,pdf2:e}))})}),_e.addAssign(ta({contribution:t.xyz.mul(F).mul(i).mul(r),pathLength:(0,n.float)(e),fireflyThreshold:re,frame:(0,n.int)(ge)})),(0,n.If)(ne.and(ve.not()),()=>{I.assign(0)}).ElseIf(ne.not(),()=>{I.mulAssign(t.a)}),(0,n.Break)()});let U=kt.wrap(un(H.materialIndex,s)).toVar(),Be=H.uv.toVar(),Ve=H.normal.toVar();(0,n.If)(U.displacementMapIndex.greaterThanEqual((0,n.int)(0)).and(U.displacementScale.greaterThan(0)),()=>{let t=qn.wrap(Jn(N,H,o,m,U,e)).toVar();Be.assign(t.uv),Ve.assign(t.normal),H.hitPoint.assign(t.hitPoint)});let He=It.wrap(Bn(c,l,u,d,f,p,U,Be,H.normal)).toVar();U.color.assign(He.albedo),U.metalness.assign((0,n.clamp)(He.metalness,0,1)),U.roughness.assign((0,n.clamp)(He.roughness,Gt,1));let W=He.normal.toVar();(0,n.If)(U.displacementMapIndex.greaterThanEqual((0,n.int)(0)).and(U.displacementScale.greaterThan(0)),()=>{W.assign((0,n.normalize)(Ve.add(He.normal.sub(H.normal))))});let Ue=(0,n.float)(1).toVar(),We=(0,n.float)(1).toVar();(0,n.If)(we.equal((0,n.int)(1)),()=>{Ue.assign(Te)}).ElseIf(we.equal((0,n.int)(2)),()=>{Ue.assign(Ee),We.assign(Te)}).ElseIf(we.equal((0,n.int)(3)),()=>{Ue.assign(De),We.assign(Ee)});let Ge=Sr.wrap(Ar(N,H.hitPoint,W,U,t,ke,Ue,We)).toVar();(0,n.If)(Ge.continueRay,()=>{let e=(0,n.bool)(!1).toVar();(0,n.If)(Ge.isTransmissive.and(ke.greaterThan((0,n.int)(0))),()=>{ke.subAssign(1),Ae.assign((0,n.int)(qi)),e.assign((0,n.bool)(!0)),(0,n.If)(Ge.didReflect.not(),()=>{(0,n.If)(Ge.entering,()=>{(0,n.If)(we.lessThan((0,n.int)(3)),()=>{we.addAssign(1),(0,n.If)(we.equal((0,n.int)(1)),()=>{Te.assign(U.ior)}).ElseIf(we.equal((0,n.int)(2)),()=>{Ee.assign(U.ior)}).ElseIf(we.equal((0,n.int)(3)),()=>{De.assign(U.ior)})})}).Else(()=>{(0,n.If)(we.greaterThan((0,n.int)(0)),()=>{we.subAssign(1)})})})}).ElseIf(Ge.isAlphaSkip,()=>{e.assign((0,n.bool)(!0))}),F.mulAssign(Ge.throughput),(0,n.If)(ne.not(),()=>{I.mulAssign(Ge.alpha)});let t=(0,n.select)(Ge.entering,W,W.negate()),r=(0,n.select)(Ge.didReflect,t,V);B.assign(H.hitPoint.add(r.mul(.001))),V.assign(Ge.direction),je.assign((0,n.bool)(!1)),Me.assign((0,n.bool)(!1)),z.assign((0,n.bool)(!1)),(0,n.If)(e.not(),()=>{ze.addAssign(1)}),(0,n.Continue)()}),(0,n.If)(ne.not(),()=>{I.mulAssign(Ge.alpha)}),ve.assign((0,n.bool)(!0));let Ke=he(pe,r,e,t,(0,n.int)(-1),me,ge).toVar(),qe=V.negate().toVar();U.sheenRoughness.assign((0,n.clamp)(U.sheenRoughness,Gt,1)),(0,n.If)(z.not(),()=>{Re.assign(mr(W,qe,U,He,Ie)),z.assign((0,n.bool)(!0))});let Je=(0,n.vec3)(0).toVar(),Ye=(0,n.vec3)(0).toVar(),Xe=(0,n.float)(0).toVar();(0,n.If)(U.clearcoat.greaterThan(0),()=>{let e=Nr.wrap(Pr(N,H,U,Ke,t));Je.assign(e.L),Ye.assign(e.brdf),Xe.assign(e.pdf)}).Else(()=>{let e=Mt.wrap(Zi(qe,W,U,H.materialIndex,Ke,t,Ne,Fe,Ie,Me,Le,z,Re));Je.assign(e.direction),Ye.assign(e.value),Xe.assign(e.pdf),(0,n.If)(Fe.notEqual(H.materialIndex).or(Ne.not()),()=>{Ie.assign(sn(U.metalness,U.roughness,U.transmission,U.clearcoat,U.emissive))}),Ne.assign((0,n.bool)(!0)),Fe.assign(H.materialIndex),Me.assign((0,n.bool)(!0))}),(0,n.If)((0,n.length)(He.emissive).greaterThan(0),()=>{let t=(0,n.float)(1).toVar();(0,n.If)(oe.equal((0,n.int)(1)).and(ce.greaterThan((0,n.int)(0))).and(ye.greaterThan(0)),()=>{let e=Ii(H.triangleIndex,H.dst,V,B,o,s,le);t.assign($t({pdf1:ye,pdf2:e}))}),_e.addAssign(ta({contribution:He.emissive.mul(F).mul(i).mul(t),pathLength:(0,n.float)(e),fireflyThreshold:re,frame:(0,n.int)(ge)}))});let Ze=pi(H.hitPoint,W,U,qe,Je,Xe,Ye,r,e,t,h,g,_,v,y,b,x,S,a,o,s,C,w,T,E,D,O,k,A);_e.addAssign(ta({contribution:Ze.mul(F).mul(i),pathLength:(0,n.float)(e),fireflyThreshold:re,frame:(0,n.int)(ge)})),(0,n.If)(oe.equal((0,n.int)(1)).and(ce.greaterThan((0,n.int)(0))),()=>{let r=(0,n.Fn)(([e,t,n,r])=>ei(e,t,n,r,Sn,a,o,s));(0,n.If)(fe.greaterThan((0,n.int)(0)),()=>{let a=bi.wrap(Wi(H.hitPoint,W,t,de,se,P,o));(0,n.If)(e.greaterThan((0,n.int)(1)).and(U.roughness.greaterThan(.9)).and(U.metalness.lessThan(.1)).not().and(a.valid).and(a.pdf.greaterThan(0)),()=>{let o=(0,n.max)((0,n.float)(0),(0,n.dot)(W,a.direction));(0,n.If)(o.greaterThan(0),()=>{let s=ti(H.hitPoint,W,U),c=H.hitPoint.add(s),l=a.distance.sub(.001),u=r(c,a.direction,l,t);(0,n.If)(u.greaterThan(0),()=>{let t=jr(qe,a.direction,W,U),r=fi(qe,a.direction,W,U),s=(0,n.select)(r.greaterThan(0),$t({pdf1:a.pdf,pdf2:r}),(0,n.float)(1)),c=a.emission.mul(t).mul(o).div(a.pdf).mul(u).mul(ue).mul(s);_e.addAssign(ta({contribution:c.mul(F).mul(i),pathLength:(0,n.float)(e),fireflyThreshold:re,frame:(0,n.int)(ge)}))})})})}).Else(()=>{let a=Bi(H.hitPoint,W,qe,U,ae,e,t,ue,se,P,ce,le,o,r,jr,ti);_e.addAssign(ta({contribution:a.mul(F).mul(i),pathLength:(0,n.float)(e),fireflyThreshold:re,frame:(0,n.int)(ge)}))})}),(0,n.If)(Me.not().or(e.equal((0,n.int)(0))),()=>{Ie.assign(Lt.wrap(Xi(U,H.materialIndex,Ne,Fe,Ie))),Ne.assign((0,n.bool)(!0)),Fe.assign(H.materialIndex)});let Qe=Pt.wrap(pr(U,e,Ie,w,j,A)),$e=Br.wrap(yi(qe,W,U,Je,Xe,Ye,r,e,t,Qe,C,w,T,D,O,k,A,j));F.mulAssign($e.throughput),B.assign(H.hitPoint.add(W.mul(.001))),V.assign($e.direction),ye.assign($e.combinedPdf),je.assign((0,n.bool)(!1)),(0,n.If)(U.metalness.greaterThan(.7).and(U.roughness.lessThan(.3)),()=>{Ae.assign((0,n.int)(Ki))}).ElseIf(U.transmission.greaterThan(.5),()=>{Ae.assign((0,n.int)(qi))}).Else(()=>{Ae.assign((0,n.int)(Ji))}),(0,n.If)(e.equal((0,n.int)(0)).and(H.didHit),()=>{Se.assign(H.hitPoint),R.assign(H.dst)}),(0,n.If)(Ce.not().and(H.didHit),()=>{L.assign(W),be.assign(U.color.xyz),xe.assign((0,n.float)(H.materialIndex));let e=U.metalness.greaterThan(.7).and(U.roughness.lessThan(.3)),t=U.transmission.greaterThan(.5);(0,n.If)(e.or(t).not(),()=>{Ce.assign((0,n.bool)(!0))})});let et=$i(e,F,U,H.materialIndex,V,t,Ne,Fe,Ie,Me,Pe,A,j);(0,n.If)(et.lessThanEqual(0),()=>{(0,n.Break)()}),F.divAssign(et),ze.addAssign(1),Me.assign((0,n.bool)(!1)),z.assign((0,n.bool)(!1))}),Yi({radiance:(0,n.vec4)(_e,I),objectNormal:L,objectColor:be,objectID:xe,firstHitPoint:Se,firstHitDistance:R})}),ra=(0,n.wgslFn)(`
487
+ `,[qt,Yt]),Bi=(0,n.Fn)(([e,t,r,i,a,o,s,c,l,u,d,f,p,m,h,g,_,v,y,b,x,S,C,w,T,E,D,O,k,A,j,M,N,P,ee,F,I,te,ne,re,ae,oe,L,R,se,ce,z,le,ue,de])=>{let B=(0,n.vec3)(0).toVar(),fe=(0,n.vec3)(1).toVar(),pe=(0,n.float)(1).toVar(),me=(0,n.bool)(!1).toVar(),he=(0,n.float)(0).toVar(),ge=(0,n.vec3)(0).toVar(),_e=(0,n.vec3)(0).toVar(),ve=(0,n.float)(-1e3).toVar(),ye=e.origin.toVar(),be=(0,n.float)(1e10).toVar(),xe=(0,n.bool)(!1).toVar(),Se=(0,n.int)(0).toVar(),V=(0,n.float)(1).toVar(),Ce=(0,n.float)(1).toVar(),we=(0,n.float)(1).toVar(),Te=M.toVar(),Ee=N.toVar(),De=(0,n.int)(ki).toVar(),Oe=(0,n.bool)(!0).toVar(),H=(0,n.bool)(!1).toVar(),U=(0,n.bool)(!1).toVar(),ke=(0,n.bool)(!1).toVar();(0,n.bool)(!1).toVar();let Ae=(0,n.float)(0).toVar(),W=(0,n.int)(-1).toVar(),je=Tt({isMetallic:!1,isRough:!1,isSmooth:!1,isTransmissive:!1,hasClearcoat:!1,isEmissive:!1,complexityScore:(0,n.float)(0)}).toVar(),Me=xt({specular:(0,n.float)(.5),diffuse:(0,n.float)(.5),sheen:(0,n.float)(0),clearcoat:(0,n.float)(0),transmission:(0,n.float)(0),iridescence:(0,n.float)(0)}).toVar(),Ne=Dt({F0:(0,n.vec3)(.04),NoV:(0,n.float)(1),diffuseColor:(0,n.vec3)(0),isPurelyDiffuse:!1,alpha:(0,n.float)(0),k:(0,n.float)(0),alpha2:(0,n.float)(0),invRoughness:(0,n.float)(1),metalFactor:(0,n.float)(.5),iorFactor:(0,n.float)(1),maxSheenColor:(0,n.float)(0)}).toVar(),Pe=(0,n.int)(0).toVar(),Fe=e.origin.toVar(),Ie=e.direction.toVar();return(0,n.Loop)({start:(0,n.int)(0),end:M.add(N).add(1),type:`int`,condition:`<`},({i:e})=>{Te.assign(M.sub(Pe)),Oe.assign(e.equal((0,n.int)(0))),(0,n.If)(Pe.greaterThan(M),()=>{(0,n.Break)()});let i=(0,n.select)(e.greaterThan((0,n.int)(0)),te,(0,n.float)(1)),N=gt({origin:Fe,direction:Ie}),G=yt.wrap(dn(N,a,o,s)).toVar();(0,n.If)(G.didHit.not(),()=>{let t=Ri(Oe,Ie,C,T,w,A,ee,P),r=(0,n.float)(1).toVar();(0,n.If)(he.greaterThan(0).and(A).and(j),()=>{let e=_n(C,Ie,T,D,O,k).w.toVar();(0,n.If)(e.greaterThan(0),()=>{r.assign(Wt({pdf1:he,pdf2:e}))})}),B.addAssign(zi({contribution:t.xyz.mul(fe).mul(i).mul(r),pathLength:(0,n.float)(e),fireflyThreshold:I,frame:(0,n.int)(de)})),(0,n.If)(F.and(me.not()),()=>{pe.assign(0)}).ElseIf(F.not(),()=>{pe.mulAssign(t.a)}),(0,n.Break)()});let K=_t.wrap($t(G.materialIndex,s)).toVar(),Le=G.uv.toVar(),Re=G.normal.toVar();(0,n.If)(K.displacementMapIndex.greaterThanEqual((0,n.int)(0)).and(K.displacementScale.greaterThan(0)),()=>{let t=Ln.wrap(Rn(N,G,o,m,K,e)).toVar();Le.assign(t.uv),Re.assign(t.normal),G.hitPoint.assign(t.hitPoint)});let ze=wt.wrap(An(c,l,u,d,f,p,K,Le,G.normal)).toVar();K.color.assign(ze.albedo),K.metalness.assign((0,n.clamp)(ze.metalness,0,1)),K.roughness.assign((0,n.clamp)(ze.roughness,Pt,1));let q=ze.normal.toVar();(0,n.If)(K.displacementMapIndex.greaterThanEqual((0,n.int)(0)).and(K.displacementScale.greaterThan(0)),()=>{q.assign((0,n.normalize)(Re.add(ze.normal.sub(G.normal))))});let Be=(0,n.float)(1).toVar(),Ve=(0,n.float)(1).toVar();(0,n.If)(Se.equal((0,n.int)(1)),()=>{Be.assign(V)}).ElseIf(Se.equal((0,n.int)(2)),()=>{Be.assign(Ce),Ve.assign(V)}).ElseIf(Se.equal((0,n.int)(3)),()=>{Be.assign(we),Ve.assign(Ce)});let He=ur.wrap(_r(N,G.hitPoint,q,K,t,Ee,Be,Ve)).toVar();(0,n.If)(He.continueRay,()=>{let e=(0,n.bool)(!1).toVar();(0,n.If)(He.isTransmissive.and(Ee.greaterThan((0,n.int)(0))),()=>{Ee.subAssign(1),De.assign((0,n.int)(ji)),e.assign((0,n.bool)(!0)),(0,n.If)(He.didReflect.not(),()=>{(0,n.If)(He.entering,()=>{(0,n.If)(Se.lessThan((0,n.int)(3)),()=>{Se.addAssign(1),(0,n.If)(Se.equal((0,n.int)(1)),()=>{V.assign(K.ior)}).ElseIf(Se.equal((0,n.int)(2)),()=>{Ce.assign(K.ior)}).ElseIf(Se.equal((0,n.int)(3)),()=>{we.assign(K.ior)})})}).Else(()=>{(0,n.If)(Se.greaterThan((0,n.int)(0)),()=>{Se.subAssign(1)})})})}).ElseIf(He.isAlphaSkip,()=>{e.assign((0,n.bool)(!0))}),fe.mulAssign(He.throughput),(0,n.If)(F.not(),()=>{pe.mulAssign(He.alpha)});let t=(0,n.select)(He.entering,q,q.negate()),r=(0,n.select)(He.didReflect,t,Ie);Fe.assign(G.hitPoint.add(r.mul(.001))),Ie.assign(He.direction),Oe.assign((0,n.bool)(!1)),H.assign((0,n.bool)(!1)),ke.assign((0,n.bool)(!1)),(0,n.If)(e.not(),()=>{Pe.addAssign(1)}),(0,n.Continue)()}),(0,n.If)(F.not(),()=>{pe.mulAssign(He.alpha)}),me.assign((0,n.bool)(!0));let Ue=ie(le,r,e,t,(0,n.int)(-1),ue,de).toVar(),We=Ie.negate().toVar();K.sheenRoughness.assign((0,n.clamp)(K.sheenRoughness,Pt,1)),(0,n.If)(ke.not(),()=>{Ne.assign(ir(q,We,K,ze,je)),ke.assign((0,n.bool)(!0))});let Ge=(0,n.vec3)(0).toVar(),Ke=(0,n.vec3)(0).toVar(),qe=(0,n.float)(0).toVar();(0,n.If)(K.clearcoat.greaterThan(0),()=>{let e=br.wrap(xr(N,G,K,Ue,t));Ge.assign(e.L),Ke.assign(e.brdf),qe.assign(e.pdf)}).Else(()=>{let e=bt.wrap(Fi(We,q,K,G.materialIndex,Ue,t,U,W,je,H,Me,ke,Ne));Ge.assign(e.direction),Ke.assign(e.value),qe.assign(e.pdf),(0,n.If)(W.notEqual(G.materialIndex).or(U.not()),()=>{je.assign(Xt(K.metalness,K.roughness,K.transmission,K.clearcoat,K.emissive))}),U.assign((0,n.bool)(!0)),W.assign(G.materialIndex),H.assign((0,n.bool)(!0))}),(0,n.If)((0,n.length)(ze.emissive).greaterThan(0),()=>{let t=(0,n.float)(1).toVar();(0,n.If)(re.equal((0,n.int)(1)).and(L.greaterThan((0,n.int)(0))).and(he.greaterThan(0)),()=>{let e=bi(G.triangleIndex,G.dst,Ie,Fe,o,s,R);t.assign(Ut({pdf1:he,pdf2:e}))}),B.addAssign(zi({contribution:ze.emissive.mul(fe).mul(i).mul(t),pathLength:(0,n.float)(e),fireflyThreshold:I,frame:(0,n.int)(de)}))});let Je=Qr(G.hitPoint,q,K,We,Ge,qe,Ke,r,e,t,h,g,_,v,y,b,x,S,a,o,s,C,w,T,E,D,O,k,A);B.addAssign(zi({contribution:Je.mul(fe).mul(i),pathLength:(0,n.float)(e),fireflyThreshold:I,frame:(0,n.int)(de)})),(0,n.If)(re.equal((0,n.int)(1)).and(L.greaterThan((0,n.int)(0))),()=>{let r=(0,n.Fn)(([e,t,n,r])=>Br(e,t,n,r,fn,a,o,s));(0,n.If)(z.greaterThan((0,n.int)(0)),()=>{let a=ai.wrap(Oi(G.hitPoint,q,t,ce,ae,oe,o));(0,n.If)(e.greaterThan((0,n.int)(1)).and(K.roughness.greaterThan(.9)).and(K.metalness.lessThan(.1)).not().and(a.valid).and(a.pdf.greaterThan(0)),()=>{let o=(0,n.max)((0,n.float)(0),(0,n.dot)(q,a.direction));(0,n.If)(o.greaterThan(0),()=>{let s=Vr(G.hitPoint,q,K),c=G.hitPoint.add(s),l=a.distance.sub(.001),u=r(c,a.direction,l,t);(0,n.If)(u.greaterThan(0),()=>{let t=vr(We,a.direction,q,K),r=Zr(We,a.direction,q,K),s=(0,n.select)(r.greaterThan(0),Ut({pdf1:a.pdf,pdf2:r}),(0,n.float)(1)),c=a.emission.mul(t).mul(o).div(a.pdf).mul(u).mul(se).mul(s);B.addAssign(zi({contribution:c.mul(fe).mul(i),pathLength:(0,n.float)(e),fireflyThreshold:I,frame:(0,n.int)(de)}))})})})}).Else(()=>{let a=wi(G.hitPoint,q,We,K,ne,e,t,se,ae,oe,L,R,o,r,vr,Vr);B.addAssign(zi({contribution:a.mul(fe).mul(i),pathLength:(0,n.float)(e),fireflyThreshold:I,frame:(0,n.int)(de)}))})}),(0,n.If)(H.not().or(e.equal((0,n.int)(0))),()=>{je.assign(Tt.wrap(Pi(K,G.materialIndex,U,W,je))),U.assign((0,n.bool)(!0)),W.assign(G.materialIndex)});let Ye=St.wrap(rr(K,e,je,w,j,A)),Xe=Dr.wrap(ii(We,q,K,Ge,qe,Ke,r,e,t,Ye,C,w,T,D,O,k,A,j));fe.mulAssign(Xe.throughput),Fe.assign(G.hitPoint.add(q.mul(.001))),Ie.assign(Xe.direction),he.assign(Xe.combinedPdf),Oe.assign((0,n.bool)(!1)),(0,n.If)(K.metalness.greaterThan(.7).and(K.roughness.lessThan(.3)),()=>{De.assign((0,n.int)(Ai))}).ElseIf(K.transmission.greaterThan(.5),()=>{De.assign((0,n.int)(ji))}).Else(()=>{De.assign((0,n.int)(Mi))}),(0,n.If)(e.equal((0,n.int)(0)).and(G.didHit),()=>{ye.assign(G.hitPoint),be.assign(G.dst)}),(0,n.If)(xe.not().and(G.didHit),()=>{ge.assign(q),_e.assign(K.color.xyz),ve.assign((0,n.float)(G.materialIndex));let e=K.metalness.greaterThan(.7).and(K.roughness.lessThan(.3)),t=K.transmission.greaterThan(.5);(0,n.If)(e.or(t).not(),()=>{xe.assign((0,n.bool)(!0))})});let Ze=Li(e,fe,K,G.materialIndex,Ie,t,U,W,je,H,Ae,A,j);(0,n.If)(Ze.lessThanEqual(0),()=>{(0,n.Break)()}),fe.divAssign(Ze),Pe.addAssign(1),H.assign((0,n.bool)(!1)),ke.assign((0,n.bool)(!1))}),Ni({radiance:(0,n.vec4)(B,pe),objectNormal:ge,objectColor:_e,objectID:ve,firstHitPoint:ye,firstHitDistance:be})}),Vi=(0,n.wgslFn)(`
512
488
  fn visualizeDepth( depth: f32 ) -> vec3f {
513
489
  return vec3f( 1.0f - depth );
514
490
  }
515
- `),ia=(0,n.wgslFn)(`
491
+ `),Hi=(0,n.wgslFn)(`
516
492
  fn visualizeNormal( normal: vec3f ) -> vec3f {
517
493
  return normal * 0.5f + 0.5f;
518
494
  }
519
- `),aa=(0,n.wgslFn)(`
495
+ `),Ui=(0,n.wgslFn)(`
520
496
  fn computeNDCDepthLocal( worldPos: vec3f, cameraProjectionMatrix: mat4x4f, cameraViewMatrix: mat4x4f ) -> f32 {
521
497
  let clipPos = cameraProjectionMatrix * cameraViewMatrix * vec4f( worldPos, 1.0f );
522
498
  let ndcDepth = clipPos.z / clipPos.w * 0.5f + 0.5f;
523
499
  return clamp( ndcDepth, 0.0f, 1.0f );
524
500
  }
525
- `),oa=(0,n.Fn)(([e,t,r,i,a,o,s,c,l,u,d,f,p,m,h,g,_,v,y,b,x,S])=>{let C=(0,n.vec4)(1,0,1,1).toVar(),w=Ot({origin:e,direction:t}),T=jt.wrap(xn(w,r,i,a).toVar());return(0,n.If)(u.equal((0,n.int)(7)),()=>{let e=(0,n.float)(T.triTests).div(d);C.assign((0,n.select)(e.lessThan(1),(0,n.vec4)((0,n.vec3)(e),1),(0,n.vec4)(1,0,0,1)))}),(0,n.If)(u.equal((0,n.int)(8)),()=>{let e=(0,n.float)(T.boxTests).div(d);C.assign((0,n.select)(e.lessThan(1),(0,n.vec4)((0,n.vec3)(e),1),(0,n.vec4)(1,0,0,1)))}),(0,n.If)(u.equal((0,n.int)(10)),()=>{(0,n.If)(l,()=>{let e=kn({tex:o,samp:(0,n.sampler)(o),direction:t,environmentMatrix:s,environmentIntensity:c,enableEnvironmentLight:l}).toVar(),r=(0,n.dot)(e.xyz,qt).toVar(),i=r.toVar(),a=(0,n.max)(d.mul(.1),.001),u=r.div(a).toVar(),m=(0,n.log)(r.add(1e-6)).add(10).div(10).toVar(),h=(0,n.select)(d.greaterThan(1),u,m).toVar(),g=(0,n.vec3)(0).toVar();(0,n.If)(h.lessThan(.2),()=>{g.assign((0,n.mix)((0,n.vec3)(0,0,0),(0,n.vec3)(0,0,.5),h.mul(5)))}).ElseIf(h.lessThan(.4),()=>{g.assign((0,n.mix)((0,n.vec3)(0,0,.5),(0,n.vec3)(0,0,1),h.sub(.2).mul(5)))}).ElseIf(h.lessThan(.6),()=>{g.assign((0,n.mix)((0,n.vec3)(0,0,1),(0,n.vec3)(0,1,0),h.sub(.4).mul(5)))}).ElseIf(h.lessThan(.8),()=>{g.assign((0,n.mix)((0,n.vec3)(0,1,0),(0,n.vec3)(1,1,0),h.sub(.6).mul(5)))}).ElseIf(h.lessThan(1),()=>{g.assign((0,n.mix)((0,n.vec3)(1,1,0),(0,n.vec3)(1,0,0),h.sub(.8).mul(5)))}).Else(()=>{g.assign((0,n.mix)((0,n.vec3)(1,0,0),(0,n.vec3)(1,1,1),(0,n.min)(h.sub(1),1)))});let _=f.div(p);(0,n.If)(_.x.lessThan(.1).and(_.y.lessThan(.1)),()=>{let e=i.mul(1);g.assign((0,n.vec3)(e))}).ElseIf(_.x.greaterThan(.9).and(_.y.lessThan(.1)),()=>{g.assign(e.xyz.mul(1))}),C.assign((0,n.vec4)(g,1))}).Else(()=>{C.assign((0,n.vec4)(1,0,1,1))})}),(0,n.If)(u.equal((0,n.int)(4)),()=>{(0,n.If)(T.didHit.not(),()=>{C.assign((0,n.vec4)(0,0,0,1))}).Else(()=>{let t=kt.wrap(un(T.materialIndex,a)).toVar(),r=It.wrap(Bn(m,h,g,_,v,y,t,T.uv,T.normal)).toVar().emissive.toVar(),i=(0,n.length)(r).toVar();(0,n.If)(i.greaterThan(0),()=>{let t=r.div((0,n.max)(i.mul(.1),.001)).toVar(),a=(0,n.length)(e.sub(T.hitPoint)),o=(0,n.clamp)((0,n.float)(1).sub(a.div(10)),0,1),s=(0,n.mix)(t,t.mul((0,n.vec3)(1,.8,.6)),o.mul(.3));C.assign((0,n.vec4)(s,1))}).Else(()=>{C.assign((0,n.vec4)(0,0,.1,1))})})}),(0,n.If)(u.equal((0,n.int)(1)),()=>{(0,n.If)(T.didHit.not(),()=>{C.assign((0,n.vec4)(.5,.5,1,1))}).Else(()=>{let e=kt.wrap(un(T.materialIndex,a)).toVar(),t=(0,n.normalize)(It.wrap(Bn(m,h,g,_,v,y,e,T.uv,T.normal)).toVar().normal);C.assign((0,n.vec4)(ia({normal:t}),1))})}),(0,n.If)(u.equal((0,n.int)(2)),()=>{(0,n.If)(T.didHit.not(),()=>{C.assign((0,n.vec4)((0,n.vec3)(1),1))}).Else(()=>{let e=aa({worldPos:T.hitPoint,cameraProjectionMatrix:b,cameraViewMatrix:x});C.assign((0,n.vec4)(ra({depth:e}),1))})}),(0,n.If)(u.equal((0,n.int)(3)),()=>{(0,n.If)(T.didHit.not(),()=>{C.assign((0,n.vec4)(0,0,0,1))}).Else(()=>{let e=kt.wrap(un(T.materialIndex,a)).toVar(),t=It.wrap(Bn(m,h,g,_,v,y,e,T.uv,T.normal)).toVar().albedo.rgb;C.assign((0,n.vec4)(t,1))})}),(0,n.If)(u.equal((0,n.int)(5)),()=>{(0,n.If)(T.didHit.not(),()=>{C.assign((0,n.vec4)(0,0,0,1))}).Else(()=>{let e=kt.wrap(un(T.materialIndex,a)).toVar(),t=It.wrap(Bn(m,h,g,_,v,y,e,T.uv,T.normal)).toVar(),u=t.albedo.rgb.toVar(),d=(0,n.normalize)(t.normal).toVar(),p=ae({state:oe({seed:(0,n.uint)(f.x).mul((0,n.uint)(1973)).add((0,n.uint)(f.y).mul((0,n.uint)(9277))).add(S.mul((0,n.uint)(26699)))})}).toVar(),b=_r({N:d,xi:(0,n.vec2)(P(p).toVar(),P(p).toVar()).toVar()}).toVar(),x=Ot({origin:T.hitPoint.add(d.mul(.001)).toVar(),direction:b}),w=jt.wrap(xn(x,r,i,a).toVar()),E=(0,n.vec3)(0).toVar();(0,n.If)(w.didHit.not(),()=>{(0,n.If)(l,()=>{E.assign(kn({tex:o,samp:(0,n.sampler)(o),direction:b,environmentMatrix:s,environmentIntensity:c,enableEnvironmentLight:l}).xyz)})}).Else(()=>{let e=kt.wrap(un(w.materialIndex,a)).toVar(),t=It.wrap(Bn(m,h,g,_,v,y,e,w.uv,w.normal)).toVar();E.assign(t.emissive),(0,n.If)(l,()=>{let e=(0,n.normalize)(t.normal).toVar(),r=kn({tex:o,samp:(0,n.sampler)(o),direction:e,environmentMatrix:s,environmentIntensity:c,enableEnvironmentLight:l}).xyz;E.addAssign(t.albedo.rgb.mul(r))})});let D=u.mul(E);C.assign((0,n.vec4)(D,1))})}),(0,n.If)(u.equal((0,n.int)(6)),()=>{(0,n.If)(T.didHit,()=>{let e=T.normal.toVar(),r=(0,n.normalize)(t.sub(e.mul((0,n.dot)(t,e).mul(2)))).toVar(),i=kn({tex:o,samp:(0,n.sampler)(o),direction:r,environmentMatrix:s,environmentIntensity:c,enableEnvironmentLight:l}).xyz,a=i.div(i.add(1));C.assign((0,n.vec4)(a,1))}).Else(()=>{let e=kn({tex:o,samp:(0,n.sampler)(o),direction:t,environmentMatrix:s,environmentIntensity:c,enableEnvironmentLight:l}).xyz,r=e.div(e.add(1));C.assign((0,n.vec4)(r,1))})}),C});(0,n.Fn)(([e,t])=>{let r=P(t),i=(0,n.vec3)(.25/255,-.25/255,.25/255).toVar();return i.assign((0,n.mix)(i.mul(2),i.mul(-2),r)),e.add(i)});var sa=(0,n.wgslFn)(`
501
+ `),Wi=(0,n.Fn)(([e,t,r,i,a,o,s,c,l,u,d,f,p,m,h,g,_,v,y,b,x,S])=>{let C=(0,n.vec4)(1,0,1,1).toVar(),w=gt({origin:e,direction:t}),T=yt.wrap(dn(w,r,i,a).toVar());return(0,n.If)(u.equal((0,n.int)(7)),()=>{let e=(0,n.float)(T.triTests).div(d);C.assign((0,n.select)(e.lessThan(1),(0,n.vec4)((0,n.vec3)(e),1),(0,n.vec4)(1,0,0,1)))}),(0,n.If)(u.equal((0,n.int)(8)),()=>{let e=(0,n.float)(T.boxTests).div(d);C.assign((0,n.select)(e.lessThan(1),(0,n.vec4)((0,n.vec3)(e),1),(0,n.vec4)(1,0,0,1)))}),(0,n.If)(u.equal((0,n.int)(10)),()=>{(0,n.If)(l,()=>{let e=yn({tex:o,samp:(0,n.sampler)(o),direction:t,environmentMatrix:s,environmentIntensity:c,enableEnvironmentLight:l}).toVar(),r=(0,n.dot)(e.xyz,Lt).toVar(),i=r.toVar(),a=(0,n.max)(d.mul(.1),.001),u=r.div(a).toVar(),m=(0,n.log)(r.add(1e-6)).add(10).div(10).toVar(),h=(0,n.select)(d.greaterThan(1),u,m).toVar(),g=(0,n.vec3)(0).toVar();(0,n.If)(h.lessThan(.2),()=>{g.assign((0,n.mix)((0,n.vec3)(0,0,0),(0,n.vec3)(0,0,.5),h.mul(5)))}).ElseIf(h.lessThan(.4),()=>{g.assign((0,n.mix)((0,n.vec3)(0,0,.5),(0,n.vec3)(0,0,1),h.sub(.2).mul(5)))}).ElseIf(h.lessThan(.6),()=>{g.assign((0,n.mix)((0,n.vec3)(0,0,1),(0,n.vec3)(0,1,0),h.sub(.4).mul(5)))}).ElseIf(h.lessThan(.8),()=>{g.assign((0,n.mix)((0,n.vec3)(0,1,0),(0,n.vec3)(1,1,0),h.sub(.6).mul(5)))}).ElseIf(h.lessThan(1),()=>{g.assign((0,n.mix)((0,n.vec3)(1,1,0),(0,n.vec3)(1,0,0),h.sub(.8).mul(5)))}).Else(()=>{g.assign((0,n.mix)((0,n.vec3)(1,0,0),(0,n.vec3)(1,1,1),(0,n.min)(h.sub(1),1)))});let _=f.div(p);(0,n.If)(_.x.lessThan(.1).and(_.y.lessThan(.1)),()=>{let e=i.mul(1);g.assign((0,n.vec3)(e))}).ElseIf(_.x.greaterThan(.9).and(_.y.lessThan(.1)),()=>{g.assign(e.xyz.mul(1))}),C.assign((0,n.vec4)(g,1))}).Else(()=>{C.assign((0,n.vec4)(1,0,1,1))})}),(0,n.If)(u.equal((0,n.int)(4)),()=>{(0,n.If)(T.didHit.not(),()=>{C.assign((0,n.vec4)(0,0,0,1))}).Else(()=>{let t=_t.wrap($t(T.materialIndex,a)).toVar(),r=wt.wrap(An(m,h,g,_,v,y,t,T.uv,T.normal)).toVar().emissive.toVar(),i=(0,n.length)(r).toVar();(0,n.If)(i.greaterThan(0),()=>{let t=r.div((0,n.max)(i.mul(.1),.001)).toVar(),a=(0,n.length)(e.sub(T.hitPoint)),o=(0,n.clamp)((0,n.float)(1).sub(a.div(10)),0,1),s=(0,n.mix)(t,t.mul((0,n.vec3)(1,.8,.6)),o.mul(.3));C.assign((0,n.vec4)(s,1))}).Else(()=>{C.assign((0,n.vec4)(0,0,.1,1))})})}),(0,n.If)(u.equal((0,n.int)(1)),()=>{(0,n.If)(T.didHit.not(),()=>{C.assign((0,n.vec4)(.5,.5,1,1))}).Else(()=>{let e=_t.wrap($t(T.materialIndex,a)).toVar(),t=(0,n.normalize)(wt.wrap(An(m,h,g,_,v,y,e,T.uv,T.normal)).toVar().normal);C.assign((0,n.vec4)(Hi({normal:t}),1))})}),(0,n.If)(u.equal((0,n.int)(2)),()=>{(0,n.If)(T.didHit.not(),()=>{C.assign((0,n.vec4)((0,n.vec3)(1),1))}).Else(()=>{let e=Ui({worldPos:T.hitPoint,cameraProjectionMatrix:b,cameraViewMatrix:x});C.assign((0,n.vec4)(Vi({depth:e}),1))})}),(0,n.If)(u.equal((0,n.int)(3)),()=>{(0,n.If)(T.didHit.not(),()=>{C.assign((0,n.vec4)(0,0,0,1))}).Else(()=>{let e=_t.wrap($t(T.materialIndex,a)).toVar(),t=wt.wrap(An(m,h,g,_,v,y,e,T.uv,T.normal)).toVar().albedo.rgb;C.assign((0,n.vec4)(t,1))})}),(0,n.If)(u.equal((0,n.int)(5)),()=>{(0,n.If)(T.didHit.not(),()=>{C.assign((0,n.vec4)(0,0,0,1))}).Else(()=>{let e=_t.wrap($t(T.materialIndex,a)).toVar(),t=wt.wrap(An(m,h,g,_,v,y,e,T.uv,T.normal)).toVar(),u=t.albedo.rgb.toVar(),d=(0,n.normalize)(t.normal).toVar(),p=A({state:j({seed:(0,n.uint)(f.x).mul((0,n.uint)(1973)).add((0,n.uint)(f.y).mul((0,n.uint)(9277))).add(S.mul((0,n.uint)(26699)))})}).toVar(),b=sr({N:d,xi:(0,n.vec2)(N(p).toVar(),N(p).toVar()).toVar()}).toVar(),x=gt({origin:T.hitPoint.add(d.mul(.001)).toVar(),direction:b}),w=yt.wrap(dn(x,r,i,a).toVar()),E=(0,n.vec3)(0).toVar();(0,n.If)(w.didHit.not(),()=>{(0,n.If)(l,()=>{E.assign(yn({tex:o,samp:(0,n.sampler)(o),direction:b,environmentMatrix:s,environmentIntensity:c,enableEnvironmentLight:l}).xyz)})}).Else(()=>{let e=_t.wrap($t(w.materialIndex,a)).toVar(),t=wt.wrap(An(m,h,g,_,v,y,e,w.uv,w.normal)).toVar();E.assign(t.emissive),(0,n.If)(l,()=>{let e=(0,n.normalize)(t.normal).toVar(),r=yn({tex:o,samp:(0,n.sampler)(o),direction:e,environmentMatrix:s,environmentIntensity:c,enableEnvironmentLight:l}).xyz;E.addAssign(t.albedo.rgb.mul(r))})});let D=u.mul(E);C.assign((0,n.vec4)(D,1))})}),(0,n.If)(u.equal((0,n.int)(6)),()=>{(0,n.If)(T.didHit,()=>{let e=T.normal.toVar(),r=(0,n.normalize)(t.sub(e.mul((0,n.dot)(t,e).mul(2)))).toVar(),i=yn({tex:o,samp:(0,n.sampler)(o),direction:r,environmentMatrix:s,environmentIntensity:c,enableEnvironmentLight:l}).xyz,a=i.div(i.add(1));C.assign((0,n.vec4)(a,1))}).Else(()=>{let e=yn({tex:o,samp:(0,n.sampler)(o),direction:t,environmentMatrix:s,environmentIntensity:c,enableEnvironmentLight:l}).xyz,r=e.div(e.add(1));C.assign((0,n.vec4)(r,1))})}),C});(0,n.Fn)(([e,t])=>{let r=N(t),i=(0,n.vec3)(.25/255,-.25/255,.25/255).toVar();return i.assign((0,n.mix)(i.mul(2),i.mul(-2),r)),e.add(i)});var Gi=(0,n.wgslFn)(`
526
502
  fn computeNDCDepth( worldPos: vec3f, cameraProjectionMatrix: mat4x4f, cameraViewMatrix: mat4x4f ) -> f32 {
527
503
  let clipPos = cameraProjectionMatrix * cameraViewMatrix * vec4f( worldPos, 1.0f );
528
504
  let ndcDepth = clipPos.z / clipPos.w * 0.5f + 0.5f;
529
505
  return clamp( ndcDepth, 0.0f, 1.0f );
530
506
  }
531
- `),ca=(0,n.Fn)(([e,t,r,i,a])=>{let o=(0,n.texture)(r,e.div(t),0),s=(0,n.int)(0).toVar();return(0,n.If)(o.b.greaterThan(.5),()=>{s.assign(0)}).Else(()=>{let e=(0,n.int)((0,n.floor)(o.r.mul((0,n.float)(a)).add(.5)));s.assign((0,n.clamp)(e,i,a))}),s}),la=e=>{let{pixelCoord:t,writeColorTex:r,writeNDTex:i,writeAlbedoTex:a,resolution:o,frame:s,samplesPerPixel:c,visMode:l,cameraWorldMatrix:u,cameraProjectionMatrixInverse:d,cameraViewMatrix:f,cameraProjectionMatrix:p,bvhBuffer:m,triangleBuffer:h,materialBuffer:g,albedoMaps:_,normalMaps:v,bumpMaps:y,metalnessMaps:b,roughnessMaps:x,emissiveMaps:S,displacementMaps:C,directionalLightsBuffer:w,numDirectionalLights:T,areaLightsBuffer:E,numAreaLights:D,pointLightsBuffer:O,numPointLights:k,spotLightsBuffer:A,numSpotLights:j,envTexture:M,environmentIntensity:N,envMatrix:ee,envCDFBuffer:te,envTotalSum:ne,envCompensationDelta:re,envResolution:ie,enableEnvironmentLight:oe,useEnvMapIS:se,maxBounceCount:P,transmissiveBounces:ce,showBackground:le,transparentBackground:ue,backgroundIntensity:de,fireflyThreshold:fe,globalIlluminationIntensity:pe,totalTriangleCount:me,enableEmissiveTriangleSampling:he,emissiveTriangleBuffer:F,emissiveVec4Offset:I,emissiveTriangleCount:ve,emissiveTotalPower:ye,emissiveBoost:L,lightBVHBuffer:be,lightBVHNodeCount:xe,debugVisScale:Se,enableAccumulation:R,hasPreviousAccumulated:Ce,prevAccumTexture:we,prevNormalDepthTexture:Te,prevAlbedoTexture:Ee,accumulationAlpha:De,cameraIsMoving:Oe,useAdaptiveSampling:ke,adaptiveSamplingTexture:Ae,adaptiveSamplingMin:je,adaptiveSamplingMax:Me,enableDOF:Ne,focalLength:z,aperture:Pe,focusDistance:Fe,sceneScale:Ie,apertureScale:Le,anamorphicRatio:Re}=e,ze=(0,n.uvec2)((0,n.uint)((0,n.int)(t.x)),(0,n.uint)((0,n.int)(t.y))),B=t.div(o),V=t.div(o).mul(2).sub(1).toVar();V.y.assign(V.y.negate());let H=(0,n.vec4)(0).toVar(),U=(0,n.int)(0).toVar(),Be=_e({pixelCoord:t,rayIndex:(0,n.int)(0),frame:s}).toVar(),Ve=(0,n.int)(t.y).mul((0,n.int)(o.x)).add((0,n.int)(t.x)).toVar(),He=(0,n.vec3)(0,0,1).toVar(),W=(0,n.float)(1).toVar(),Ue=(0,n.float)(0).toVar(),We=(0,n.int)(c).toVar();(0,n.If)(s.greaterThan((0,n.uint)(2)).and(ke),()=>{let e=ca(t,o,Ae,je,Me);We.assign(e),(0,n.If)(We.equal((0,n.int)(0)),()=>{(0,n.If)(R.and(Ce),()=>{let e=(0,n.texture)(we,B,0);H.assign(e),Ue.assign(e.w);let t=(0,n.texture)(Te,B,0);He.assign(t.xyz.mul(2).sub(1)),W.assign(t.w)}).Else(()=>{We.assign(1)})})});let Ge=(0,n.vec3)(0).toVar(),Ke=(0,n.vec3)(0).toVar(),qe=(0,n.float)(-1e3).toVar(),Je=(0,n.vec2)(2).div(o).toVar();(0,n.Loop)({start:(0,n.int)(0),end:We,type:`int`,condition:`<`},({i:e})=>{let r=ae({state:Be.add((0,n.uint)(e))}).toVar(),i=ge(t,e,We,r,o,s).toVar();(0,n.If)(l.equal((0,n.int)(9)),()=>{H.assign((0,n.vec4)(i,1,1)),U.assign(1),(0,n.Break)()});let a=i.sub(.5).mul(Je),c=V.add(a),_e=Ot.wrap(Cn(c,r,u,d,Ne,z,Pe,Fe,Ie,Le,Re)),R=(0,n.vec4)(0).toVar();(0,n.If)(l.greaterThan((0,n.int)(0)),()=>{R.assign(oa(_e.origin,_e.direction,m,h,g,M,ee,N,oe,l,Se,t,o,_,v,y,b,x,S,p,f,s))}).Else(()=>{let i=Yi.wrap(na(_e,r,e,Ve,m,h,g,_,v,y,b,x,S,C,w,T,E,D,O,k,A,j,M,N,ee,te,ne,re,ie,oe,se,P,ce,de,le,ue,fe,pe,me,he,F,I,ve,ye,L,be,xe,t,o,s));R.assign(i.radiance),(0,n.If)(e.equal((0,n.int)(0)),()=>{Ge.assign(i.objectNormal),Ke.assign(i.objectColor),qe.assign(i.objectID),(0,n.If)(i.firstHitDistance.lessThan(1e9),()=>{He.assign((0,n.normalize)(i.objectNormal)),W.assign(sa({worldPos:i.firstHitPoint,cameraProjectionMatrix:p,cameraViewMatrix:f}))})})}),H.addAssign(R),Ue.addAssign(R.w),U.addAssign(1)}),(0,n.If)(U.greaterThan((0,n.int)(0)),()=>{H.divAssign((0,n.float)(U)),Ue.divAssign((0,n.float)(U))});let Ye=H.xyz.toVar(),Xe=(0,n.vec4)(He.mul(.5).add(.5),W).toVar(),Ze=(0,n.vec3)(Ke).toVar(),Qe=(0,n.select)(ue,Ue,(0,n.float)(1)).toVar();(0,n.If)(R.and(Oe.not()).and(s.greaterThan((0,n.uint)(0))).and(Ce),()=>{let e=(0,n.texture)(we,B,0).toVar();Ye.assign((0,n.mix)(e.xyz,H.xyz,De)),Xe.assign((0,n.mix)((0,n.texture)(Te,B,0),Xe,De)),Ze.assign((0,n.mix)((0,n.texture)(Ee,B,0).xyz,Ze,De)),(0,n.If)(ue,()=>{Qe.assign((0,n.mix)(e.w,Ue,De))})}),(0,n.textureStore)(r,ze,(0,n.vec4)(Ye.xyz,Qe)).toWriteOnly(),(0,n.textureStore)(i,ze,Xe).toWriteOnly(),(0,n.textureStore)(a,ze,(0,n.vec4)(Ze,1)).toWriteOnly()},ua=class{constructor(e=`Build`){this.label=e,this.entries=new Map,this.order=[],this.totalStart=performance.now()}start(e){return this.entries.set(e,{start:performance.now(),end:null}),this.order.includes(e)||this.order.push(e),this}end(e){let t=this.entries.get(e);return t&&(t.end=performance.now(),t.duration=t.end-t.start),this}getDuration(e){return this.entries.get(e)?.duration??0}print(){let e=performance.now()-this.totalStart,t=this.order.map(e=>{let t=this.entries.get(e)?.duration??0;return t>=1?`${e} ${Math.round(t)}ms`:null}).filter(Boolean);return console.log(`[${this.label}] ${Math.round(e)}ms`+(t.length?` | ${t.join(` · `)}`:``)),{steps:Object.fromEntries(this.order.map(e=>[e,Math.round(this.entries.get(e)?.duration??0)])),total:Math.round(e)}}},da=8,fa=class{constructor(){this.computeNode=null,this.prevColorTexNode=null,this.prevNormalDepthTexNode=null,this.prevAlbedoTexNode=null,this.adaptiveSamplingTexNode=null,this.tileOffsetX=(0,n.uniform)(0,`int`),this.tileOffsetY=(0,n.uniform)(0,`int`),this.renderWidth=(0,n.uniform)(1920,`int`),this.renderHeight=(0,n.uniform)(1080,`int`),this._dispatchX=0,this._dispatchY=0,this._dispatchSize=[0,0,1],this._sceneTextureNodes=null,this._compiled=!1}setupCompute(e){let{stage:t,storageTextures:n}=e,r=new ua(`setupCompute`);r.start(`Create texture nodes`);let i=this._createTextureNodes(t,n);r.end(`Create texture nodes`),r.start(`Build compute node (TSL)`);let a=n.renderWidth,o=n.renderHeight;this._dispatchX=Math.ceil(a/da),this._dispatchY=Math.ceil(o/da),this.renderWidth.value=a,this.renderHeight.value=o;let s=n.getWriteTextures();this.computeNode=this._buildComputeNode(t,i,s.color,s.normalDepth,s.albedo),this._compiled=!1,r.end(`Build compute node (TSL)`),r.print()}updateSceneTextures(e){let t=this._sceneTextureNodes,n=e.environment,r=e.materialData;n.environmentTexture&&t.envTex&&(t.envTex.value=n.environmentTexture),r.albedoMaps&&t.albedoMapsTex&&(t.albedoMapsTex.value=r.albedoMaps),r.normalMaps&&t.normalMapsTex&&(t.normalMapsTex.value=r.normalMaps),r.bumpMaps&&t.bumpMapsTex&&(t.bumpMapsTex.value=r.bumpMaps),r.metalnessMaps&&t.metalnessMapsTex&&(t.metalnessMapsTex.value=r.metalnessMaps),r.roughnessMaps&&t.roughnessMapsTex&&(t.roughnessMapsTex.value=r.roughnessMaps),r.emissiveMaps&&t.emissiveMapsTex&&(t.emissiveMapsTex.value=r.emissiveMaps),r.displacementMaps&&t.displacementMapsTex&&(t.displacementMapsTex.value=r.displacementMaps),console.log(`ShaderBuilder: Scene textures updated in-place`)}getSceneTextureNodes(){return this._sceneTextureNodes}setSize(e,t){this._dispatchX=Math.ceil(e/da),this._dispatchY=Math.ceil(t/da),this.computeNode&&(this._dispatchSize[0]=this._dispatchX,this._dispatchSize[1]=this._dispatchY,this.computeNode.dispatchSize=this._dispatchSize),this.renderWidth.value=e,this.renderHeight.value=t,this.tileOffsetX.value=0,this.tileOffsetY.value=0}setTileDispatch(e,t,n,r){this.tileOffsetX.value=e,this.tileOffsetY.value=t;let i=Math.ceil(n/da),a=Math.ceil(r/da);this.computeNode&&(this._dispatchSize[0]=i,this._dispatchSize[1]=a,this.computeNode.dispatchSize=this._dispatchSize)}setFullScreenDispatch(){this.tileOffsetX.value=0,this.tileOffsetY.value=0,this.computeNode&&(this._dispatchSize[0]=this._dispatchX,this._dispatchSize[1]=this._dispatchY,this.computeNode.dispatchSize=this._dispatchSize)}forceCompile(e){this._compiled||!this.computeNode||!e||(this._compiled=!0,e.compute(this.computeNode))}_createTextureNodes(e,i){let a=e.triangleStorageNode,o=e.bvhStorageNode,s=e.materialData.materialStorageNode,c=e.lightStorageNode;$r(e.uniforms.get(`enableAlphaShadows`));let l=(0,n.texture)(e.environment.environmentTexture),u=new t.TextureNode;this.adaptiveSamplingTexNode=u;let d=e.environment.envCDFStorageNode,f=i.getReadTextures();this.prevColorTexNode=(0,n.texture)(f.color),this.prevNormalDepthTexNode=(0,n.texture)(f.normalDepth),this.prevAlbedoTexNode=(0,n.texture)(f.albedo);let p=()=>{let e=new r.DataArrayTexture(new Uint8Array([255,255,255,255]),1,1,1);return e.minFilter=r.LinearFilter,e.magFilter=r.LinearFilter,e.generateMipmaps=!1,e.needsUpdate=!0,(0,n.texture)(e)},m=e.materialData,h=m.albedoMaps?(0,n.texture)(m.albedoMaps):p(),g=m.normalMaps?(0,n.texture)(m.normalMaps):p(),_=m.bumpMaps?(0,n.texture)(m.bumpMaps):p(),v=m.metalnessMaps?(0,n.texture)(m.metalnessMaps):p(),y=m.roughnessMaps?(0,n.texture)(m.roughnessMaps):p(),b=m.emissiveMaps?(0,n.texture)(m.emissiveMaps):p(),x=m.displacementMaps?(0,n.texture)(m.displacementMaps):p();Qr(h);let S={triStorage:a,bvhStorage:o,matStorage:s,lightBufferStorage:c,envTex:l,adaptiveSamplingTex:u,envCDFStorage:d,albedoMapsTex:h,normalMapsTex:g,bumpMapsTex:_,metalnessMapsTex:v,roughnessMapsTex:y,emissiveMapsTex:b,displacementMapsTex:x};return this._sceneTextureNodes=S,S}_buildComputeNode(e,t,r,i,a){let{triStorage:o,bvhStorage:s,matStorage:c,lightBufferStorage:l,envTex:u,adaptiveSamplingTex:d,envCDFStorage:f,albedoMapsTex:p,normalMapsTex:m,bumpMapsTex:h,metalnessMapsTex:g,roughnessMapsTex:_,emissiveMapsTex:v,displacementMapsTex:y}=t,b=this.tileOffsetX,x=this.tileOffsetY,S=this.renderWidth,C=this.renderHeight,w=this.prevColorTexNode,T=this.prevNormalDepthTexNode,E=this.prevAlbedoTexNode;return(0,n.Fn)(()=>{let t=b.add((0,n.int)(n.workgroupId.x).mul(da)).add((0,n.int)(n.localId.x)),D=x.add((0,n.int)(n.workgroupId.y).mul(da)).add((0,n.int)(n.localId.y));(0,n.If)(t.lessThan(S).and(D.lessThan(C)),()=>{la({pixelCoord:(0,n.vec2)((0,n.float)(t).add(.5),(0,n.float)(D).add(.5)),writeColorTex:r,writeNDTex:i,writeAlbedoTex:a,prevAccumTexture:w,prevNormalDepthTexture:T,prevAlbedoTexture:E,resolution:e.resolution,frame:e.frame,samplesPerPixel:e.samplesPerPixel,visMode:e.visMode,cameraWorldMatrix:e.cameraWorldMatrix,cameraProjectionMatrixInverse:e.cameraProjectionMatrixInverse,cameraViewMatrix:e.cameraViewMatrix,cameraProjectionMatrix:e.cameraProjectionMatrix,bvhBuffer:s,triangleBuffer:o,materialBuffer:c,albedoMaps:p,normalMaps:m,bumpMaps:h,metalnessMaps:g,roughnessMaps:_,emissiveMaps:v,displacementMaps:y,directionalLightsBuffer:e.directionalLightsBufferNode,numDirectionalLights:e.numDirectionalLights,areaLightsBuffer:e.areaLightsBufferNode,numAreaLights:e.numAreaLights,pointLightsBuffer:e.pointLightsBufferNode,numPointLights:e.numPointLights,spotLightsBuffer:e.spotLightsBufferNode,numSpotLights:e.numSpotLights,envTexture:u,environmentIntensity:e.environmentIntensity,envMatrix:e.environmentMatrix,envCDFBuffer:f,envTotalSum:e.envTotalSum,envCompensationDelta:e.envCompensationDelta,envResolution:e.envResolution,enableEnvironmentLight:e.enableEnvironment,useEnvMapIS:e.useEnvMapIS,maxBounceCount:e.maxBounces,transmissiveBounces:e.transmissiveBounces,showBackground:e.showBackground,transparentBackground:e.transparentBackground,backgroundIntensity:e.backgroundIntensity,fireflyThreshold:e.fireflyThreshold,globalIlluminationIntensity:e.globalIlluminationIntensity,totalTriangleCount:e.totalTriangleCount,enableEmissiveTriangleSampling:e.enableEmissiveTriangleSampling,emissiveTriangleBuffer:l,emissiveTriangleCount:e.emissiveTriangleCount,emissiveTotalPower:e.emissiveTotalPower,emissiveBoost:e.emissiveBoost,emissiveVec4Offset:e.emissiveVec4Offset,lightBVHBuffer:l,lightBVHNodeCount:e.lightBVHNodeCount,debugVisScale:e.debugVisScale,enableAccumulation:e.enableAccumulation,hasPreviousAccumulated:e.hasPreviousAccumulated,accumulationAlpha:e.accumulationAlpha,cameraIsMoving:e.cameraIsMoving,useAdaptiveSampling:e.useAdaptiveSampling,adaptiveSamplingTexture:d,adaptiveSamplingMin:e.adaptiveSamplingMin,adaptiveSamplingMax:e.adaptiveSamplingMax,enableDOF:e.enableDOF,focalLength:e.focalLength,aperture:e.aperture,focusDistance:e.focusDistance,sceneScale:e.sceneScale,apertureScale:e.apertureScale,anamorphicRatio:e.anamorphicRatio})})})().compute([this._dispatchX,this._dispatchY,1],[da,da,1])}dispose(){this.computeNode?.dispose(),this.computeNode=null,this.prevColorTexNode=null,this.prevNormalDepthTexNode=null,this.prevAlbedoTexNode=null,this.adaptiveSamplingTexNode=null,this._sceneTextureNodes=null,this._compiled=!1}},pa=class{constructor(e,t){this.traversalCost=e,this.intersectionCost=t,this.maxTreeletLeaves=7,this.minImprovement=.02,this.topologyCache=new Map;for(let e=3;e<=this.maxTreeletLeaves;e++)this.topologyCache.set(e,this.generateTopologies(e));this.stats={treeletsProcessed:0,treeletsImproved:0,totalSAHImprovement:0,averageSAHImprovement:0,optimizationTime:0}}generateTopologies(e){if(e===1)return[0];if(e===2)return[[0,1]];let t=[];for(let n=1;n<e;n++){let r=this.generateTopologies(n),i=this.generateTopologies(e-n);for(let e of r)for(let r of i)t.push([e,this.offsetTopology(r,n)])}return t}offsetTopology(e,t){return typeof e==`number`?e+t:[this.offsetTopology(e[0],t),this.offsetTopology(e[1],t)]}optimizeBVH(e){let t=performance.now();this.stats={treeletsProcessed:0,treeletsImproved:0,totalSAHImprovement:0,averageSAHImprovement:0,optimizationTime:0};let n=this.identifyTreeletRoots(e);for(let e=0;e<n.length;e++){if(performance.now()-t>3e4){console.warn(`TreeletOptimizer: timeout after ${e}/${n.length} treelets`);break}this.optimizeTreelet(n[e])}return this.stats.optimizationTime=performance.now()-t,this.stats.averageSAHImprovement=this.stats.treeletsProcessed>0?this.stats.totalSAHImprovement/this.stats.treeletsProcessed:0,e}identifyTreeletRoots(e){let t=[],n=new Set,r=[{node:e,visited:!1}];for(;r.length>0;){let e=r[r.length-1];if(e.visited){r.pop();let i=e.node;if(i.triangleCount>0||n.has(i))continue;let a=this.countLeaves(i);a>=3&&a<=this.maxTreeletLeaves&&(t.push(i),this.markSubtree(i,n))}else{e.visited=!0;let t=e.node;if(t.triangleCount>0)continue;t.rightChild&&r.push({node:t.rightChild,visited:!1}),t.leftChild&&r.push({node:t.leftChild,visited:!1})}}return t}countLeaves(e){return e?e.triangleCount>0?1:this.countLeaves(e.leftChild)+this.countLeaves(e.rightChild):0}markSubtree(e,t){e&&(t.add(e),!(e.triangleCount>0)&&(this.markSubtree(e.leftChild,t),this.markSubtree(e.rightChild,t)))}optimizeTreelet(e){let t=[];this.extractLeaves(e,t);let n=t.length;if(n<3||n>this.maxTreeletLeaves)return;this.stats.treeletsProcessed++;let r=this.evaluateSubtreeSAH(e),i=this.topologyCache.get(n);if(!i||i.length===0)return;let a=r,o=null,s=null;if(n<=5){let e=this.generatePermutations(n);for(let n of i)for(let r of e){let e=this.evaluateTopology(n,t,r);e<a&&(a=e,o=n,s=r)}}else{let e=Array.from({length:n},(e,t)=>t);for(let n of i){let r=this.evaluateTopology(n,t,e);r<a&&(a=r,o=n,s=e);let i=this.greedySwapOptimize(n,t,e,r);i.cost<a&&(a=i.cost,o=n,s=i.perm)}}let c=(r-a)/r;o&&c>this.minImprovement&&(this.reconstructTreelet(e,o,t,s),this.stats.treeletsImproved++,this.stats.totalSAHImprovement+=c)}extractLeaves(e,t){if(e){if(e.triangleCount>0){t.push({minX:e.minX,minY:e.minY,minZ:e.minZ,maxX:e.maxX,maxY:e.maxY,maxZ:e.maxZ,triangleOffset:e.triangleOffset,triangleCount:e.triangleCount});return}this.extractLeaves(e.leftChild,t),this.extractLeaves(e.rightChild,t)}}evaluateSubtreeSAH(e){if(!e)return 0;if(e.triangleCount>0)return this.surfaceAreaFlat(e.minX,e.minY,e.minZ,e.maxX,e.maxY,e.maxZ)*e.triangleCount*this.intersectionCost;let t=this.evaluateSubtreeSAH(e.leftChild),n=this.evaluateSubtreeSAH(e.rightChild);return this.surfaceAreaFlat(e.minX,e.minY,e.minZ,e.maxX,e.maxY,e.maxZ)*this.traversalCost+t+n}evaluateTopology(e,t,n){return this.evalTopoRecursive(e,t,n).cost}evalTopoRecursive(e,t,n){if(typeof e==`number`){let r=t[n[e]];return{cost:this.surfaceAreaFlat(r.minX,r.minY,r.minZ,r.maxX,r.maxY,r.maxZ)*r.triangleCount*this.intersectionCost,minX:r.minX,minY:r.minY,minZ:r.minZ,maxX:r.maxX,maxY:r.maxY,maxZ:r.maxZ}}let r=this.evalTopoRecursive(e[0],t,n),i=this.evalTopoRecursive(e[1],t,n),a=Math.min(r.minX,i.minX),o=Math.min(r.minY,i.minY),s=Math.min(r.minZ,i.minZ),c=Math.max(r.maxX,i.maxX),l=Math.max(r.maxY,i.maxY),u=Math.max(r.maxZ,i.maxZ);return{cost:this.surfaceAreaFlat(a,o,s,c,l,u)*this.traversalCost+r.cost+i.cost,minX:a,minY:o,minZ:s,maxX:c,maxY:l,maxZ:u}}surfaceAreaFlat(e,t,n,r,i,a){let o=r-e,s=i-t,c=a-n;return 2*(o*s+s*c+c*o)}generatePermutations(e){let t=[],n=Array.from({length:e},(e,t)=>t),r=i=>{if(i===e){t.push([...n]);return}for(let t=i;t<e;t++)[n[i],n[t]]=[n[t],n[i]],r(i+1),[n[i],n[t]]=[n[t],n[i]]};return r(0),t}greedySwapOptimize(e,t,n,r){let i=[...n],a=r,o=!0;for(;o;){o=!1;for(let n=0;n<i.length-1;n++)for(let r=n+1;r<i.length;r++){[i[n],i[r]]=[i[r],i[n]];let s=this.evaluateTopology(e,t,i);s<a?(a=s,o=!0):[i[n],i[r]]=[i[r],i[n]]}}return{perm:i,cost:a}}reconstructTreelet(e,t,n,r){let i=this.buildSubtree(t,n,r);e.minX=i.minX,e.minY=i.minY,e.minZ=i.minZ,e.maxX=i.maxX,e.maxY=i.maxY,e.maxZ=i.maxZ,e.leftChild=i.leftChild,e.rightChild=i.rightChild,e.triangleOffset=i.triangleOffset,e.triangleCount=i.triangleCount}buildSubtree(e,t,n){if(typeof e==`number`){let r=t[n[e]],i=new ma;return i.minX=r.minX,i.minY=r.minY,i.minZ=r.minZ,i.maxX=r.maxX,i.maxY=r.maxY,i.maxZ=r.maxZ,i.triangleOffset=r.triangleOffset,i.triangleCount=r.triangleCount,i}let r=this.buildSubtree(e[0],t,n),i=this.buildSubtree(e[1],t,n),a=new ma;return a.leftChild=r,a.rightChild=i,a.minX=Math.min(r.minX,i.minX),a.minY=Math.min(r.minY,i.minY),a.minZ=Math.min(r.minZ,i.minZ),a.maxX=Math.max(r.maxX,i.maxX),a.maxY=Math.max(r.maxY,i.maxY),a.maxZ=Math.max(r.maxZ,i.maxZ),a}setTreeletSize(e){this.maxTreeletLeaves=Math.max(3,Math.min(7,e));for(let e=3;e<=this.maxTreeletLeaves;e++)this.topologyCache.has(e)||this.topologyCache.set(e,this.generateTopologies(e))}setMinImprovement(e){this.minImprovement=Math.max(.001,e)}setMaxTreelets(){}getStatistics(){return{...this.stats}}},ma=class{constructor(){this.minX=0,this.minY=0,this.minZ=0,this.maxX=0,this.maxY=0,this.maxZ=0,this.leftChild=null,this.rightChild=null,this.triangleOffset=0,this.triangleCount=0}},ha=class{constructor(e,t){this.traversalCost=e,this.intersectionCost=t,this.batchSizeRatio=.02,this.maxIterations=2,this.timeBudgetMs=15e3,this.stats={reinsertionsApplied:0,iterations:0,timeMs:0}}setBatchSizeRatio(e){this.batchSizeRatio=Math.max(.005,Math.min(.1,e))}setMaxIterations(e){this.maxIterations=Math.max(1,Math.min(5,e))}getStatistics(){return{...this.stats}}surfaceArea(e){let t=e.maxX-e.minX,n=e.maxY-e.minY,r=e.maxZ-e.minZ;return t*n+n*r+r*t}buildParentMap(e){let t=new Map;t.set(e,{parent:null,isLeft:!1});let n=[e];for(;n.length>0;){let e=n.pop();e.triangleCount>0||(e.leftChild&&(t.set(e.leftChild,{parent:e,isLeft:!0}),n.push(e.leftChild)),e.rightChild&&(t.set(e.rightChild,{parent:e,isLeft:!1}),n.push(e.rightChild)))}return t}findCandidates(e,t,n){let r=[],i=[e];for(;i.length>0;){let a=i.pop();if(a!==e&&n.get(a).parent!==e){let e=this.surfaceArea(a);r.length<t?(r.push({node:a,cost:e}),r.length===t&&this._heapify(r)):e>r[0].cost&&(r[0]={node:a,cost:e},this._siftDown(r,0))}a.triangleCount===0&&(a.leftChild&&i.push(a.leftChild),a.rightChild&&i.push(a.rightChild))}return r}_heapify(e){for(let t=(e.length>>1)-1;t>=0;t--)this._siftDown(e,t)}_siftDown(e,t){let n=e.length;for(;;){let r=t,i=2*t+1,a=2*t+2;if(i<n&&e[i].cost<e[r].cost&&(r=i),a<n&&e[a].cost<e[r].cost&&(r=a),r===t)break;let o=e[t];e[t]=e[r],e[r]=o,t=r}}findReinsertion(e,t,n){let r=n.get(e),i=r.parent;if(!i)return null;let a=r.isLeft?i.rightChild:i.leftChild,o=this.surfaceArea(e),s=this.surfaceArea(i),c=null,l=0,u=s,d=a.minX,f=a.minY,p=a.minZ,m=a.maxX,h=a.maxY,g=a.maxZ,_=a,v=i,y=[];do{for(y.length=0,y.push(u,_);y.length>0;){let t=y.pop(),n=y.pop();if(n-o<=l)continue;let r=Math.min(t.minX,e.minX),i=Math.min(t.minY,e.minY),a=Math.min(t.minZ,e.minZ),s=Math.max(t.maxX,e.maxX),u=Math.max(t.maxY,e.maxY),d=Math.max(t.maxZ,e.maxZ),f=s-r,p=u-i,m=d-a,h=n-(f*p+p*m+m*f);if(h>l&&(c=t,l=h),t.triangleCount===0&&t.leftChild&&t.rightChild){let e=h+this.surfaceArea(t);y.push(e,t.leftChild),y.push(e,t.rightChild)}}let t=n.get(v);if(!t||t.parent===null)break;if(v!==i){d=Math.min(d,_.minX),f=Math.min(f,_.minY),p=Math.min(p,_.minZ),m=Math.max(m,_.maxX),h=Math.max(h,_.maxY),g=Math.max(g,_.maxZ);let e=m-d,t=h-f,n=g-p,r=e*t+t*n+n*e;u+=this.surfaceArea(v)-r}let r=t.parent;_=t.isLeft?r.rightChild:r.leftChild,v=r}while(n.get(v).parent!==null);return c===a||c===i?null:c?{from:e,to:c,areaDiff:l}:null}getConflicts(e,t,n){let r=n.get(e);return[t,e,r.isLeft?r.parent.rightChild:r.parent.leftChild,n.get(t).parent,r.parent]}reinsertNode(e,t,n){let r=n.get(e),i=r.parent,a=r.isLeft?i.rightChild:i.leftChild,o=n.get(i),s=o.parent,c=n.get(t),l=c.parent;o.isLeft?s.leftChild=a:s.rightChild=a,i.leftChild=e,i.rightChild=t,i.triangleOffset=0,i.triangleCount=0,i.minX=Math.min(e.minX,t.minX),i.minY=Math.min(e.minY,t.minY),i.minZ=Math.min(e.minZ,t.minZ),i.maxX=Math.max(e.maxX,t.maxX),i.maxY=Math.max(e.maxY,t.maxY),i.maxZ=Math.max(e.maxZ,t.maxZ),c.isLeft?l.leftChild=i:l.rightChild=i,n.set(a,{parent:s,isLeft:o.isLeft}),n.set(i,{parent:l,isLeft:c.isLeft}),n.set(e,{parent:i,isLeft:!0}),n.set(t,{parent:i,isLeft:!1}),this.refitFrom(s,n),this.refitFrom(l,n)}refitFrom(e,t){let n=e;for(;n;){if(n.triangleCount===0&&n.leftChild&&n.rightChild){let e=n.leftChild,t=n.rightChild;n.minX=Math.min(e.minX,t.minX),n.minY=Math.min(e.minY,t.minY),n.minZ=Math.min(e.minZ,t.minZ),n.maxX=Math.max(e.maxX,t.maxX),n.maxY=Math.max(e.maxY,t.maxY),n.maxZ=Math.max(e.maxZ,t.maxZ)}let e=t.get(n);n=e?e.parent:null}}optimizeBVH(e,t){let n=performance.now();this.stats={reinsertionsApplied:0,iterations:0,timeMs:0};for(let r=0;r<this.maxIterations&&!(performance.now()-n>this.timeBudgetMs);r++){let i=this.buildParentMap(e),a=i.size,o=Math.max(1,Math.floor(a*this.batchSizeRatio));t&&t(`Reinsertion iter ${r+1}/${this.maxIterations}: selecting ${o} candidates`);let s=this.findCandidates(e,o,i),c=[];for(let t=0;t<s.length&&!(performance.now()-n>this.timeBudgetMs);t++){let n=this.findReinsertion(s[t].node,e,i);n&&n.areaDiff>0&&c.push(n)}c.sort((e,t)=>t.areaDiff-e.areaDiff);let l=new Set,u=0;for(let e of c){let t=this.getConflicts(e.from,e.to,i);if(!t.some(e=>l.has(e))){for(let e of t)l.add(e);this.reinsertNode(e.from,e.to,i),u++}}if(this.stats.reinsertionsApplied+=u,this.stats.iterations=r+1,t&&t(`Reinsertion iter ${r+1}: applied ${u} reinsertions`),u===0)break}return this.stats.timeMs=performance.now()-n,this.stats}},ga=``+(typeof document>`u`&&typeof location>`u`?require(`url`).pathToFileURL(__dirname+`/assets/BVHWorker-CNJ0UBQz.js`).href:new URL(`assets/BVHWorker-CNJ0UBQz.js`,typeof document>`u`?location.href:document.currentScript&&document.currentScript.tagName.toUpperCase()===`SCRIPT`&&document.currentScript.src||document.baseURI).href),_a={FLOATS_PER_TRIANGLE:32,POSITION_A_OFFSET:0,POSITION_B_OFFSET:4,POSITION_C_OFFSET:8,NORMAL_A_OFFSET:12,NORMAL_B_OFFSET:16,NORMAL_C_OFFSET:20,UV_AB_OFFSET:24,UV_C_MAT_OFFSET:28},va=_a.FLOATS_PER_TRIANGLE,ya=class{constructor(){this.minX=0,this.minY=0,this.minZ=0,this.maxX=0,this.maxY=0,this.maxZ=0,this.leftChild=null,this.rightChild=null,this.triangleOffset=0,this.triangleCount=0}},ba=class{constructor(){this.useWorker=!0,this.maxLeafSize=8,this.numBins=32,this.minBins=8,this.maxBins=64,this.totalNodes=0,this.processedTriangles=0,this.totalTriangles=0,this.lastProgressUpdate=0,this.progressUpdateInterval=100,this.traversalCost=1,this.intersectionCost=2.5,this.useMortonCodes=!0,this.mortonBits=10,this.mortonClusterThreshold=128,this.enableObjectMedianFallback=!0,this.enableSpatialMedianFallback=!0,this.splitStats={sahSplits:0,objectMedianSplits:0,spatialMedianSplits:0,failedSplits:0,avgBinsUsed:0,totalSplitAttempts:0,mortonSortTime:0,totalBuildTime:0,treeletOptimizationTime:0,treeletsProcessed:0,treeletsImproved:0,averageSAHImprovement:0,reinsertionOptimizationTime:0,reinsertionsApplied:0,reinsertionIterations:0},this.enableTreeletOptimization=!0,this.treeletSize=5,this.treeletOptimizationPasses=1,this.treeletMinImprovement=.02,this.maxTreeletDepth=3,this.maxTreeletsPerScene=20,this.treeletComplexityThreshold=5e4,this.enableReinsertionOptimization=!0,this.reinsertionBatchSizeRatio=.02,this.reinsertionMaxIterations=2,this.initializeBinArrays(),this._partResult={mid:0,lMinX:0,lMinY:0,lMinZ:0,lMaxX:0,lMaxY:0,lMaxZ:0,rMinX:0,rMinY:0,rMinZ:0,rMaxX:0,rMaxY:0,rMaxZ:0},this.centroids=null,this.bMin=null,this.bMax=null,this.indices=null,this.mortonCodes=null,this.triangles=null,this.reorderedTriangleData=null}initializeBinArrays(){let e=this.maxBins;this.binBoundsMin=new Float32Array(e*3),this.binBoundsMax=new Float32Array(e*3),this.binCounts=new Uint32Array(e),this.leftPrefixMin=new Float32Array(e*3),this.leftPrefixMax=new Float32Array(e*3),this.leftPrefixCount=new Uint32Array(e),this.rightPrefixMin=new Float32Array(e*3),this.rightPrefixMax=new Float32Array(e*3),this.rightPrefixCount=new Uint32Array(e)}getOptimalBinCount(e){return e<=16?this.minBins:e<=64?16:e<=256?32:e<=1024?48:this.maxBins}setAdaptiveBinConfig(e){e.minBins!==void 0&&(this.minBins=Math.max(4,e.minBins)),e.maxBins!==void 0&&(this.maxBins=Math.min(128,e.maxBins)),e.baseBins!==void 0&&(this.numBins=e.baseBins),e.maxBins!==void 0&&this.initializeBinArrays()}setMortonConfig(e){e.enabled!==void 0&&(this.useMortonCodes=e.enabled),e.bits!==void 0&&(this.mortonBits=Math.max(6,Math.min(10,e.bits))),e.threshold!==void 0&&(this.mortonClusterThreshold=Math.max(16,e.threshold))}setFallbackConfig(e){e.objectMedian!==void 0&&(this.enableObjectMedianFallback=e.objectMedian),e.spatialMedian!==void 0&&(this.enableSpatialMedianFallback=e.spatialMedian)}setTreeletConfig(e){e.enabled!==void 0&&(this.enableTreeletOptimization=e.enabled),e.size!==void 0&&(this.treeletSize=Math.max(3,Math.min(12,e.size))),e.passes!==void 0&&(this.treeletOptimizationPasses=Math.max(1,Math.min(3,e.passes))),e.minImprovement!==void 0&&(this.treeletMinImprovement=Math.max(.001,e.minImprovement))}disableTreeletOptimization(){this.enableTreeletOptimization=!1}setReinsertionConfig(e){e.enabled!==void 0&&(this.enableReinsertionOptimization=e.enabled),e.batchSizeRatio!==void 0&&(this.reinsertionBatchSizeRatio=Math.max(.005,Math.min(.1,e.batchSizeRatio))),e.maxIterations!==void 0&&(this.reinsertionMaxIterations=Math.max(1,Math.min(5,e.maxIterations)))}initializeTriangleArrays(){let e=this.totalTriangles,t=this.triangles,n=_a.POSITION_A_OFFSET,r=_a.POSITION_B_OFFSET,i=_a.POSITION_C_OFFSET;for(let a=0;a<e;a++){let e=a*va,o=t[e+n],s=t[e+n+1],c=t[e+n+2],l=t[e+r],u=t[e+r+1],d=t[e+r+2],f=t[e+i],p=t[e+i+1],m=t[e+i+2],h=a*3;this.centroids[h]=(o+l+f)/3,this.centroids[h+1]=(s+u+p)/3,this.centroids[h+2]=(c+d+m)/3,this.bMin[h]=o<l?o<f?o:f:l<f?l:f,this.bMin[h+1]=s<u?s<p?s:p:u<p?u:p,this.bMin[h+2]=c<d?c<m?c:m:d<m?d:m,this.bMax[h]=o>l?o>f?o:f:l>f?l:f,this.bMax[h+1]=s>u?s>p?s:p:u>p?u:p,this.bMax[h+2]=c>d?c>m?c:m:d>m?d:m,this.indices[a]=a}}expandBits(e){return e=e*65537&4278190335,e=e*257&251719695,e=e*17&3272356035,e=e*5&1227133513,e}morton3D(e,t,n){return(this.expandBits(n)<<2)+(this.expandBits(t)<<1)+this.expandBits(e)}computeMortonCodeForIndex(e,t,n,r,i,a,o){let s=this.centroids,c=e*3,l=(1<<this.mortonBits)-1,u=i>0?(s[c]-t)/i:0,d=a>0?(s[c+1]-n)/a:0,f=o>0?(s[c+2]-r)/o:0,p=Math.max(0,Math.min(l,Math.floor(u*l))),m=Math.max(0,Math.min(l,Math.floor(d*l))),h=Math.max(0,Math.min(l,Math.floor(f*l)));return this.morton3D(p,m,h)}sortTrianglesByMortonCode(){let e=this.totalTriangles;if(!this.useMortonCodes||e<this.mortonClusterThreshold)return;let t=performance.now(),n=this.centroids,r=this.indices,i=1/0,a=1/0,o=1/0,s=-1/0,c=-1/0,l=-1/0;for(let t=0;t<e;t++){let e=r[t]*3,u=n[e],d=n[e+1],f=n[e+2];u<i&&(i=u),d<a&&(a=d),f<o&&(o=f),u>s&&(s=u),d>c&&(c=d),f>l&&(l=f)}let u=s-i,d=c-a,f=l-o,p=this.mortonCodes,m=(1<<this.mortonBits)-1,h=u>0?m/u:0,g=d>0?m/d:0,_=f>0?m/f:0;for(let t=0;t<e;t++){let e=r[t],s=e*3,c=(n[s]-i)*h,l=(n[s+1]-a)*g,u=(n[s+2]-o)*_;c=c<0?0:(c>m?m:c)|0,l=l<0?0:(l>m?m:l)|0,u=u<0?0:(u>m?m:u)|0,c=c*65537&4278190335,c=c*257&251719695,c=c*17&3272356035,c=c*5&1227133513,l=l*65537&4278190335,l=l*257&251719695,l=l*17&3272356035,l=l*5&1227133513,u=u*65537&4278190335,u=u*257&251719695,u=u*17&3272356035,u=u*5&1227133513,p[e]=(u<<2)+(l<<1)+c}let v=new Uint32Array(e),y=new Uint32Array(256);for(let t=0;t<32;t+=8){y.fill(0);for(let n=0;n<e;n++)y[p[r[n]]>>>t&255]++;let n=0;for(let e=0;e<256;e++){let t=y[e];y[e]=n,n+=t}for(let n=0;n<e;n++){let e=p[r[n]]>>>t&255;v[y[e]++]=r[n]}r.set(v)}this.splitStats.mortonSortTime+=performance.now()-t}build(e,t=30,n=null){return this.totalTriangles=e.byteLength/(va*4),this.processedTriangles=0,this.lastProgressUpdate=performance.now(),this.useWorker&&typeof Worker<`u`?new Promise((r,i)=>{let a=a=>{let o=this.totalTriangles,s=typeof SharedArrayBuffer<`u`;console.log(`[BVHBuilder] SharedArrayBuffer: ${s?`enabled`:`unavailable (using transfer fallback)`}`);let c=s?new SharedArrayBuffer(o*va*4):null;a.onmessage=e=>{let{bvhData:t,triangles:o,originalToBvh:s,error:l,progress:u,treeletStats:d}=e.data;if(l){a.terminate(),i(Error(l));return}if(u!==void 0&&n){n(u);return}d&&(this.splitStats=d),a.terminate(),r({bvhData:t,bvhRoot:!0,reorderedTriangles:c?new Float32Array(c):o,originalToBvh:s||null})},a.onerror=e=>{a.terminate(),i(e)};let l=e.buffer,u={triangleData:l,triangleByteOffset:e.byteOffset,triangleByteLength:e.byteLength,triangleCount:o,depth:t,reportProgress:!!n,sharedReorderBuffer:c,treeletOptimization:{enabled:this.enableTreeletOptimization,size:this.treeletSize,passes:this.treeletOptimizationPasses,minImprovement:this.treeletMinImprovement},reinsertionOptimization:{enabled:this.enableReinsertionOptimization,batchSizeRatio:this.reinsertionBatchSizeRatio,maxIterations:this.reinsertionMaxIterations}};a.postMessage(u,[l])};try{a(new Worker(ga,{type:`module`}))}catch(i){i.name===`SecurityError`?Ze(ga).then(a).catch(()=>{console.warn(`Worker fetch fallback failed, using synchronous build`),r(this._buildSyncAndFlatten(e,t,n))}):(console.warn(`Worker creation failed, falling back to synchronous build:`,i),r(this._buildSyncAndFlatten(e,t,n)))}}):new Promise(r=>{r(this._buildSyncAndFlatten(e,t,n))})}_buildSyncAndFlatten(e,t,n){let r=this.buildSync(e,t,n);return{bvhData:this.flattenBVH(r),bvhRoot:!0,reorderedTriangles:this.reorderedTriangleData||null,originalToBvh:this.originalToBvhMap||null}}buildSync(e,t=30,n=null,r=null){let i=performance.now();this.totalNodes=0,this.processedTriangles=0,this.triangles=e,this.totalTriangles=e.byteLength/(va*4),this.lastProgressUpdate=performance.now(),this.splitStats={sahSplits:0,objectMedianSplits:0,spatialMedianSplits:0,failedSplits:0,avgBinsUsed:0,totalSplitAttempts:0,mortonSortTime:0,totalBuildTime:0,treeletOptimizationTime:0,treeletsProcessed:0,treeletsImproved:0,averageSAHImprovement:0,reinsertionOptimizationTime:0,reinsertionsApplied:0,reinsertionIterations:0,saOrderTime:0,initTime:0,sahBuildTime:0,reorderTime:0};let a=this.totalTriangles,o=performance.now();this.centroids=new Float32Array(a*3),this.bMin=new Float32Array(a*3),this.bMax=new Float32Array(a*3),this.indices=new Uint32Array(a),this.mortonCodes=new Uint32Array(a),this.initializeTriangleArrays(),this.splitStats.initTime=performance.now()-o,this.sortTrianglesByMortonCode();let s=performance.now(),c=this.buildNodeRecursive(0,a,t,n);if(this.splitStats.sahBuildTime=performance.now()-s,this.enableTreeletOptimization&&this.totalTriangles>1e3){let e=this.totalTriangles>this.treeletComplexityThreshold,t=e?3:this.treeletSize,r=e?10:this.maxTreeletsPerScene,i=new pa(this.traversalCost,this.intersectionCost);i.setTreeletSize(t),i.setMinImprovement(this.treeletMinImprovement),i.setMaxTreelets(r);let a=performance.now();for(let e=0;e<this.treeletOptimizationPasses;e++){let t=n?t=>{n(`Treelet optimization pass ${e+1}/${this.treeletOptimizationPasses}: ${t}`)}:null;try{i.optimizeBVH(c,t)}catch(t){console.error(`TreeletOptimizer: Error in pass ${e+1}:`,t);break}let r=i.getStatistics(),o=performance.now()-a;if(r.treeletsImproved===0&&e>0||o>15e3)break}let o=performance.now()-a;this.splitStats.treeletOptimizationTime=o;let s=i.getStatistics();this.splitStats.treeletsProcessed=s.treeletsProcessed,this.splitStats.treeletsImproved=s.treeletsImproved,this.splitStats.averageSAHImprovement=s.averageSAHImprovement}if(this.enableReinsertionOptimization&&this.totalTriangles>1e3){let e=new ha(this.traversalCost,this.intersectionCost);e.setBatchSizeRatio(this.reinsertionBatchSizeRatio),e.setMaxIterations(this.reinsertionMaxIterations);let t=n?e=>{n(e)}:null;try{e.optimizeBVH(c,t)}catch(e){console.error(`ReinsertionOptimizer: Error:`,e)}let r=e.getStatistics();this.splitStats.reinsertionOptimizationTime=r.timeMs,this.splitStats.reinsertionsApplied=r.reinsertionsApplied,this.splitStats.reinsertionIterations=r.iterations}let l=performance.now();this.applySAOrdering(c),this.splitStats.saOrderTime=performance.now()-l;let u=performance.now(),d=this.triangles,f=r||new Float32Array(a*va);for(let e=0;e<a;e++){let t=this.indices[e]*va,n=e*va;f.set(d.subarray(t,t+va),n)}this.reorderedTriangleData=f;let p=new Uint32Array(a);for(let e=0;e<a;e++)p[this.indices[e]]=e;this.originalToBvhMap=p,this.splitStats.reorderTime=performance.now()-u,this.splitStats.totalBuildTime=performance.now()-i;let m=this.splitStats.totalBuildTime,h=this.splitStats;return console.log(`[BVH] ${a.toLocaleString()} tris → ${this.totalNodes} nodes in ${Math.round(m)}ms | SAH ${h.sahSplits} objMed ${h.objectMedianSplits} spatMed ${h.spatialMedianSplits} failed ${h.failedSplits}`+(h.treeletsProcessed?` | treelets ${h.treeletsImproved}/${h.treeletsProcessed} improved`:``)+(h.reinsertionsApplied?` | reinsertions ${h.reinsertionsApplied}`:``)),n&&n(100),this.centroids=null,this.bMin=null,this.bMax=null,this.mortonCodes=null,c}updateProgress(e,t){if(!t)return;this.processedTriangles+=e;let n=performance.now();n-this.lastProgressUpdate<this.progressUpdateInterval||(this.lastProgressUpdate=n,t(Math.min(Math.floor(this.processedTriangles/this.totalTriangles*100),99)))}buildNodeRecursiveToDepth(e,t,n,r,i,a,o,s,c,l,u){let d=new ya;this.totalNodes++;let f=t-e;if(a===void 0?this.updateNodeBounds(d,e,t):(d.minX=a,d.minY=o,d.minZ=s,d.maxX=c,d.maxY=l,d.maxZ=u),f<=this.maxLeafSize||n<=0)return d.triangleOffset=e,d.triangleCount=f,this.updateProgress(f,i),d;if(r<=0&&f>this.maxLeafSize*16){let r=this.frontierTasks.length;return d.triangleOffset=e,d.triangleCount=f,d.isFrontier=!0,d.frontierTaskId=r,this.frontierTasks.push({taskId:r,start:e,end:t,depth:n,preMinX:d.minX,preMinY:d.minY,preMinZ:d.minZ,preMaxX:d.maxX,preMaxY:d.maxY,preMaxZ:d.maxZ}),d}let p=this.findBestSplitPositionSAH(e,t,d);if(!p.success){if(this.splitStats.failedSplits++,r>0||f<=this.maxLeafSize*16)return d.triangleOffset=e,d.triangleCount=f,this.updateProgress(f,i),d;let a=this.frontierTasks.length;return d.triangleOffset=e,d.triangleCount=f,d.isFrontier=!0,d.frontierTaskId=a,this.frontierTasks.push({taskId:a,start:e,end:t,depth:n,preMinX:d.minX,preMinY:d.minY,preMinZ:d.minZ,preMaxX:d.maxX,preMaxY:d.maxY,preMaxZ:d.maxZ}),d}p.method===`SAH`?this.splitStats.sahSplits++:p.method===`object_median`?this.splitStats.objectMedianSplits++:p.method===`spatial_median`&&this.splitStats.spatialMedianSplits++,this.partitionWithBounds(e,t,p.axis,p.pos);let m=this._partResult,h=m.mid,g=m.lMinX,_=m.lMinY,v=m.lMinZ,y=m.lMaxX,b=m.lMaxY,x=m.lMaxZ,S=m.rMinX,C=m.rMinY,w=m.rMinZ,T=m.rMaxX,E=m.rMaxY,D=m.rMaxZ;return h===e||h===t?(d.triangleOffset=e,d.triangleCount=f,this.updateProgress(f,i),d):(d.leftChild=this.buildNodeRecursiveToDepth(e,h,n-1,r-1,i,g,_,v,y,b,x),d.rightChild=this.buildNodeRecursiveToDepth(h,t,n-1,r-1,i,S,C,w,T,E,D),d)}buildNodeRecursive(e,t,n,r,i,a,o,s,c,l){let u=new ya;this.totalNodes++;let d=t-e;if(i===void 0?this.updateNodeBounds(u,e,t):(u.minX=i,u.minY=a,u.minZ=o,u.maxX=s,u.maxY=c,u.maxZ=l),d<=this.maxLeafSize||n<=0)return u.triangleOffset=e,u.triangleCount=d,this.updateProgress(d,r),u;let f=this.findBestSplitPositionSAH(e,t,u);if(!f.success)return this.splitStats.failedSplits++,u.triangleOffset=e,u.triangleCount=d,this.updateProgress(d,r),u;f.method===`SAH`?this.splitStats.sahSplits++:f.method===`object_median`?this.splitStats.objectMedianSplits++:f.method===`spatial_median`&&this.splitStats.spatialMedianSplits++,this.partitionWithBounds(e,t,f.axis,f.pos);let p=this._partResult,m=p.mid,h=p.lMinX,g=p.lMinY,_=p.lMinZ,v=p.lMaxX,y=p.lMaxY,b=p.lMaxZ,x=p.rMinX,S=p.rMinY,C=p.rMinZ,w=p.rMaxX,T=p.rMaxY,E=p.rMaxZ;return m===e||m===t?(u.triangleOffset=e,u.triangleCount=d,this.updateProgress(d,r),u):(u.leftChild=this.buildNodeRecursive(e,m,n-1,r,h,g,_,v,y,b),u.rightChild=this.buildNodeRecursive(m,t,n-1,r,x,S,C,w,T,E),u)}partitionWithBounds(e,t,n,r){let i=this.indices,a=this.centroids,o=this.bMin,s=this.bMax,c=e,l=t-1,u=1/0,d=1/0,f=1/0,p=-1/0,m=-1/0,h=-1/0,g=1/0,_=1/0,v=1/0,y=-1/0,b=-1/0,x=-1/0;for(;c<=l;){let e=i[c],t=e*3;a[t+n]<=r?(o[t]<u&&(u=o[t]),o[t+1]<d&&(d=o[t+1]),o[t+2]<f&&(f=o[t+2]),s[t]>p&&(p=s[t]),s[t+1]>m&&(m=s[t+1]),s[t+2]>h&&(h=s[t+2]),c++):(o[t]<g&&(g=o[t]),o[t+1]<_&&(_=o[t+1]),o[t+2]<v&&(v=o[t+2]),s[t]>y&&(y=s[t]),s[t+1]>b&&(b=s[t+1]),s[t+2]>x&&(x=s[t+2]),i[c]=i[l],i[l]=e,l--)}let S=this._partResult;return S.mid=c,S.lMinX=u,S.lMinY=d,S.lMinZ=f,S.lMaxX=p,S.lMaxY=m,S.lMaxZ=h,S.rMinX=g,S.rMinY=_,S.rMinZ=v,S.rMaxX=y,S.rMaxY=b,S.rMaxZ=x,S}updateNodeBounds(e,t,n){let r=1/0,i=1/0,a=1/0,o=-1/0,s=-1/0,c=-1/0,l=this.indices,u=this.bMin,d=this.bMax;for(let e=t;e<n;e++){let t=l[e]*3;u[t]<r&&(r=u[t]),u[t+1]<i&&(i=u[t+1]),u[t+2]<a&&(a=u[t+2]),d[t]>o&&(o=d[t]),d[t+1]>s&&(s=d[t+1]),d[t+2]>c&&(c=d[t+2])}e.minX=r,e.minY=i,e.minZ=a,e.maxX=o,e.maxY=s,e.maxZ=c}findBestSplitPositionSAH(e,t,n){let r=1/0,i=-1,a=0,o=this.computeSurfaceAreaFlat(n.minX,n.minY,n.minZ,n.maxX,n.maxY,n.maxZ),s=t-e,c=this.intersectionCost*s,l=this.getOptimalBinCount(s);this.splitStats.totalSplitAttempts++,this.splitStats.avgBinsUsed=(this.splitStats.avgBinsUsed*(this.splitStats.totalSplitAttempts-1)+l)/this.splitStats.totalSplitAttempts;let u=this.indices,d=this.centroids,f=this.bMin,p=this.bMax,m=this.binBoundsMin,h=this.binBoundsMax,g=this.binCounts,_=this.leftPrefixMin,v=this.leftPrefixMax,y=this.leftPrefixCount,b=this.rightPrefixMin,x=this.rightPrefixMax,S=this.rightPrefixCount,C=1/0,w=-1/0,T=1/0,E=-1/0,D=1/0,O=-1/0;for(let n=e;n<t;n++){let e=u[n]*3,t=d[e],r=d[e+1],i=d[e+2];t<C&&(C=t),t>w&&(w=t),r<T&&(T=r),r>E&&(E=r),i<D&&(D=i),i>O&&(O=i)}let k=[C,T,D],A=[w,E,O];for(let n=0;n<3;n++){let s=k[n],C=A[n];if(C-s<1e-6)continue;for(let e=0;e<l;e++){g[e]=0;let t=e*3;m[t]=1/0,m[t+1]=1/0,m[t+2]=1/0,h[t]=-1/0,h[t+1]=-1/0,h[t+2]=-1/0}let w=l/(C-s);for(let r=e;r<t;r++){let e=u[r],t=d[e*3+n],i=Math.floor((t-s)*w);i>=l&&(i=l-1),g[i]++;let a=i*3,o=e*3;f[o]<m[a]&&(m[a]=f[o]),f[o+1]<m[a+1]&&(m[a+1]=f[o+1]),f[o+2]<m[a+2]&&(m[a+2]=f[o+2]),p[o]>h[a]&&(h[a]=p[o]),p[o+1]>h[a+1]&&(h[a+1]=p[o+1]),p[o+2]>h[a+2]&&(h[a+2]=p[o+2])}y[0]=g[0],_[0]=m[0],_[1]=m[1],_[2]=m[2],v[0]=h[0],v[1]=h[1],v[2]=h[2];for(let e=1;e<l;e++){let t=e*3,n=(e-1)*3;y[e]=y[e-1]+g[e];let r=_[n],i=m[t],a=_[n+1],o=m[t+1],s=_[n+2],c=m[t+2];_[t]=r<i?r:i,_[t+1]=a<o?a:o,_[t+2]=s<c?s:c;let l=v[n],u=h[t],d=v[n+1],f=h[t+1],p=v[n+2],b=h[t+2];v[t]=l>u?l:u,v[t+1]=d>f?d:f,v[t+2]=p>b?p:b}let T=l-1,E=T*3;S[T]=g[T],b[E]=m[E],b[E+1]=m[E+1],b[E+2]=m[E+2],x[E]=h[E],x[E+1]=h[E+1],x[E+2]=h[E+2];for(let e=T-1;e>=0;e--){let t=e*3,n=(e+1)*3;S[e]=S[e+1]+g[e];let r=b[n],i=m[t],a=b[n+1],o=m[t+1],s=b[n+2],c=m[t+2];b[t]=r<i?r:i,b[t+1]=a<o?a:o,b[t+2]=s<c?s:c;let l=x[n],u=h[t],d=x[n+1],f=h[t+1],p=x[n+2],_=h[t+2];x[t]=l>u?l:u,x[t+1]=d>f?d:f,x[t+2]=p>_?p:_}for(let e=1;e<l;e++){let t=(e-1)*3,u=e*3,d=y[e-1],f=S[e];if(d===0||f===0)continue;let p=v[t]-_[t],m=v[t+1]-_[t+1],h=v[t+2]-_[t+2],g=2*(p*m+m*h+h*p),w=x[u]-b[u],T=x[u+1]-b[u+1],E=x[u+2]-b[u+2],D=2*(w*T+T*E+E*w),O=this.traversalCost+g/o*d*this.intersectionCost+D/o*f*this.intersectionCost;O<r&&O<c&&(r=O,i=n,a=s+(C-s)*e/l)}}return i===-1?this.enableObjectMedianFallback?this.findObjectMedianSplit(e,t):this.enableSpatialMedianFallback?this.findSpatialMedianSplit(e,t):{success:!1,method:`fallbacks_disabled`}:{success:!0,axis:i,pos:a,method:`SAH`,binsUsed:l}}findObjectMedianSplit(e,t){let n=this.indices,r=this.centroids,i=-1,a=-1;for(let o=0;o<3;o++){let s=1/0,c=-1/0;for(let i=e;i<t;i++){let e=r[n[i]*3+o];e<s&&(s=e),e>c&&(c=e)}let l=c-s;l>a&&(a=l,i=o)}if(i===-1||a<1e-10)return this.enableSpatialMedianFallback?this.findSpatialMedianSplit(e,t):{success:!1,method:`object_median_failed`};let o=t-e,s=e+Math.floor(o/2);this.quickselect(e,t,s,i);let c=r[n[s]*3+i],l=!0;for(let e=s+1;e<t;e++)if(r[n[e]*3+i]>c){l=!1;break}if(l){let a=-1/0;for(let t=e;t<s;t++){let e=r[n[t]*3+i];e>a&&(a=e)}if(a<c)c=(a+c)*.5;else return this.enableSpatialMedianFallback?this.findSpatialMedianSplit(e,t):{success:!1,method:`object_median_degenerate`}}return{success:!0,axis:i,pos:c,method:`object_median`}}findSpatialMedianSplit(e,t){let n=this.indices,r=this.centroids,i=this.bMin,a=this.bMax,o=-1,s=-1,c=0,l=0;for(let r=0;r<3;r++){let u=1/0,d=-1/0;for(let o=e;o<t;o++){let e=n[o]*3+r;i[e]<u&&(u=i[e]),a[e]>d&&(d=a[e])}let f=d-u;f>s&&(s=f,o=r,c=u,l=d)}if(o===-1||s<1e-12)return{success:!1,method:`spatial_median_failed`};let u=(c+l)*.5,d=t-e,f=0;for(let i=e;i<t;i++)r[n[i]*3+o]<=u&&f++;if(f===0||f===d){let i=e+Math.floor(d/2);this.quickselect(e,t,i,o);let a=r[n[i]*3+o],s=!0;for(let i=e;i<t;i++)if(r[n[i]*3+o]!==a){s=!1;break}if(s)return{success:!1,method:`spatial_median_degenerate`};let c=-1/0;for(let t=e;t<i;t++){let e=r[n[t]*3+o];e>c&&(c=e)}if(c<a)u=(c+a)*.5;else{let e=1/0;for(let a=i+1;a<t;a++){let t=r[n[a]*3+o];t<e&&(e=t)}u=(a+e)*.5}}return{success:!0,axis:o,pos:u,method:`spatial_median`}}quickselect(e,t,n,r){let i=this.indices,a=this.centroids,o=e,s=t-1;for(;o<s;){let e=o+s>>>1,t=a[i[o]*3+r],c=a[i[e]*3+r],l=a[i[s]*3+r];if(t>c){let t=i[o];i[o]=i[e],i[e]=t}if(t>l){let e=i[o];i[o]=i[s],i[s]=e}if(c>l){let t=i[e];i[e]=i[s],i[s]=t}let u=a[i[e]*3+r],d=o,f=s;for(;d<=f;){for(;a[i[d]*3+r]<u;)d++;for(;a[i[f]*3+r]>u;)f--;if(d<=f){let e=i[d];i[d]=i[f],i[f]=e,d++,f--}}f<n&&(o=d),d>n&&(s=f)}}applySAOrdering(e){if(!e||!e.leftChild)return;let t=[e],n=[];for(;t.length>0;){let e=t.pop();!e.leftChild||!e.rightChild||(n.push(e),t.push(e.leftChild),t.push(e.rightChild))}for(let e=n.length-1;e>=0;e--){let t=n[e],r=t.leftChild,i=t.rightChild,a=r.maxX-r.minX,o=r.maxY-r.minY,s=r.maxZ-r.minZ,c=i.maxX-i.minX,l=i.maxY-i.minY,u=i.maxZ-i.minZ;c*l+l*u+u*c>a*o+o*s+s*a&&(t.leftChild=i,t.rightChild=r)}}flattenBVH(e){let t=[],n=[e];for(;n.length>0;){let e=n.pop();e._flatIndex=t.length,t.push(e),e.rightChild&&n.push(e.rightChild),e.leftChild&&n.push(e.leftChild)}let r=new Float32Array(t.length*16);for(let e=0;e<t.length;e++){let n=t[e],i=e*16;if(n.leftChild){let e=n.leftChild,t=n.rightChild;r[i]=e.minX,r[i+1]=e.minY,r[i+2]=e.minZ,r[i+3]=e._flatIndex,r[i+4]=e.maxX,r[i+5]=e.maxY,r[i+6]=e.maxZ,r[i+7]=t._flatIndex,r[i+8]=t.minX,r[i+9]=t.minY,r[i+10]=t.minZ,r[i+12]=t.maxX,r[i+13]=t.maxY,r[i+14]=t.maxZ}else r[i]=n.triangleOffset,r[i+1]=n.triangleCount,r[i+3]=-1}return r}flattenBVHWithFrontier(e){let t=[],n=[e];for(;n.length>0;){let e=n.pop();e._flatIndex=t.length,t.push(e),e.rightChild&&n.push(e.rightChild),e.leftChild&&n.push(e.leftChild)}let r=new Float32Array(t.length*16),i=[];for(let e=0;e<t.length;e++){let n=t[e],a=e*16;if(n.leftChild){let e=n.leftChild,t=n.rightChild;r[a]=e.minX,r[a+1]=e.minY,r[a+2]=e.minZ,r[a+3]=e._flatIndex,r[a+4]=e.maxX,r[a+5]=e.maxY,r[a+6]=e.maxZ,r[a+7]=t._flatIndex,r[a+8]=t.minX,r[a+9]=t.minY,r[a+10]=t.minZ,r[a+12]=t.maxX,r[a+13]=t.maxY,r[a+14]=t.maxZ}else if(n.isFrontier){let t=n.frontierTaskId;r[a]=n.triangleOffset,r[a+1]=n.triangleCount,r[a+2]=t,r[a+3]=-2,i.push({taskId:t,flatIndex:e})}else r[a]=n.triangleOffset,r[a+1]=n.triangleCount,r[a+3]=-1}return{flatData:r,frontierMap:i,nodeCount:t.length}}assembleParallelBVH(e,t,n,r){let i=[...r].sort((e,t)=>e.taskId-t.taskId),a=t;for(let e=0;e<i.length;e++)a+=i[e].nodeCount;let o=new Float32Array(a*16);o.set(e);let s=new Map;for(let e of n)s.set(e.taskId,e.flatIndex);let c=t;for(let e=0;e<i.length;e++){let t=i[e],n=t.flatData,r=t.nodeCount,a=c*16;o.set(n,a);for(let e=0;e<r;e++){let t=a+e*16;o[t+3]!==-1&&(o[t+3]+=c,o[t+7]+=c)}let l=s.get(t.taskId);if(l!==void 0){let e=l*16,t=a;for(let n=0;n<16;n++)o[e+n]=o[t+n]}c+=r}return o}computeSurfaceAreaFlat(e,t,n,r,i,a){let o=r-e,s=i-t,c=a-n;return 2*(o*s+s*c+c*o)}},Z={FLOATS_PER_TRIANGLE:32,POSITION_A_OFFSET:0,POSITION_B_OFFSET:4,POSITION_C_OFFSET:8,NORMAL_A_OFFSET:12,NORMAL_B_OFFSET:16,NORMAL_C_OFFSET:20},xa=Z.FLOATS_PER_TRIANGLE,Sa=16,Ca=-1,wa=-2,Ta=class{constructor(){this._bounds=null,this._boundsNodeCount=0}updateTrianglePositions(e,t,n){let r=n.length;for(let i=0;i<r;i++){let r=n[i],a=i*xa,o=r*9,s=t[o],c=t[o+1],l=t[o+2],u=t[o+3],d=t[o+4],f=t[o+5],p=t[o+6],m=t[o+7],h=t[o+8];e[a+Z.POSITION_A_OFFSET]=s,e[a+Z.POSITION_A_OFFSET+1]=c,e[a+Z.POSITION_A_OFFSET+2]=l,e[a+Z.POSITION_B_OFFSET]=u,e[a+Z.POSITION_B_OFFSET+1]=d,e[a+Z.POSITION_B_OFFSET+2]=f,e[a+Z.POSITION_C_OFFSET]=p,e[a+Z.POSITION_C_OFFSET+1]=m,e[a+Z.POSITION_C_OFFSET+2]=h;let g=u-s,_=d-c,v=f-l,y=p-s,b=m-c,x=h-l,S=_*x-v*b,C=v*y-g*x,w=g*b-_*y;e[a+Z.NORMAL_A_OFFSET]=S,e[a+Z.NORMAL_A_OFFSET+1]=C,e[a+Z.NORMAL_A_OFFSET+2]=w,e[a+Z.NORMAL_B_OFFSET]=S,e[a+Z.NORMAL_B_OFFSET+1]=C,e[a+Z.NORMAL_B_OFFSET+2]=w,e[a+Z.NORMAL_C_OFFSET]=S,e[a+Z.NORMAL_C_OFFSET+1]=C,e[a+Z.NORMAL_C_OFFSET+2]=w}}refitRange(e,t,n,r){r>this._boundsNodeCount&&(this._bounds=new Float32Array(r*6),this._boundsNodeCount=r);let i=this._bounds,a=n+r;for(let r=a-1;r>=n;r--){let a=r*Sa,o=(r-n)*6;if(e[a+3]===Ca){let n=e[a],r=e[a+1],s=1/0,c=1/0,l=1/0,u=-1/0,d=-1/0,f=-1/0;for(let e=0;e<r;e++){let r=(n+e)*xa,i=t[r+Z.POSITION_A_OFFSET],a=t[r+Z.POSITION_A_OFFSET+1],o=t[r+Z.POSITION_A_OFFSET+2],p=t[r+Z.POSITION_B_OFFSET],m=t[r+Z.POSITION_B_OFFSET+1],h=t[r+Z.POSITION_B_OFFSET+2],g=t[r+Z.POSITION_C_OFFSET],_=t[r+Z.POSITION_C_OFFSET+1],v=t[r+Z.POSITION_C_OFFSET+2];s=Math.min(s,i,p,g),c=Math.min(c,a,m,_),l=Math.min(l,o,h,v),u=Math.max(u,i,p,g),d=Math.max(d,a,m,_),f=Math.max(f,o,h,v)}i[o]=s,i[o+1]=c,i[o+2]=l,i[o+3]=u,i[o+4]=d,i[o+5]=f}else{let t=e[a+3],r=e[a+7],s=(t-n)*6,c=(r-n)*6,l=i[s],u=i[s+1],d=i[s+2],f=i[s+3],p=i[s+4],m=i[s+5],h=i[c],g=i[c+1],_=i[c+2],v=i[c+3],y=i[c+4],b=i[c+5];e[a]=l,e[a+1]=u,e[a+2]=d,e[a+4]=f,e[a+5]=p,e[a+6]=m,e[a+8]=h,e[a+9]=g,e[a+10]=_,e[a+12]=v,e[a+13]=y,e[a+14]=b,i[o]=Math.min(l,h),i[o+1]=Math.min(u,g),i[o+2]=Math.min(d,_),i[o+3]=Math.max(f,v),i[o+4]=Math.max(p,y),i[o+5]=Math.max(m,b)}}}refit(e,t,n){n!==this._boundsNodeCount&&(this._bounds=new Float32Array(n*6),this._boundsNodeCount=n);let r=this._bounds;for(let i=n-1;i>=0;i--){let n=i*Sa,a=i*6,o=e[n+3];if(o===Ca){let i=e[n],o=e[n+1],s=1/0,c=1/0,l=1/0,u=-1/0,d=-1/0,f=-1/0;for(let e=0;e<o;e++){let n=(i+e)*xa,r=t[n+Z.POSITION_A_OFFSET],a=t[n+Z.POSITION_A_OFFSET+1],o=t[n+Z.POSITION_A_OFFSET+2],p=t[n+Z.POSITION_B_OFFSET],m=t[n+Z.POSITION_B_OFFSET+1],h=t[n+Z.POSITION_B_OFFSET+2],g=t[n+Z.POSITION_C_OFFSET],_=t[n+Z.POSITION_C_OFFSET+1],v=t[n+Z.POSITION_C_OFFSET+2];s=Math.min(s,r,p,g),c=Math.min(c,a,m,_),l=Math.min(l,o,h,v),u=Math.max(u,r,p,g),d=Math.max(d,a,m,_),f=Math.max(f,o,h,v)}r[a]=s,r[a+1]=c,r[a+2]=l,r[a+3]=u,r[a+4]=d,r[a+5]=f}else if(o===wa){let t=e[n]*6;r[a]=r[t],r[a+1]=r[t+1],r[a+2]=r[t+2],r[a+3]=r[t+3],r[a+4]=r[t+4],r[a+5]=r[t+5]}else{let t=e[n+3],i=e[n+7],o=t*6,s=i*6,c=r[o],l=r[o+1],u=r[o+2],d=r[o+3],f=r[o+4],p=r[o+5],m=r[s],h=r[s+1],g=r[s+2],_=r[s+3],v=r[s+4],y=r[s+5];e[n]=c,e[n+1]=l,e[n+2]=u,e[n+4]=d,e[n+5]=f,e[n+6]=p,e[n+8]=m,e[n+9]=h,e[n+10]=g,e[n+12]=_,e[n+13]=v,e[n+14]=y,r[a]=Math.min(c,m),r[a+1]=Math.min(l,h),r[a+2]=Math.min(u,g),r[a+3]=Math.max(d,_),r[a+4]=Math.max(f,v),r[a+5]=Math.max(p,y)}}}},Ea=``+(typeof document>`u`&&typeof location>`u`?require(`url`).pathToFileURL(__dirname+`/assets/BVHSubtreeWorker-D9GImjGj.js`).href:new URL(`assets/BVHSubtreeWorker-D9GImjGj.js`,typeof document>`u`?location.href:document.currentScript&&document.currentScript.tagName.toUpperCase()===`SCRIPT`&&document.currentScript.src||document.baseURI).href),Da=32,Oa=5e4,ka=8;function Aa(e,t,n,r){let i=e.byteLength/(Da*4),a=Math.min(navigator.hardwareConcurrency||4,ka),o=Math.ceil(Math.log2(a*2.5+1));return console.log(`[ParallelBVH] Parallel build: ${i.toLocaleString()} triangles, ${a} workers, parallelDepth=${o}`),new Promise((s,c)=>{(async()=>{let c=new SharedArrayBuffer(e.byteLength);new Float32Array(c).set(e);let l=new SharedArrayBuffer(i*3*4),u=new SharedArrayBuffer(i*3*4),d=new SharedArrayBuffer(i*3*4),f=new SharedArrayBuffer(i*4),p=new SharedArrayBuffer(i*4),m=new SharedArrayBuffer(i*Da*4),h;try{h=new Worker(ga,{type:`module`})}catch(e){if(e.name!==`SecurityError`)throw e;h=await Ze(ga)}let g=null,_=[h],v={id:null},y=!1,b=()=>{v.id&&=(clearTimeout(v.id),null);for(let e of _)try{e.terminate()}catch{}},x=e=>{if(y)return;y=!0,console.warn(`[ParallelBVH] Parallel build failed (${e}), falling back to single worker`),b();let i=new ArrayBuffer(c.byteLength);new Float32Array(i).set(new Float32Array(c)),s(Ma(new Float32Array(i),t,n,r))};h.onerror=e=>{x(`coordinator error: ${e.message}`)},h.onmessage=e=>{let t=e.data;if(t.error||t.type===`error`){x(t.error);return}if(t.type===`progress`&&n){n(Math.floor(t.progress*.3));return}if(t.type===`phase1Result`){g=t.splitStats,ja(t,a,c,l,u,d,f,m,i,n,h,_,b,x,s,v,r).catch(e=>x(e.message));return}if(t.type===`assembleResult`){y=!0,b();let e=new Float32Array(m);s({bvhData:t.bvhData,bvhRoot:!0,reorderedTriangles:e,originalToBvh:t.originalToBvh||null,splitStats:g||{}});return}},n&&n(0),h.postMessage({type:`buildPhase1`,sharedTriangleData:c,sharedCentroids:l,sharedBMin:u,sharedBMax:d,sharedIndices:f,sharedMortonCodes:p,triangleCount:i,depth:t,parallelDepth:o,reportProgress:!!n,treeletOptimization:r.treeletOptimization})})().catch(e=>{console.warn(`[ParallelBVH] Parallel build setup failed:`,e),c(e)})})}async function ja(e,t,n,r,i,a,o,s,c,l,u,d,f,p,m,h,g){let{topFlatData:_,topNodeCount:v,frontierTasks:y,frontierMap:b}=e;if(!y||y.length===0){console.log(`[ParallelBVH] No frontier tasks, assembling with top-level tree only`),u.postMessage({type:`assemble`,topFlatData:_,topNodeCount:v,frontierMap:[],subtreeResults:[],sharedTriangleData:n,sharedIndices:o,sharedReorderBuffer:s,triangleCount:c},[_.buffer]);return}console.log(`[ParallelBVH] Phase 2: distributing ${y.length} tasks across ${t} workers`);let x=[...y].sort((e,t)=>t.end-t.start-(e.end-e.start)),S=Array.from({length:Math.min(t,x.length)},()=>[]),C=Array(S.length).fill(0);for(let e of x){let t=0;for(let e=1;e<C.length;e++)C[e]<C[t]&&(t=e);S[t].push(e),C[t]+=e.end-e.start}let w=[],T=0,E=y.length,D=y.reduce((e,t)=>e+(t.end-t.start),0),O=0;h.id=setTimeout(()=>{p(`Phase 2 timeout (30s)`)},3e4);let k=()=>{clearTimeout(h.id),h.id=null,l&&l(85);let t=[];e.topFlatData&&e.topFlatData.buffer&&t.push(e.topFlatData.buffer);for(let e of w)e.flatData&&e.flatData.buffer&&t.push(e.flatData.buffer);u.postMessage({type:`assemble`,topFlatData:e.topFlatData,topNodeCount:v,frontierMap:b,subtreeResults:w,sharedTriangleData:n,sharedIndices:o,sharedReorderBuffer:s,triangleCount:c},t)},A=S.length;for(let e=0;e<A;e++){let t=S[e];if(t.length===0)continue;let s;try{s=new Worker(Ea,{type:`module`})}catch(e){if(e.name!==`SecurityError`)throw e;s=await Ze(Ea)}d.push(s),s.onerror=e=>{p(`subtree worker error: ${e.message}`)},s.onmessage=e=>{let t=e.data;if(t.type===`error`){p(`subtree task ${t.taskId} error: ${t.error}`);return}if(t.type===`progress`&&l){let e=30+Math.floor(O/D*55);l(Math.min(e,85));return}if(t.type===`subtreeResult`){w.push({taskId:t.taskId,flatData:t.flatData,nodeCount:t.nodeCount});let e=y.find(e=>e.taskId===t.taskId);if(e&&(O+=e.end-e.start),T++,l){let e=30+Math.floor(O/D*55);l(Math.min(e,85))}if(T===E){for(let e of d)if(e!==u)try{e.terminate()}catch{}k()}}},s.postMessage({tasks:t,sharedTriangleData:n,sharedCentroids:r,sharedBMin:i,sharedBMax:a,sharedIndices:o,triangleCount:c,maxLeafSize:g.maxLeafSize,numBins:g.numBins,maxBins:g.maxBins,minBins:g.minBins,treeletConfig:g.treeletOptimization,reinsertionConfig:g.reinsertionOptimization,reportProgress:!!l})}}function Ma(e,t,n,r){return new Promise((i,a)=>{(async()=>{let o;try{o=new Worker(ga,{type:`module`})}catch(e){if(e.name!==`SecurityError`)throw e;o=await Ze(ga)}let s=e.byteLength/(Da*4),c=typeof SharedArrayBuffer<`u`?new SharedArrayBuffer(s*Da*4):null;o.onmessage=e=>{let{bvhData:t,triangles:r,originalToBvh:s,error:l,progress:u,treeletStats:d}=e.data;if(l){o.terminate(),a(Error(l));return}if(u!==void 0&&n){n(u);return}o.terminate(),i({bvhData:t,bvhRoot:!0,reorderedTriangles:c?new Float32Array(c):r,originalToBvh:s||null,splitStats:d||{}})},o.onerror=e=>{o.terminate(),a(e)};let l=e.buffer;o.postMessage({triangleData:l,triangleByteOffset:e.byteOffset,triangleByteLength:e.byteLength,triangleCount:s,depth:t,reportProgress:!!n,sharedReorderBuffer:c,treeletOptimization:r.treeletOptimization,reinsertionOptimization:r.reinsertionOptimization},[l])})().catch(e=>{console.warn(`[ParallelBVH] Single worker fallback failed:`,e),a(e)})})}function Na(e){return typeof Worker<`u`&&typeof SharedArrayBuffer<`u`&&e>=Oa}var Pa=16,Fa=class{constructor(){this.minX=0,this.minY=0,this.minZ=0,this.maxX=0,this.maxY=0,this.maxZ=0,this.leftChild=null,this.rightChild=null,this.entryIndex=-1}},Ia=class{constructor(){this._flatBuffer=null,this._flatBufferCapacity=0}build(e){if(e.length===0)return{root:null,nodeCount:0};let t=[];for(let n=0;n<e.length;n++)t.push(n);let n=this._buildRecursive(e,t);return{root:n,nodeCount:this._countNodes(n)}}_buildRecursive(e,t){let n=new Fa;if(t.length===1){let r=e[t[0]].worldAABB;return n.minX=r.minX,n.minY=r.minY,n.minZ=r.minZ,n.maxX=r.maxX,n.maxY=r.maxY,n.maxZ=r.maxZ,n.entryIndex=t[0],n}let r=1/0,i=1/0,a=1/0,o=-1/0,s=-1/0,c=-1/0;for(let n of t){let t=e[n].worldAABB;t.minX<r&&(r=t.minX),t.minY<i&&(i=t.minY),t.minZ<a&&(a=t.minZ),t.maxX>o&&(o=t.maxX),t.maxY>s&&(s=t.maxY),t.maxZ>c&&(c=t.maxZ)}if(n.minX=r,n.minY=i,n.minZ=a,n.maxX=o,n.maxY=s,n.maxZ=c,t.length===2)return n.leftChild=this._buildRecursive(e,[t[0]]),n.rightChild=this._buildRecursive(e,[t[1]]),n;let l=this._surfaceArea(r,i,a,o,s,c),u=1/0,d=0,f=0;if(l>0&&isFinite(l))for(let n=0;n<3;n++){let r=t.slice().sort((t,r)=>{let i=e[t].worldAABB,a=e[r].worldAABB;return this._centroid(i,n)-this._centroid(a,n)});for(let t=1;t<r.length;t++){let i=this._computeGroupAABB(e,r,0,t),a=this._computeGroupAABB(e,r,t,r.length),o=this._surfaceArea(i.minX,i.minY,i.minZ,i.maxX,i.maxY,i.maxZ),s=this._surfaceArea(a.minX,a.minY,a.minZ,a.maxX,a.maxY,a.maxZ),c=1+(o*t+s*(r.length-t))/l;c<u&&(u=c,d=n,f=t)}}if(f<=0||f>=t.length){d=0;let e=o-r,n=s-i,l=c-a;n>e&&n>l?d=1:l>e&&(d=2),f=t.length>>1}let p=t.slice().sort((t,n)=>this._centroid(e[t].worldAABB,d)-this._centroid(e[n].worldAABB,d)),m=p.slice(0,f),h=p.slice(f);return n.leftChild=this._buildRecursive(e,m),n.rightChild=this._buildRecursive(e,h),n}flatten(e,t){if(!e)return new Float32Array;let n=[],r=[e];for(;r.length>0;){let e=r.pop();e._flatIndex=n.length,n.push(e),e.rightChild&&r.push(e.rightChild),e.leftChild&&r.push(e.leftChild)}let i=n.length*Pa;i>this._flatBufferCapacity&&(this._flatBuffer=new Float32Array(i),this._flatBufferCapacity=i);let a=this._flatBuffer;a.fill(0,0,i);for(let e=0;e<n.length;e++){let r=n[e],i=e*Pa;if(r.leftChild){let e=r.leftChild,t=r.rightChild;a[i]=e.minX,a[i+1]=e.minY,a[i+2]=e.minZ,a[i+3]=e._flatIndex,a[i+4]=e.maxX,a[i+5]=e.maxY,a[i+6]=e.maxZ,a[i+7]=t._flatIndex,a[i+8]=t.minX,a[i+9]=t.minY,a[i+10]=t.minZ,a[i+12]=t.maxX,a[i+13]=t.maxY,a[i+14]=t.maxZ}else{let n=t[r.entryIndex];a[i]=n.blasOffset,a[i+1]=r.entryIndex,a[i+2]=n.visible===!1?0:1,a[i+3]=H.BLAS_POINTER_LEAF,n.tlasLeafIndex=e}}return a.subarray(0,i)}_centroid(e,t){return t===0?(e.minX+e.maxX)*.5:t===1?(e.minY+e.maxY)*.5:(e.minZ+e.maxZ)*.5}_surfaceArea(e,t,n,r,i,a){let o=r-e,s=i-t,c=a-n;return 2*(o*s+s*c+c*o)}_computeGroupAABB(e,t,n,r){let i=1/0,a=1/0,o=1/0,s=-1/0,c=-1/0,l=-1/0;for(let u=n;u<r;u++){let n=e[t[u]].worldAABB;n.minX<i&&(i=n.minX),n.minY<a&&(a=n.minY),n.minZ<o&&(o=n.minZ),n.maxX>s&&(s=n.maxX),n.maxY>c&&(c=n.maxY),n.maxZ>l&&(l=n.maxZ)}return{minX:i,minY:a,minZ:o,maxX:s,maxY:c,maxZ:l}}_countNodes(e){if(!e)return 0;let t=0,n=[e];for(;n.length>0;){let e=n.pop();t++,e.leftChild&&n.push(e.leftChild),e.rightChild&&n.push(e.rightChild)}return t}},La=class{constructor(){this.entries=[],this.totalBLASNodes=0,this.tlasNodeCount=0}allocate(e){this.entries=Array(e).fill(null)}setEntry({meshIndex:e,blasNodeCount:t,triOffset:n,triCount:r,originalToBvhMap:i,bvhData:a}){this.entries[e]={meshIndex:e,blasOffset:0,blasNodeCount:t,triOffset:n,triCount:r,worldAABB:null,originalToBvhMap:i,bvhData:a,visible:!0,tlasLeafIndex:-1}}setVisibility(e,t){let n=this.entries[e];n&&(n.visible=t)}computeAABBs(e){for(let t of this.entries)t&&(t.worldAABB=this._readRootAABB(t.bvhData,t,e))}recomputeAABB(e,t,n){let r=this.entries[e],i=t.subarray(r.blasOffset*16,r.blasOffset*16+16);r.worldAABB=this._readRootAABB(i,r,n)}_readRootAABB(e,t,n){if(e[3]===-1)return this._computeAABBFromTriangles(t,n);let r=e[0],i=e[1],a=e[2],o=e[4],s=e[5],c=e[6],l=e[8],u=e[9],d=e[10],f=e[12],p=e[13],m=e[14];return{minX:Math.min(r,l),minY:Math.min(i,u),minZ:Math.min(a,d),maxX:Math.max(o,f),maxY:Math.max(s,p),maxZ:Math.max(c,m)}}_computeAABBFromTriangles(e,t){let n=B.FLOATS_PER_TRIANGLE,r=1/0,i=1/0,a=1/0,o=-1/0,s=-1/0,c=-1/0;for(let l=0;l<e.triCount;l++){let u=(e.triOffset+l)*n;for(let e=0;e<=8;e+=4){let n=t[u+e],l=t[u+e+1],d=t[u+e+2];n<r&&(r=n),l<i&&(i=l),d<a&&(a=d),n>o&&(o=n),l>s&&(s=l),d>c&&(c=d)}}return{minX:r,minY:i,minZ:a,maxX:o,maxY:s,maxZ:c}}assignOffsets(e){this.tlasNodeCount=e;let t=e;for(let e of this.entries)e&&(e.blasOffset=t,t+=e.blasNodeCount);this.totalBLASNodes=t-e}get totalNodeCount(){return this.tlasNodeCount+this.totalBLASNodes}get count(){return this.entries.length}clear(){this.entries=[],this.totalBLASNodes=0,this.tlasNodeCount=0}},Ra=``+(typeof document>`u`&&typeof location>`u`?require(`url`).pathToFileURL(__dirname+`/assets/TexturesWorker-DBqGmVdR.js`).href:new URL(`assets/TexturesWorker-DBqGmVdR.js`,typeof document>`u`?location.href:document.currentScript&&document.currentScript.tagName.toUpperCase()===`SCRIPT`&&document.currentScript.src||document.baseURI).href),za=class{constructor(){this.canvasContextPairs=[],this.maxPoolSize=U.CANVAS_POOL_SIZE}getCanvasWithContext(e,t,n=!1,r={}){let i={willReadFrequently:!0,alpha:!0,desynchronized:!0,...r},a=this.canvasContextPairs.pop();if(!a){let r;r=n&&typeof OffscreenCanvas<`u`?new OffscreenCanvas(e,t):document.createElement(`canvas`);let o=r.getContext(`2d`,i);a={canvas:r,context:o}}return a.canvas.width=e,a.canvas.height=t,a}releaseCanvasWithContext(e){this.canvasContextPairs.length<this.maxPoolSize&&(e.context.globalAlpha=1,e.context.globalCompositeOperation=`source-over`,e.context.imageSmoothingEnabled=!0,e.context.clearRect(0,0,e.canvas.width,e.canvas.height),e.canvas.width=1,e.canvas.height=1,this.canvasContextPairs.push(e))}getCanvas(e,t,n=!1){return this.getCanvasWithContext(e,t,n).canvas}getContext(e,t={}){let n=this.canvasContextPairs.find(t=>t.canvas===e);return n?n.context:e.getContext(`2d`,{willReadFrequently:!0,alpha:!0,desynchronized:!0,...t})}dispose(){this.canvasContextPairs=[]}},Ba=class{constructor(e={}){this.pools=new Map,this.memoryUsage=0,this.maxMemoryUsage=e.maxMemory||W.MAX_BUFFER_MEMORY,this.allocatedBuffers=new WeakMap,this.sizeStrategy=e.sizeStrategy||`adaptive`}getOptimalSize(e){switch(this.sizeStrategy){case`exact`:return e;case`power2`:return 2**Math.ceil(Math.log2(e));default:return e<1024?e:e<1024*1024?Math.ceil(e/1024)*1024:2**Math.ceil(Math.log2(e))}}getBuffer(e,t=Float32Array){let n=this.getOptimalSize(e),r=`${t.name}-${n}`,i=(this.pools.get(r)||[]).pop();if(!i)try{i=new t(n),this.memoryUsage+=i.byteLength,this.allocatedBuffers.set(i,!0)}catch{this.cleanup();try{i=new t(n),this.memoryUsage+=i.byteLength,this.allocatedBuffers.set(i,!0)}catch(e){let r=n*t.BYTES_PER_ELEMENT/(1024*1024),i=this.memoryUsage/(1024*1024);throw Error(`Buffer allocation failed: requested ${r.toFixed(1)}MB, current usage: ${i.toFixed(1)}MB, max: ${(this.maxMemoryUsage/(1024*1024)).toFixed(1)}MB. Original error: ${e.message}`)}}return this.memoryUsage>this.maxMemoryUsage*W.CLEANUP_THRESHOLD&&this.cleanup(),this.checkMemoryHealth(),i.byteOffset+e*t.BYTES_PER_ELEMENT>i.buffer.byteLength&&(i=new t(e),this.memoryUsage+=i.byteLength),new t(i.buffer,i.byteOffset,e)}releaseBuffer(e,t=Float32Array){let n=(e.buffer.byteLength-e.byteOffset)/t.BYTES_PER_ELEMENT,r=this.getOptimalSize(n),i=`${t.name}-${r}`,a=this.pools.get(i)||[];a.length<U.BUFFER_POOL_SIZE?(a.push(new t(e.buffer,e.byteOffset,n)),this.pools.set(i,a)):this.allocatedBuffers.has(e)&&(this.memoryUsage-=e.byteLength,this.allocatedBuffers.delete(e))}cleanup(){let e=Array.from(this.pools.entries());e.slice(0,Math.floor(e.length/2)).forEach(([e,t])=>{t.forEach(e=>{this.allocatedBuffers.has(e)&&(this.memoryUsage-=e.byteLength,this.allocatedBuffers.delete(e))}),this.pools.delete(e)})}dispose(){this.pools.forEach(e=>{e.forEach(e=>{this.allocatedBuffers.has(e)&&this.allocatedBuffers.delete(e)})}),this.pools.clear(),this.memoryUsage=0}getMemoryStats(){return{currentUsage:this.memoryUsage,maxUsage:this.maxMemoryUsage,utilizationPercentage:this.memoryUsage/this.maxMemoryUsage*100,poolCount:this.pools.size,allocatedBufferCount:this.allocatedBuffers&&this.allocatedBuffers.size||0}}checkMemoryHealth(){let e=this.getMemoryStats();return e.utilizationPercentage>90?(console.warn(`Memory pool critical: ${e.utilizationPercentage.toFixed(1)}% used (${(e.currentUsage/(1024*1024)).toFixed(1)}MB / ${(e.maxUsage/(1024*1024)).toFixed(1)}MB)`),`critical`):e.utilizationPercentage>70?(console.warn(`Memory pool high: ${e.utilizationPercentage.toFixed(1)}% used (${(e.currentUsage/(1024*1024)).toFixed(1)}MB / ${(e.maxUsage/(1024*1024)).toFixed(1)}MB)`),`high`):`normal`}},Va=class{constructor(e=U.CACHE_SIZE_LIMIT){this.cache=new Map,this.accessOrder=[],this.maxSize=e}generateHash(e){let t=``;for(let n of e)if(n?.image){let e=n.image.width||0,r=n.image.height||0,i=n.image.src||n.uuid||``;t+=`${e}x${r}_${i.slice(-8)}_`}return t+e.length}get(e){if(this.cache.has(e)){let t=this.accessOrder.indexOf(e);return t>-1&&this.accessOrder.splice(t,1),this.accessOrder.push(e),this.cache.get(e)}return null}set(e,t){if(this.cache.has(e)){let t=this.accessOrder.indexOf(e);t>-1&&this.accessOrder.splice(t,1)}else this.cache.size>=this.maxSize&&this.evictLRU();this.cache.set(e,t),this.accessOrder.push(e)}evictLRU(){if(this.accessOrder.length>0){let e=this.accessOrder.shift(),t=this.cache.get(e);t&&t.dispose&&t.dispose(),this.cache.delete(e)}}dispose(){this.cache.forEach(e=>{e&&e.dispose&&e.dispose()}),this.cache.clear(),this.accessOrder=[]}},Ha=class{constructor(e={}){this.useWorkers=typeof Worker<`u`,this.maxConcurrentWorkers=U.MAX_CONCURRENT_WORKERS,this.activeWorkers=0,this.canvasPool=new za,this.bufferPool=new Ba({maxMemory:e.maxBufferMemory||W.MAX_BUFFER_MEMORY,sizeStrategy:e.bufferSizeStrategy||`adaptive`}),this.textureCache=new Va,this.capabilities=this.detectCapabilities(),this.optimalMethod=this.selectOptimalMethod()}detectCapabilities(){return{offscreenCanvas:typeof OffscreenCanvas<`u`,imageBitmap:typeof createImageBitmap<`u`,workers:typeof Worker<`u`,hardwareConcurrency:navigator.hardwareConcurrency||4}}selectOptimalMethod(){return this.capabilities.workers&&this.capabilities.offscreenCanvas?`worker-offscreen`:this.capabilities.imageBitmap?`imageBitmap`:`canvas`}async createTexturesToDataTexture(e){if(!e||e.length===0)return null;let t=this.textureCache.generateHash(e),n=this.textureCache.get(t);if(n)return n;let{normalized:r,bitmapsToClose:i}=await this._normalizeTexturesForProcessing(e),a=this.selectProcessingStrategy(r),o;try{switch(a.method){case`worker-direct`:o=await this.processWithWorkerDirect(r);break;case`worker-chunked`:o=await this.processWithWorkerChunked(r,a.chunkSize);break;case`main-batch`:o=await this.processOnMainThreadBatch(r,a.batchSize);break;case`main-streaming`:o=await this.processOnMainThreadStreaming(r);break;default:o=await this.processOnMainThreadSync(r)}return o&&this.textureCache.set(t,o),o}catch(e){return console.warn(`Texture processing failed, trying fallback:`,e),await this.processOnMainThreadSync(r)}finally{for(let e of i)e.close()}}selectProcessingStrategy(e){let t=e.reduce((e,t)=>e+(t.image?.width||0)*(t.image?.height||0),0),n=t*4;return this.capabilities.workers&&n>W.MAX_TEXTURE_MEMORY?{method:`worker-chunked`,chunkSize:Math.max(1,Math.floor(e.length/4))}:this.capabilities.workers&&t>2097152?{method:`worker-direct`}:t>524288?{method:`main-batch`,batchSize:Math.min(4,e.length)}:e.length>8?{method:`main-streaming`}:{method:`main-sync`}}async processWithWorkerDirect(e){for(;this.activeWorkers>=this.maxConcurrentWorkers;)await new Promise(e=>setTimeout(e,10));this.activeWorkers++;try{let t;try{t=new Worker(Ra,{type:`module`})}catch(e){if(e.name!==`SecurityError`)throw e;t=await Ze(Ra)}let n=await this.prepareTexturesForWorkerDirect(e),r=await new Promise((e,r)=>{t.onmessage=t=>{t.data.error?r(Error(t.data.error)):e(t.data)},t.onerror=r;let i=[];n.forEach(e=>{e.data instanceof ArrayBuffer?i.push(e.data):e.bitmap&&i.push(e.bitmap)}),t.postMessage({textures:n,maxTextureSize:U.MAX_TEXTURE_SIZE,method:`direct-transfer`},i)});return t.terminate(),this.createDataArrayTextureFromResult(r)}finally{this.activeWorkers--}}async prepareTexturesForWorkerDirect(e){let t=[];for(let n of e)if(n?.image)try{if(typeof createImageBitmap<`u`&&n.image instanceof HTMLImageElement){let e=await createImageBitmap(n.image);t.push({bitmap:e,width:n.image.width,height:n.image.height,isDirect:!0})}else{let e=this.canvasPool.getCanvasWithContext(n.image.width,n.image.height);e.context.drawImage(n.image,0,0);let r=e.context.getImageData(0,0,n.image.width,n.image.height);t.push({data:r.data.buffer,width:n.image.width,height:n.image.height,isImageData:!0}),this.canvasPool.releaseCanvasWithContext(e)}}catch(e){console.warn(`Failed to prepare texture for worker:`,e)}return t}async processWithWorkerChunked(e,t){let n=[];for(let r=0;r<e.length;r+=t){let i=e.slice(r,r+t),a=await this.processWithWorkerDirect(i);n.push(a)}return this.combineTextureResults(n)}async processOnMainThreadBatch(e,t){let n=e.filter(e=>e?.image);if(n.length===0)return this.createFallbackTexture();let{maxWidth:r,maxHeight:i}=this.calculateOptimalDimensions(n),a=n.length,o=this.bufferPool.getBuffer(r*i*a*4,Uint8Array);for(let e=0;e<n.length;e+=t){let a=Math.min(e+t,n.length),s=[];for(let t=e;t<a;t++){let e=n[t],a=createImageBitmap(e.image,{resizeWidth:r,resizeHeight:i,resizeQuality:`high`});s.push(a.then(e=>({bitmap:e,index:t})))}let c=await Promise.all(s),l=this.canvasPool.getCanvasWithContext(r,i);l.context.imageSmoothingEnabled=!1;for(let{bitmap:e,index:t}of c){l.context.clearRect(0,0,r,i),l.context.drawImage(e,0,0);let n=l.context.getImageData(0,0,r,i),a=r*i*4*t;o.set(n.data,a),e.close()}this.canvasPool.releaseCanvasWithContext(l)}return this.createDataArrayTextureFromBuffer(o,r,i,a)}async processOnMainThreadStreaming(e){let t=e.filter(e=>e?.image);if(t.length===0)return this.createFallbackTexture();let{maxWidth:n,maxHeight:r}=this.calculateOptimalDimensions(t),i=t.length,a=this.bufferPool.getBuffer(n*r*i*4,Uint8Array),o=this.canvasPool.getCanvasWithContext(n,r);o.context.imageSmoothingEnabled=!0,o.context.imageSmoothingQuality=`high`;for(let e=0;e<t.length;e++){let i=t[e];o.context.clearRect(0,0,n,r),o.context.drawImage(i.image,0,0,n,r);let s=o.context.getImageData(0,0,n,r),c=n*r*4*e;a.set(s.data,c),e%W.STREAM_BATCH_SIZE===0&&await new Promise(e=>setTimeout(e,0))}return this.canvasPool.releaseCanvasWithContext(o),this.createDataArrayTextureFromBuffer(a,n,r,i)}async processOnMainThreadSync(e){let t=e.filter(e=>e?.image);if(t.length===0)return this.createFallbackTexture();let{maxWidth:n,maxHeight:r}=this.calculateOptimalDimensions(t),i=t.length,a=this.bufferPool.getBuffer(n*r*i*4,Uint8Array),o=this.canvasPool.getCanvasWithContext(n,r);o.context.imageSmoothingEnabled=!0,o.context.imageSmoothingQuality=`high`;for(let e=0;e<t.length;e++){let i=t[e];o.context.clearRect(0,0,n,r),o.context.drawImage(i.image,0,0,n,r);let s=o.context.getImageData(0,0,n,r),c=n*r*4*e;a.set(s.data,c)}return this.canvasPool.releaseCanvasWithContext(o),this.createDataArrayTextureFromBuffer(a,n,r,i)}createMaterialRawData(e){let t=V.FLOATS_PER_MATERIAL,n=e.length,r=n*t,i=new Float32Array(r);for(let r=0;r<n;r++){let n=e[r],a=r*t,o=n.mapMatrix??Be,s=n.normalMapMatrices??Be,c=n.roughnessMapMatrices??Be,l=n.metalnessMapMatrices??Be,u=n.emissiveMapMatrices??Be,d=n.bumpMapMatrices??Be,f=n.displacementMapMatrices??Be,p=[n.ior,n.transmission,n.thickness,n.emissiveIntensity,n.attenuationColor.r,n.attenuationColor.g,n.attenuationColor.b,n.attenuationDistance,n.opacity,n.side,n.transparent,n.alphaTest,n.alphaMode,n.depthWrite,n.normalScale?.x??1,n.normalScale?.y??1,n.color.r,n.color.g,n.color.b,n.metalness,n.emissive.r,n.emissive.g,n.emissive.b,n.roughness,n.map,n.normalMap,n.roughnessMap,n.metalnessMap,n.emissiveMap,n.bumpMap,n.clearcoat,n.clearcoatRoughness,n.dispersion,n.visible,n.sheen,n.sheenRoughness,n.sheenColor.r,n.sheenColor.g,n.sheenColor.b,1,n.specularIntensity,n.specularColor.r,n.specularColor.g,n.specularColor.b,n.iridescence,n.iridescenceIOR,n.iridescenceThicknessRange[0],n.iridescenceThicknessRange[1],n.bumpScale,n.displacementScale,n.displacementMap,0,o[0],o[1],o[2],o[3],o[4],o[5],o[6],1,s[0],s[1],s[2],s[3],s[4],s[5],s[6],1,c[0],c[1],c[2],c[3],c[4],c[5],c[6],1,l[0],l[1],l[2],l[3],l[4],l[5],l[6],1,u[0],u[1],u[2],u[3],u[4],u[5],u[6],1,d[0],d[1],d[2],d[3],d[4],d[5],d[6],1,f[0],f[1],f[2],f[3],f[4],f[5],f[6],1];i.set(p,a)}return i}createBVHRawData(e){let t=[],n=e=>{let r=t.length;if(t.push(e),e.leftChild){let t=n(e.leftChild),r=n(e.rightChild);e.leftChild=t,e.rightChild=r}return r};n(e);let r=U.VEC4_PER_BVH_NODE*U.FLOATS_PER_VEC4,i=t.length*r,a=new Float32Array(i);for(let e=0;e<t.length;e++){let n=e*r,i=t[e];if(i.leftChild!==null){let e=i.leftChild,r=i.rightChild,o=t[e],s=t[r];a[n]=o.boundsMin.x,a[n+1]=o.boundsMin.y,a[n+2]=o.boundsMin.z,a[n+3]=e,a[n+4]=o.boundsMax.x,a[n+5]=o.boundsMax.y,a[n+6]=o.boundsMax.z,a[n+7]=r,a[n+8]=s.boundsMin.x,a[n+9]=s.boundsMin.y,a[n+10]=s.boundsMin.z,a[n+12]=s.boundsMax.x,a[n+13]=s.boundsMax.y,a[n+14]=s.boundsMax.z}else a[n]=i.triangleOffset,a[n+1]=i.triangleCount,a[n+3]=-1}return a}async createMaterialTextures(e){let{materials:t,maps:n,normalMaps:i,bumpMaps:a,roughnessMaps:o,metalnessMaps:s,emissiveMaps:c,displacementMaps:l}=e;console.log(`[TextureCreator] Creating material textures only`);let u=performance.now();try{if(!t||t.length===0)throw Error(`No materials provided for texture creation`);this.textureCache.dispose(),this.textureCache=new Va;let e=[];n&&n.length>0&&e.push(this.createTexturesToDataTexture(n).then(e=>({type:`albedo`,texture:e})).catch(e=>(console.warn(`Failed to create albedo textures:`,e),{type:`albedo`,texture:null}))),i&&i.length>0&&e.push(this.createTexturesToDataTexture(i).then(e=>({type:`normal`,texture:e})).catch(e=>(console.warn(`Failed to create normal textures:`,e),{type:`normal`,texture:null}))),a&&a.length>0&&e.push(this.createTexturesToDataTexture(a).then(e=>({type:`bump`,texture:e})).catch(e=>(console.warn(`Failed to create bump textures:`,e),{type:`bump`,texture:null}))),o&&o.length>0&&e.push(this.createTexturesToDataTexture(o).then(e=>({type:`roughness`,texture:e})).catch(e=>(console.warn(`Failed to create roughness textures:`,e),{type:`roughness`,texture:null}))),s&&s.length>0&&e.push(this.createTexturesToDataTexture(s).then(e=>({type:`metalness`,texture:e})).catch(e=>(console.warn(`Failed to create metalness textures:`,e),{type:`metalness`,texture:null}))),c&&c.length>0&&e.push(this.createTexturesToDataTexture(c).then(e=>({type:`emissive`,texture:e})).catch(e=>(console.warn(`Failed to create emissive textures:`,e),{type:`emissive`,texture:null}))),l&&l.length>0&&e.push(this.createTexturesToDataTexture(l).then(e=>({type:`displacement`,texture:e})).catch(e=>(console.warn(`Failed to create displacement textures:`,e),{type:`displacement`,texture:null})));let d=await Promise.allSettled(e),f={};d.forEach(e=>{if(e.status===`fulfilled`&&e.value){let{type:t,texture:n}=e.value;if(n)switch(t){case`albedo`:n.colorSpace=r.SRGBColorSpace,f.albedoTexture=n;break;case`normal`:f.normalTexture=n;break;case`bump`:f.bumpTexture=n;break;case`roughness`:f.roughnessTexture=n;break;case`metalness`:f.metalnessTexture=n;break;case`emissive`:n.colorSpace=r.SRGBColorSpace,f.emissiveTexture=n;break;case`displacement`:f.displacementTexture=n;break}}});let p=performance.now()-u;return console.log(`[TextureCreator] Material texture creation complete (${p.toFixed(2)}ms)`),f}catch(e){throw console.error(`[TextureCreator] Material texture creation error:`,e),Error(`Material texture creation failed: ${e.message}`)}}calculateOptimalDimensions(e){let t=0,n=0;for(let r of e)t=Math.max(t,r.image.width),n=Math.max(n,r.image.height);for(t=2**Math.ceil(Math.log2(t)),n=2**Math.ceil(Math.log2(n));t>=U.MAX_TEXTURE_SIZE/2||n>=U.MAX_TEXTURE_SIZE/2;)t=Math.max(1,Math.floor(t/2)),n=Math.max(1,Math.floor(n/2));return{maxWidth:t,maxHeight:n}}createDataArrayTextureFromResult(e){let t=(e.data instanceof ArrayBuffer,new Uint8Array(e.data));return this.createDataArrayTextureFromBuffer(t,e.width,e.height,e.depth)}createDataArrayTextureFromBuffer(e,t,n,i){let a=new r.DataArrayTexture(e,t,n,i);a.minFilter=r.LinearFilter,a.magFilter=r.LinearFilter,a.format=r.RGBAFormat,a.type=r.UnsignedByteType,a.needsUpdate=!0,a.generateMipmaps=!1,a.userData={buffer:e,bufferType:Uint8Array};let o=a.dispose.bind(a);return a.dispose=()=>{a.userData.buffer&&(this.bufferPool.releaseBuffer(a.userData.buffer,a.userData.bufferType),a.userData.buffer=null),o()},a}async _normalizeTexturesForProcessing(e){let t=[],n=[],i=[];for(let n of e)if(n?.image){if(n.isCompressedTexture&&n.format===r.RGBAFormat&&n.mipmaps?.[0]?.data){let e=n.mipmaps[0],r=t.length;t.push(null),i.push({index:r,promise:Ua(e.data,e.width,e.height)});continue}if(n.isCompressedTexture){console.warn(`[TextureCreator] GPU-compressed texture in mixed group — using placeholder`),t.push(null);continue}if(n.image.data&&!(n.image instanceof HTMLImageElement)&&!(n.image instanceof HTMLCanvasElement)&&!(typeof ImageBitmap<`u`&&n.image instanceof ImageBitmap)){let e=t.length;t.push(null),i.push({index:e,promise:Ua(n.image.data,n.image.width,n.image.height)});continue}t.push(n)}if(i.length>0){let e=await Promise.allSettled(i.map(e=>e.promise));for(let r=0;r<i.length;r++){let{index:a}=i[r],o=e[r];if(o.status===`fulfilled`){let e=o.value;n.push(e),t[a]={image:e}}else console.warn(`[TextureCreator] Failed to create ImageBitmap:`,o.reason)}}for(let e=0;e<t.length;e++)if(t[e]===null){let r=new Uint8ClampedArray([255,255,255,255]),i=await createImageBitmap(new ImageData(r,1,1));n.push(i),t[e]={image:i}}return{normalized:t,bitmapsToClose:n}}createFallbackTexture(){let e=new r.DataArrayTexture(new Uint8Array([255,255,255,255]),1,1,1);return e.minFilter=r.LinearFilter,e.magFilter=r.LinearFilter,e.format=r.RGBAFormat,e.type=r.UnsignedByteType,e.needsUpdate=!0,e.generateMipmaps=!1,e}combineTextureResults(e){return e[0]}dispose(){this.canvasPool.dispose(),this.bufferPool.dispose(),this.textureCache.dispose()}};function Ua(e,t,n){let r=new Uint8ClampedArray(e.buffer,e.byteOffset,e.byteLength);return createImageBitmap(new ImageData(r,t,n))}var Wa=128,Ga=class{constructor(){this._vectorPool={vec3:Array(9).fill().map(()=>new r.Vector3),vec2:[,,,,,,].fill().map(()=>new r.Vector2)},this._matrixPool={mat3:new r.Matrix3,mat4:new r.Matrix4},this.resetArrays(),this.triangleCount=0,this.currentTriangleIndex=0}_getVec3(e=0){return this._vectorPool.vec3[e%this._vectorPool.vec3.length]}_getVec2(e=0){return this._vectorPool.vec2[e%this._vectorPool.vec2.length]}extract(e){return this.resetArrays(),this._triangleCapacity=1024,this.triangleData=new Float32Array(this._triangleCapacity*B.FLOATS_PER_TRIANGLE),this.currentTriangleIndex=0,this.traverseObject(e),this.logStats(),this.getExtractedData()}_ensureCapacity(e){if(e<=this._triangleCapacity)return;let t=this._triangleCapacity;for(;t<e;)t*=2;let n=new Float32Array(t*B.FLOATS_PER_TRIANGLE);n.set(this.triangleData),this.triangleData=n,this._triangleCapacity=t}traverseObject(e){if(e.isMesh?this.processMesh(e):e.isDirectionalLight?this.directionalLights.push(e):e.isCamera&&this.cameras.push(e),e.children)for(let t of e.children)this.traverseObject(t)}processMesh(e){if(!e.geometry||!e.material){console.warn(`Skipping mesh with missing geometry or material:`,e);return}let t=this.processMaterial(e.material);e.userData.materialIndex=t;let n=this.meshes.length;this.meshes.push(e),e.userData.meshIndex=n;let r=this.currentTriangleIndex;this.extractGeometry(e,t,n),this.meshTriangleRanges.push({start:r,count:this.currentTriangleIndex-r})}processMaterial(e){let t=this._materialUuidMap.get(e.uuid)??-1;if(t===-1){e.depthWrite===!1&&(e.depthWrite=!0,console.warn(`Depth write is disabled in material, enabling it for rastered rendering`));let n=this.createMaterialObject(e);this.materials.push(n),t=this.materials.length-1,this._materialUuidMap.set(e.uuid,t),n.clearcoat>0&&(this.sceneFeatures.hasClearcoat=!0),n.transmission>0&&(this.sceneFeatures.hasTransmission=!0),n.dispersion>0&&(this.sceneFeatures.hasDispersion=!0),n.iridescence>0&&(this.sceneFeatures.hasIridescence=!0),n.sheen>0&&(this.sceneFeatures.hasSheen=!0),(n.transparent||n.opacity<1||n.alphaTest>0)&&(this.sceneFeatures.hasTransparency=!0),[n.clearcoat>0,n.transmission>0,n.iridescence>0,n.sheen>0].filter(Boolean).length>=2&&(this.sceneFeatures.hasMultiLobeMaterials=!0)}return t}getMaterialAlphaMode(e){if(e.userData?.gltfExtensions?.KHR_materials_unlit?.alphaMode){let t=e.userData.gltfExtensions.KHR_materials_unlit.alphaMode;return t===`BLEND`?2:+(t===`MASK`)}return e.alphaTest>0?1:e.transparent&&e.opacity<1||e.map&&e.map.format===r.RGBAFormat&&e.transparent?2:0}getMaterialType(e){return e.isMeshPhysicalMaterial?`physical`:e.isMeshStandardMaterial?`standard`:e.isMeshPhongMaterial?`phong`:e.isMeshLambertMaterial?`lambert`:e.isMeshBasicMaterial?`basic`:e.isMeshToonMaterial?`toon`:`unknown`}getPhysicalDefaults(){return{emissive:new r.Color(0,0,0),emissiveIntensity:1,roughness:1,metalness:0,ior:1.5,opacity:1,transmission:0,thickness:.1,attenuationColor:new r.Color(16777215),attenuationDistance:1/0,dispersion:0,sheen:0,sheenRoughness:1,sheenColor:new r.Color(0),specularIntensity:1,specularColor:new r.Color(16777215),clearcoat:0,clearcoatRoughness:0,iridescence:0,iridescenceIOR:1.3,iridescenceThicknessRange:[100,400],normalScale:{x:1,y:1},bumpScale:1,displacementScale:1,alphaTest:0}}mapLegacyMaterialToPhysical(e,t){let n={};switch(t){case`basic`:n.emissive=e.color.clone(),n.emissiveIntensity=1,n.color=new r.Color(0),n.roughness=1,n.metalness=0;break;case`lambert`:n.roughness=1,n.metalness=0,n.specularIntensity=0;break;case`phong`:{let t=e.shininess||30;n.roughness=Math.sqrt(2/(t+2)),n.metalness=0}if(e.specular){let t=e.specular.r*.299+e.specular.g*.587+e.specular.b*.114;n.specularIntensity=Math.min(t*2,1),n.specularColor=e.specular.clone()}break;case`toon`:n.roughness=.9,n.metalness=0;break;case`standard`:case`physical`:break}return n}createMaterialObject(e){let t=this.getPhysicalDefaults(),n=this.getMaterialType(e),i=this.mapLegacyMaterialToPhysical(e,n),a=(e.metalness??i.metalness??0)>.1,o=t.ior;a?o=2.5:e.transmission>0&&(o=1.5);let s=e.color||new r.Color(16777215);return n===`basic`&&!e.map&&(s=new r.Color(0)),{uuid:e.uuid,color:s,emissive:i.emissive??e.emissive??t.emissive,emissiveIntensity:i.emissiveIntensity??e.emissiveIntensity??t.emissiveIntensity,roughness:Math.max(.05,i.roughness??e.roughness??t.roughness),metalness:i.metalness??e.metalness??t.metalness,ior:e.ior??o,opacity:e.opacity??t.opacity,transmission:e.transmission??t.transmission,thickness:e.thickness??t.thickness,attenuationColor:e.attenuationColor??t.attenuationColor,attenuationDistance:e.attenuationDistance??t.attenuationDistance,dispersion:e.dispersion??t.dispersion,sheen:e.sheen??t.sheen,sheenRoughness:e.sheenRoughness??t.sheenRoughness,sheenColor:e.sheenColor??t.sheenColor,clearcoat:e.clearcoat??t.clearcoat,clearcoatRoughness:e.clearcoatRoughness??t.clearcoatRoughness,iridescence:e.iridescence??t.iridescence,iridescenceIOR:e.iridescenceIOR??t.iridescenceIOR,iridescenceThicknessRange:e.iridescenceThicknessRange??t.iridescenceThicknessRange,specularIntensity:i.specularIntensity??e.specularIntensity??t.specularIntensity,specularColor:i.specularColor??e.specularColor??t.specularColor,normalScale:e.normalScale??t.normalScale,bumpScale:e.bumpScale??t.bumpScale,displacementScale:e.displacementScale??t.displacementScale,transparent:+!!e.transparent,alphaTest:e.alphaTest??t.alphaTest,alphaMode:this.getMaterialAlphaMode(e),side:this.getMaterialSide(e),depthWrite:e.depthWrite??!0?1:0,map:this.processTexture(e.map,this.maps),normalMap:this.processTexture(e.normalMap,this.normalMaps),bumpMap:this.processTexture(e.bumpMap,this.bumpMaps),roughnessMap:this.processTexture(e.roughnessMap,this.roughnessMaps),metalnessMap:this.processTexture(e.metalnessMap,this.metalnessMaps),emissiveMap:this.processTexture(e.emissiveMap,this.emissiveMaps),displacementMap:this.processTexture(e.displacementMap,this.displacementMaps),clearcoatMap:this.processTexture(e.clearcoatMap,[]),clearcoatRoughnessMap:this.processTexture(e.clearcoatRoughnessMap,[]),transmissionMap:this.processTexture(e.transmissionMap,[]),thicknessMap:this.processTexture(e.thicknessMap,[]),sheenColorMap:this.processTexture(e.sheenColorMap,[]),sheenRoughnessMap:this.processTexture(e.sheenRoughnessMap,[]),specularIntensityMap:this.processTexture(e.specularIntensityMap,[]),specularColorMap:this.processTexture(e.specularColorMap,[]),iridescenceMap:this.processTexture(e.iridescenceMap,[]),iridescenceThicknessMap:this.processTexture(e.iridescenceThicknessMap,[]),mapMatrix:this.getTextureMatrix(e.map),normalMapMatrices:this.getTextureMatrix(e.normalMap),bumpMapMatrices:this.getTextureMatrix(e.bumpMap),roughnessMapMatrices:this.getTextureMatrix(e.roughnessMap),metalnessMapMatrices:this.getTextureMatrix(e.metalnessMap),emissiveMapMatrices:this.getTextureMatrix(e.emissiveMap),displacementMapMatrices:this.getTextureMatrix(e.displacementMap),originalType:n}}getTextureMatrix(e){return e?(e.updateMatrix(),e.matrix.elements):new r.Matrix3().elements}getMaterialSide(e){if(e.transmission>0)return 2;switch(e.side){case r.FrontSide:return 0;case r.BackSide:return 1;case r.DoubleSide:return 2;default:return 0}}processTexture(e,t){if(!e)return-1;let n=this._textureIndexCache.get(t);n||(n=new Map,this._textureIndexCache.set(t,n));let r=e.source.uuid,i=n.get(r);if(i!==void 0)return i;if(t.length<Wa){t.push(e);let i=t.length-1;return n.set(r,i),i}return-1}extractGeometry(e,t,n){e.updateMatrix(),e.updateMatrixWorld();let r=e.geometry;r.attributes.normal||r.computeVertexNormals();let i=r.attributes.position,a=r.attributes.normal,o=r.attributes.uv,s=r.index?r.index.array:null;this._matrixPool.mat4.copy(e.matrixWorld),this._matrixPool.mat3.getNormalMatrix(this._matrixPool.mat4);let c=s?s.length/3:i.count/3;this.extractTrianglesInBatch(i,a,o,s,c,t,n)}extractTrianglesInBatch(e,t,n,r,i,a,o){let s=this._getVec3(0),c=this._getVec3(1),l=this._getVec3(2),u=this._getVec3(3),d=this._getVec3(4),f=this._getVec3(5),p=this._getVec2(0),m=this._getVec2(1),h=this._getVec2(2);this._ensureCapacity(this.currentTriangleIndex+i);for(let g=0;g<i;g++){let i=g*3,_=r?r[i+0]:i+0,v=r?r[i+1]:i+1,y=r?r[i+2]:i+2;this.getVertex(e,_,s),this.getVertex(e,v,c),this.getVertex(e,y,l),this.getVertex(t,_,u),this.getVertex(t,v,d),this.getVertex(t,y,f),n?(this.getVertex(n,_,p),this.getVertex(n,v,m),this.getVertex(n,y,h)):(p.set(0,0),m.set(0,0),h.set(0,0)),s.applyMatrix4(this._matrixPool.mat4),c.applyMatrix4(this._matrixPool.mat4),l.applyMatrix4(this._matrixPool.mat4),u.applyMatrix3(this._matrixPool.mat3).normalize(),d.applyMatrix3(this._matrixPool.mat3).normalize(),f.applyMatrix3(this._matrixPool.mat3).normalize(),this.packTriangleDataTextureFormat(this.currentTriangleIndex,s,c,l,u,d,f,p,m,h,a,o),this.currentTriangleIndex++}}packTriangleDataTextureFormat(e,t,n,r,i,a,o,s,c,l,u,d){let f=e*B.FLOATS_PER_TRIANGLE;this.triangleData[f+B.POSITION_A_OFFSET+0]=t.x,this.triangleData[f+B.POSITION_A_OFFSET+1]=t.y,this.triangleData[f+B.POSITION_A_OFFSET+2]=t.z,this.triangleData[f+B.POSITION_A_OFFSET+3]=0,this.triangleData[f+B.POSITION_B_OFFSET+0]=n.x,this.triangleData[f+B.POSITION_B_OFFSET+1]=n.y,this.triangleData[f+B.POSITION_B_OFFSET+2]=n.z,this.triangleData[f+B.POSITION_B_OFFSET+3]=0,this.triangleData[f+B.POSITION_C_OFFSET+0]=r.x,this.triangleData[f+B.POSITION_C_OFFSET+1]=r.y,this.triangleData[f+B.POSITION_C_OFFSET+2]=r.z,this.triangleData[f+B.POSITION_C_OFFSET+3]=0,this.triangleData[f+B.NORMAL_A_OFFSET+0]=i.x,this.triangleData[f+B.NORMAL_A_OFFSET+1]=i.y,this.triangleData[f+B.NORMAL_A_OFFSET+2]=i.z;{let e=this.materials[u],t=e&&!(e.alphaMode|0)&&!(e.transparent|0)&&(e.transmission||0)===0&&(e.opacity??1)>=1?1:0;this.triangleData[f+B.NORMAL_A_OFFSET+3]=t}this.triangleData[f+B.NORMAL_B_OFFSET+0]=a.x,this.triangleData[f+B.NORMAL_B_OFFSET+1]=a.y,this.triangleData[f+B.NORMAL_B_OFFSET+2]=a.z,this.triangleData[f+B.NORMAL_B_OFFSET+3]=0,this.triangleData[f+B.NORMAL_C_OFFSET+0]=o.x,this.triangleData[f+B.NORMAL_C_OFFSET+1]=o.y,this.triangleData[f+B.NORMAL_C_OFFSET+2]=o.z,this.triangleData[f+B.NORMAL_C_OFFSET+3]=this.materials[u]?.side??0,this.triangleData[f+B.UV_AB_OFFSET+0]=s.x,this.triangleData[f+B.UV_AB_OFFSET+1]=s.y,this.triangleData[f+B.UV_AB_OFFSET+2]=c.x,this.triangleData[f+B.UV_AB_OFFSET+3]=c.y,this.triangleData[f+B.UV_C_MAT_OFFSET+0]=l.x,this.triangleData[f+B.UV_C_MAT_OFFSET+1]=l.y,this.triangleData[f+B.UV_C_MAT_OFFSET+2]=u,this.triangleData[f+B.UV_C_MAT_OFFSET+3]=d}getTriangleData(){return this.triangleData?this.triangleData.subarray(0,this.currentTriangleIndex*B.FLOATS_PER_TRIANGLE):null}getTriangleCount(){return this.currentTriangleIndex}getVertex(e,t,n){return e.itemSize===2?(n.x=e.getX(t),n.y=e.getY(t)):e.itemSize>=3&&(n.x=e.getX(t),n.y=e.getY(t),n.z=e.getZ(t)),n}logStats(){let e=this.currentTriangleIndex*B.FLOATS_PER_TRIANGLE*4;console.log(`materials:`,this.materials.length),console.log(`triangles:`,this.currentTriangleIndex),console.log(`triangle data size (MB):`,(e/(1024*1024)).toFixed(2)),console.log(`maps:`,this.maps.length)}extractMaterialsOnly(e){return this.resetArrays(),this._traverseMaterialsOnly(e),this.getExtractedData()}_traverseMaterialsOnly(e){if(e.isMesh&&e.geometry&&e.material){let t=this.processMaterial(e.material);e.userData.materialIndex=t;let n=this.meshes.length;this.meshes.push(e),e.userData.meshIndex=n}else e.isDirectionalLight?this.directionalLights.push(e):e.isCamera&&this.cameras.push(e);if(e.children)for(let t of e.children)this._traverseMaterialsOnly(t)}resetArrays(){this.triangleData=null,this.triangleCount=0,this.currentTriangleIndex=0,this.materials=[],this.meshes=[],this.meshTriangleRanges=[],this.maps=[],this.normalMaps=[],this.bumpMaps=[],this.metalnessMaps=[],this.emissiveMaps=[],this.roughnessMaps=[],this.displacementMaps=[],this.directionalLights=[],this.cameras=[],this._materialUuidMap=new Map,this._textureIndexCache=new WeakMap,this.sceneFeatures={hasClearcoat:!1,hasTransmission:!1,hasDispersion:!1,hasIridescence:!1,hasSheen:!1,hasTransparency:!1,hasMultiLobeMaterials:!1,hasMRTOutputs:!0}}getExtractedData(){return{triangleData:this.getTriangleData(),triangleCount:this.getTriangleCount(),materials:this.materials,meshes:this.meshes,meshTriangleRanges:this.meshTriangleRanges,maps:this.maps,normalMaps:this.normalMaps,bumpMaps:this.bumpMaps,metalnessMaps:this.metalnessMaps,emissiveMaps:this.emissiveMaps,roughnessMaps:this.roughnessMaps,displacementMaps:this.displacementMaps,directionalLights:this.directionalLights,cameras:this.cameras,sceneFeatures:this.sceneFeatures}}},Ka=class{constructor(){this.maxLeafSize=8}build(e){let t=e.length;if(t===0){let e=new Float32Array(16);return e[7]=1,{nodeData:e,nodeCount:1,sortedPerm:new Int32Array}}let n=new Int32Array(t);for(let e=0;e<t;e++)n[e]=e;let r=2*t+4,i=new Float32Array(r*16),a=0,o=(t,r)=>{let s=a++,c=s*16,l=1/0,u=1/0,d=1/0,f=-1/0,p=-1/0,m=-1/0,h=0,g=1/0,_=1/0,v=1/0,y=-1/0,b=-1/0,x=-1/0;for(let i=t;i<r;i++){let t=e[n[i]];l=Math.min(l,t.bMinX),u=Math.min(u,t.bMinY),d=Math.min(d,t.bMinZ),f=Math.max(f,t.bMaxX),p=Math.max(p,t.bMaxY),m=Math.max(m,t.bMaxZ),h+=t.power,g=Math.min(g,t.cx),_=Math.min(_,t.cy),v=Math.min(v,t.cz),y=Math.max(y,t.cx),b=Math.max(b,t.cy),x=Math.max(x,t.cz)}i[c+0]=l,i[c+1]=u,i[c+2]=d,i[c+3]=h,i[c+4]=f,i[c+5]=p,i[c+6]=m,i[c+12]=0,i[c+13]=0,i[c+14]=0,i[c+15]=0;let S=r-t;if(S<=this.maxLeafSize)i[c+7]=1,i[c+8]=t,i[c+9]=S,i[c+10]=0,i[c+11]=0;else{let a=y-g,s=b-_,l=x-v,u;u=a>=s&&a>=l?0:s>=l?1:2;let d=[`cx`,`cy`,`cz`][u],f=t+r>>1;this._nthElement(n,e,t,r,f,d),i[c+7]=0;let p=o(t,f),m=o(f,r);i[c+8]=p,i[c+9]=m,i[c+10]=0,i[c+11]=0}return s};o(0,t);let s=new Int32Array(t);for(let e=0;e<t;e++)s[e]=n[e];let c=new Float32Array(a*16);return c.set(i.subarray(0,a*16)),console.log(`[LightBVHBuilder] Built BVH: ${a} nodes for ${t} emissive triangles`),{nodeData:c,nodeCount:a,sortedPerm:s}}_nthElement(e,t,n,r,i,a){for(;n<r-1;){let o=n+r>>1,s=t[e[o]][a],c=e[o];e[o]=e[r-1],e[r-1]=c;let l=n;for(let i=n;i<r-1;i++)t[e[i]][a]<s&&(c=e[i],e[i]=e[l],e[l]=c,l++);if(c=e[l],e[l]=e[r-1],e[r-1]=c,l===i)return;l<i?n=l+1:r=l}}},qa=class{constructor(){this.emissiveTriangles=[],this.emissiveCount=0,this.totalEmissivePower=0,this.emissiveIndicesArray=null,this.emissivePowerArray=null,this.cdfArray=null,this.lightBVHNodeData=null,this.lightBVHNodeCount=0}extractEmissiveTriangles(e,t,n){console.log(`[EmissiveTriangleBuilder] Extracting emissive triangles...`),this.emissiveTriangles=[],this.totalEmissivePower=0;let r=B.FLOATS_PER_TRIANGLE,i=B.UV_C_MAT_OFFSET+2;for(let a=0;a<n;a++){let n=a*r,o=Math.floor(e[n+i]),s=t[o];if(!s)continue;let c=s.emissive||{r:0,g:0,b:0},l=s.emissiveIntensity||0;if(l>0&&(c.r>0||c.g>0||c.b>0)){let t=e[n+0],r=e[n+1],i=e[n+2],s=e[n+4],u=e[n+5],d=e[n+6],f=e[n+8],p=e[n+9],m=e[n+10],h=this._calculateTriangleArea(t,r,i,s,u,d,f,p,m),g=(c.r+c.g+c.b)/3*l*h,_=(t+s+f)/3,v=(r+u+p)/3,y=(i+d+m)/3,b=Math.min(t,s,f),x=Math.min(r,u,p),S=Math.min(i,d,m),C=Math.max(t,s,f),w=Math.max(r,u,p),T=Math.max(i,d,m);this.emissiveTriangles.push({triangleIndex:a,materialIndex:o,power:g,area:h,emissive:{r:c.r,g:c.g,b:c.b},emissiveIntensity:l,cx:_,cy:v,cz:y,bMinX:b,bMinY:x,bMinZ:S,bMaxX:C,bMaxY:w,bMaxZ:T}),this.totalEmissivePower+=g}}return this.emissiveCount=this.emissiveTriangles.length,console.log(`[EmissiveTriangleBuilder] Found ${this.emissiveCount} emissive triangles (${(this.emissiveCount/n*100).toFixed(2)}%)`),console.log(`[EmissiveTriangleBuilder] Total emissive power: ${this.totalEmissivePower.toFixed(2)}`),this._buildDataArrays(),this.emissiveCount}_calculateTriangleArea(e,t,n,r,i,a,o,s,c){let l=r-e,u=i-t,d=a-n,f=o-e,p=s-t,m=c-n,h=u*m-d*p,g=d*f-l*m,_=l*p-u*f;return Math.sqrt(h*h+g*g+_*_)*.5}_buildDataArrays(){this.emissiveIndicesArray=new Int32Array(this.emissiveCount),this.emissivePowerArray=new Float32Array(this.emissiveCount);for(let e=0;e<this.emissiveCount;e++)this.emissiveIndicesArray[e]=this.emissiveTriangles[e].triangleIndex,this.emissivePowerArray[e]=this.emissiveTriangles[e].power;this._buildCDF()}_buildCDF(){if(this.emissiveCount===0){this.cdfArray=new Float32Array(1),this.cdfArray[0]=0;return}this.cdfArray=new Float32Array(this.emissiveCount);let e=0;for(let t=0;t<this.emissiveCount;t++)e+=this.emissivePowerArray[t],this.cdfArray[t]=e;if(e>0)for(let t=0;t<this.emissiveCount;t++)this.cdfArray[t]/=e}sampleCDF(e){if(this.emissiveCount===0)return-1;if(this.emissiveCount===1)return 0;let t=0,n=this.emissiveCount-1;for(;t<n;){let r=Math.floor((t+n)/2);this.cdfArray[r]<e?t=r+1:n=r}return t}getGPUData(){return{emissiveIndices:this.emissiveIndicesArray,emissivePower:this.emissivePowerArray,emissiveCDF:this.cdfArray,emissiveCount:this.emissiveCount,totalPower:this.totalEmissivePower}}createEmissiveTexture(){if(this.emissiveCount===0)return new r.DataTexture(new Float32Array(4),1,1,r.RGBAFormat,r.FloatType);let e=new Float32Array(this.emissiveCount*4);for(let t=0;t<this.emissiveCount;t++){let n=t*4;e[n+0]=this.emissiveIndicesArray[t],e[n+1]=this.emissivePowerArray[t],e[n+2]=this.cdfArray[t],e[n+3]=0}let t=Math.ceil(Math.sqrt(this.emissiveCount)),n=Math.ceil(this.emissiveCount/t),i=t*n*4,a=new Float32Array(i);a.set(e);let o=new r.DataTexture(a,t,n,r.RGBAFormat,r.FloatType);return o.needsUpdate=!0,o.generateMipmaps=!1,o.minFilter=r.NearestFilter,o.magFilter=r.NearestFilter,console.log(`[EmissiveTriangleBuilder] Created ${t}x${n} emissive texture (${this.emissiveCount} emissives)`),o}createEmissiveRawData(){if(this.emissiveCount===0)return new Float32Array(8);let e=new Float32Array(this.emissiveCount*8);for(let t=0;t<this.emissiveCount;t++){let n=this.emissiveTriangles[t],r=t*8;e[r+0]=n.triangleIndex,e[r+1]=n.power,e[r+2]=this.cdfArray[t],e[r+3]=this.totalEmissivePower>0?n.power/this.totalEmissivePower:0,e[r+4]=n.emissive.r*n.emissiveIntensity,e[r+5]=n.emissive.g*n.emissiveIntensity,e[r+6]=n.emissive.b*n.emissiveIntensity,e[r+7]=n.area}return console.log(`[EmissiveTriangleBuilder] Created emissive raw data: ${this.emissiveCount} entries (${e.byteLength} bytes)`),e}getStats(){if(this.emissiveCount===0)return{count:0,totalPower:0,averagePower:0,minPower:0,maxPower:0};let e=1/0,t=-1/0;for(let n=0;n<this.emissiveCount;n++){let r=this.emissivePowerArray[n];e=Math.min(e,r),t=Math.max(t,r)}return{count:this.emissiveCount,totalPower:this.totalEmissivePower,averagePower:this.totalEmissivePower/this.emissiveCount,minPower:e,maxPower:t}}updateMaterialEmissive(e,t,n,r,i){let a=t.emissive||{r:0,g:0,b:0},o=t.emissiveIntensity||0,s=o>0&&(a.r>0||a.g>0||a.b>0);if(s!==this.emissiveTriangles.some(t=>t.materialIndex===e))return this.extractEmissiveTriangles(n,r,i),!0;if(!s)return!1;let c=(a.r+a.g+a.b)/3;this.totalEmissivePower=0;for(let t=0;t<this.emissiveCount;t++){let n=this.emissiveTriangles[t];n.materialIndex===e&&(n.power=c*o*n.area,n.emissive={r:a.r,g:a.g,b:a.b},n.emissiveIntensity=o,this.emissivePowerArray[t]=n.power),this.totalEmissivePower+=this.emissiveTriangles[t].power}return this._buildCDF(),!0}buildLightBVH(){if(this.emissiveCount===0)return this.lightBVHNodeData=new Float32Array(16),this.lightBVHNodeData[7]=1,this.lightBVHNodeCount=1,1;let{nodeData:e,nodeCount:t,sortedPerm:n}=new Ka().build(this.emissiveTriangles);return this.lightBVHNodeData=e,this.lightBVHNodeCount=t,this._rebuildSortedEmissiveData(n),t}_rebuildSortedEmissiveData(e){let t=e.length;this.emissiveIndicesArray=new Int32Array(t),this.emissivePowerArray=new Float32Array(t);for(let n=0;n<t;n++){let t=e[n];this.emissiveIndicesArray[n]=this.emissiveTriangles[t].triangleIndex,this.emissivePowerArray[n]=this.emissiveTriangles[t].power}this._buildCDF();let n=new Float32Array(t*8);for(let r=0;r<t;r++){let t=e[r],i=this.emissiveTriangles[t],a=r*8;n[a+0]=i.triangleIndex,n[a+1]=i.power,n[a+2]=this.cdfArray[r],n[a+3]=this.totalEmissivePower>0?i.power/this.totalEmissivePower:0,n[a+4]=i.emissive.r*i.emissiveIntensity,n[a+5]=i.emissive.g*i.emissiveIntensity,n[a+6]=i.emissive.b*i.emissiveIntensity,n[a+7]=i.area}this.emissiveTriangleData=n,console.log(`[EmissiveTriangleBuilder] Rebuilt sorted emissive data: ${t} entries`)}clear(){this.emissiveTriangles=[],this.emissiveCount=0,this.totalEmissivePower=0,this.emissiveIndicesArray=null,this.emissivePowerArray=null,this.cdfArray=null,this.lightBVHNodeData=null,this.lightBVHNodeCount=0}},Ja=``+(typeof document>`u`&&typeof location>`u`?require(`url`).pathToFileURL(__dirname+`/assets/BVHRefitWorker-GkmNJYvb.js`).href:new URL(`assets/BVHRefitWorker-GkmNJYvb.js`,typeof document>`u`?location.href:document.currentScript&&document.currentScript.tagName.toUpperCase()===`SCRIPT`&&document.currentScript.src||document.baseURI).href),Ya=class{constructor(e={}){this.config={useWorkers:!0,bvhDepth:30,maxLeafSize:4,verbose:!1,useFloat32Array:!0,textureQuality:`adaptive`,enableTextureCache:!0,maxConcurrentTextureTasks:Math.min(navigator.hardwareConcurrency||4,6),treeletSize:7,treeletOptimizationPasses:1,treeletMinImprovement:.01,...e},this.triangleData=null,this.triangleCount=0,this.materials=[],this.maps=[],this.normalMaps=[],this.bumpMaps=[],this.roughnessMaps=[],this.metalnessMaps=[],this.emissiveMaps=[],this.displacementMaps=[],this.directionalLights=[],this.cameras=[],this.spheres=[],this.bvhRoot=null,this.bvhData=null,this.materialData=null,this.instanceTable=null,this.originalToBvhMap=null,this._refitWorker=null,this._refitSharedBuffers=null,this._rebuildGeneration=0,this._pendingRebuilds=new Map,this.albedoTextures=null,this.normalTextures=null,this.bumpTextures=null,this.roughnessTextures=null,this.metalnessTextures=null,this.emissiveTextures=null,this.displacementTextures=null,this.emissiveTriangleData=null,this.emissiveTriangleCount=0,this.lightBVHNodeData=null,this.lightBVHNodeCount=0,this._initProcessors(),this.isProcessing=!1,this.processingStage=null,this.performanceMetrics={textureCreationTime:0,geometryExtractionTime:0,bvhBuildTime:0,totalProcessingTime:0}}_initProcessors(){this.geometryExtractor=new Ga,this.bvhBuilder=new ba,this.bvhBuilder.maxLeafSize=this.config.maxLeafSize,this.bvhBuilder.setTreeletConfig({enabled:this.config.enableTreeletOptimization,size:this.config.treeletSize,passes:this.config.treeletOptimizationPasses,minImprovement:this.config.treeletMinImprovement}),this.textureCreator=new Ha,this.emissiveTriangleBuilder=new qa,this.tlasBuilder=new Ia}_log(e,t){this.config.verbose&&console.log(`[SceneProcessor] ${e}`,t||``)}async buildBVH(e){if(this.isProcessing)throw Error(`Already processing a scene. Call dispose() first.`);this.isProcessing=!0,this.processingStage=`init`;let t=new ua(`SceneProcessor (${e.name||`scene`})`);try{this._reset(),this._log(`Starting scene processing`),this.processingStage=`extraction`,t.start(`Geometry extraction`),await this._extractGeometry(e),t.end(`Geometry extraction`),this.performanceMetrics.geometryExtractionTime=t.getDuration(`Geometry extraction`),this.processingStage=`bvh`,t.start(`BVH construction (worker)`),t.start(`Material textures (parallel)`);let n=!1,r=this._buildBVH().then(()=>t.end(`BVH construction (worker)`)),i=this._createMaterialTextures().then(()=>{t.end(`Material textures (parallel)`),n=!0});return await r,R({status:`Building light data...`,progress:77}),t.start(`Emissive extraction + Light BVH`),this._buildEmissiveData(),t.end(`Emissive extraction + Light BVH`),n||R({status:`Processing material textures...`,progress:80}),await i,this.performanceMetrics.bvhBuildTime=t.getDuration(`BVH construction (worker)`),this.performanceMetrics.textureCreationTime=t.getDuration(`Material textures (parallel)`),this.processingStage=`finalize`,t.start(`BVH data packing`),this.bvhRoot&&!this.bvhData&&(this.bvhData=this.textureCreator.createBVHRawData(this.bvhRoot)),t.end(`BVH data packing`),this.spheres=this._createSpheres(),this.performanceMetrics.totalProcessingTime=performance.now()-t.totalStart,t.print(),this.processingStage=`complete`,R({status:`Scene data ready`,progress:85}),this}catch(e){throw this.processingStage=`error`,console.error(`[SceneProcessor] Processing error:`,e),R({status:`Error: ${e.message}`,progress:100}),e}finally{this.isProcessing=!1}}async _extractGeometry(e){R({isLoading:!0,title:`Processing`,status:`Extracting geometry...`,progress:15}),await new Promise(e=>setTimeout(e,0)),this._log(`Extracting geometry`);let t=performance.now();try{let n=this.geometryExtractor.extract(e);this.triangleData=n.triangleData,this.triangleCount=n.triangleCount,this._log(`Using Float32Array format: ${this.triangleCount} triangles, ${(this.triangleData.byteLength/(1024*1024)).toFixed(2)}MB`),this.materials=n.materials,this.materialCount=this.materials.length,this.meshes=n.meshes,this.meshTriangleRanges=n.meshTriangleRanges,this.maps=n.maps,this.normalMaps=n.normalMaps,this.bumpMaps=n.bumpMaps,this.roughnessMaps=n.roughnessMaps,this.metalnessMaps=n.metalnessMaps,this.emissiveMaps=n.emissiveMaps,this.displacementMaps=n.displacementMaps,this.directionalLights=n.directionalLights,this.cameras=n.cameras,this.sceneFeatures=n.sceneFeatures;let r=performance.now()-t;this._log(`Geometry extraction complete (${r.toFixed(2)}ms)`,{triangleCount:this.triangleCount,materials:this.materials.length}),R({status:`Extracted ${this.triangleCount.toLocaleString()} triangles`,progress:25})}catch(e){throw console.error(`[SceneProcessor] Geometry extraction error:`,e),R({status:`Extraction error: ${e.message}`,progress:25}),e}}async _buildBVH(){if(R({status:`Building BVH...`,progress:25}),this.triangleCount===0)throw Error(`No triangles to build BVH from`);this._log(`Building two-level BVH (TLAS/BLAS)`);let e=performance.now();try{let t=B.FLOATS_PER_TRIANGLE,n=this.meshTriangleRanges;if(!n||n.length===0)throw Error(`No mesh triangle ranges available for TLAS/BLAS build`);this.instanceTable=new La,this.instanceTable.allocate(n.length);let r=n.length,i=this.config.enableTreeletOptimization,a=[],o=[];for(let e=0;e<r;e++){let t=n[e];t.count!==0&&(t.count>=2e5&&Na(t.count)?o.push({m:e,range:t}):a.push({m:e,range:t}))}let s={depth:this.config.bvhDepth,treeletOptimization:{enabled:i!==!1,size:this.config.treeletSize,passes:this.config.treeletOptimizationPasses,minImprovement:this.config.treeletMinImprovement},reinsertionOptimization:{enabled:this.bvhBuilder.enableReinsertionOptimization,batchSizeRatio:this.bvhBuilder.reinsertionBatchSizeRatio,maxIterations:this.bvhBuilder.reinsertionMaxIterations}},c=a.length+o.length,l=this._buildBLASesWithPool(a,s,e=>{R({status:`Building BLAS ${e+o.length}/${c}...`,progress:25+Math.floor(e/c*45)})}),u=o.map(({m:e,range:n})=>Aa(this.triangleData.slice(n.start*t,(n.start+n.count)*t),this.config.bvhDepth,null,{maxLeafSize:this.bvhBuilder.maxLeafSize,numBins:this.bvhBuilder.numBins,maxBins:this.bvhBuilder.maxBins,minBins:this.bvhBuilder.minBins,...s}).then(t=>({m:e,range:n,result:t}))),[d,f]=await Promise.all([l,Promise.all(u)]);for(let{m:e,range:n,result:r}of[...d,...f])r.reorderedTriangles&&this.triangleData.set(r.reorderedTriangles,n.start*t),this.instanceTable.setEntry({meshIndex:e,blasNodeCount:r.bvhData.length/16,triOffset:n.start,triCount:n.count,originalToBvhMap:r.originalToBvh||null,bvhData:r.bvhData});R({status:`Built all BLASes`,progress:70}),R({status:`Building TLAS...`,progress:72});let p=this.instanceTable.entries.filter(e=>e!==null);this.instanceTable.computeAABBs(this.triangleData);let{root:m,nodeCount:h}=this.tlasBuilder.build(p);this.instanceTable.assignOffsets(h);let g=this.instanceTable.totalNodeCount,_=this.tlasBuilder.flatten(m,p);this.bvhData=new Float32Array(g*16),this.bvhData.set(_);for(let e of p){let t=e.blasOffset*16;this.bvhData.set(e.bvhData,t),this._offsetBLASInPlace(t,e.bvhData.length/16,e.blasOffset,e.triOffset)}this._buildGlobalOriginalToBvhMap();for(let e of p)e.originalToBvhMap=null,e.bvhData=null;this.bvhRoot=!0,this._disposeRefitWorker();let v=performance.now()-e;this._log(`BVH complete: ${p.length} mesh(es), ${this.bvhData.length/16} nodes (${v.toFixed(2)}ms)`),R({status:`BVH construction complete`,progress:75})}catch(e){throw console.error(`[SceneProcessor] BVH building error:`,e),R({status:`BVH error: ${e.message}`,progress:75}),e}}_offsetBLASInPlace(e,t,n,r){for(let i=0;i<t;i++){let t=e+i*16;this.bvhData[t+3]===-1?this.bvhData[t]+=r:(this.bvhData[t+3]+=n,this.bvhData[t+7]+=n)}}_buildBLASesWithPool(e,t,n){if(e.length===0)return Promise.resolve([]);let r=B.FLOATS_PER_TRIANGLE,i=Math.min(e.length,this.config.maxConcurrentTextureTasks||4),a=[],o=0,s=0;return new Promise((c,l)=>{let u=[],d=n=>{if(o>=e.length){n.terminate(),u.splice(u.indexOf(n),1),u.length===0&&c(a);return}let{m:i,range:s}=e[o++],l=this.triangleData.slice(s.start*r,(s.start+s.count)*r),d=s.count,f=d<=500?{...t.treeletOptimization,enabled:!1}:t.treeletOptimization;n._currentTask={m:i,range:s},n.postMessage({triangleData:l.buffer,triangleByteOffset:l.byteOffset,triangleByteLength:l.byteLength,triangleCount:d,depth:t.depth,reportProgress:!1,sharedReorderBuffer:null,treeletOptimization:f,reinsertionOptimization:t.reinsertionOptimization},[l.buffer])},f=(e,t)=>{let r=t.data;if(r.error){u.forEach(e=>e.terminate()),l(Error(r.error));return}if(r.progress!==void 0)return;let{m:i,range:o}=e._currentTask;a.push({m:i,range:o,result:{bvhData:r.bvhData,reorderedTriangles:r.triangles||null,originalToBvh:r.originalToBvh||null}}),s++,n?.(s),d(e)};(async()=>{for(let e=0;e<i;e++){let e;try{e=new Worker(ga,{type:`module`})}catch(t){if(t.name!==`SecurityError`){l(t);return}e=await Ze(ga)}e.onmessage=t=>f(e,t),e.onerror=e=>{u.forEach(e=>e.terminate()),l(e)},u.push(e),d(e)}})().catch(l)})}_buildGlobalOriginalToBvhMap(){this.originalToBvhMap=new Uint32Array(this.triangleCount);for(let e of this.instanceTable.entries){if(!e)continue;let t=new Uint32Array(e.triCount);if(e.originalToBvhMap)for(let n=0;n<e.triCount;n++){let r=e.originalToBvhMap[n];this.originalToBvhMap[e.triOffset+n]=e.triOffset+r,t[r]=n}else for(let n=0;n<e.triCount;n++)this.originalToBvhMap[e.triOffset+n]=e.triOffset+n,t[n]=n;e.bvhToOriginal=t}}async _createMaterialTextures(){this._log(`Creating material textures (parallel with BVH)`);try{this.materials?.length&&(this.materialData=this.textureCreator.createMaterialRawData(this.materials));let e=[{data:this.maps,prop:`albedoTextures`},{data:this.normalMaps,prop:`normalTextures`},{data:this.bumpMaps,prop:`bumpTextures`},{data:this.roughnessMaps,prop:`roughnessTextures`},{data:this.metalnessMaps,prop:`metalnessTextures`},{data:this.emissiveMaps,prop:`emissiveTextures`},{data:this.displacementMaps,prop:`displacementTextures`}];await Promise.all(e.filter(({data:e})=>e?.length>0).map(({data:e,prop:t})=>this.textureCreator.createTexturesToDataTexture(e).then(e=>{this[t]=e}))),this._log(`Material textures complete`,{materialData:!!this.materialData})}catch(e){throw console.error(`[SceneProcessor] Texture creation error:`,e),e}}_buildEmissiveData(){this.emissiveTriangleCount=this.emissiveTriangleBuilder.extractEmissiveTriangles(this.triangleData,this.materials,this.triangleCount),this.emissiveTriangleData=this.emissiveTriangleBuilder.createEmissiveRawData(),this.emissiveTotalPower=this.emissiveTriangleBuilder.totalEmissivePower,this._log(`Emissive triangle extraction complete`,this.emissiveTriangleBuilder.getStats()),this.emissiveTriangleBuilder.buildLightBVH(),this.lightBVHNodeData=this.emissiveTriangleBuilder.lightBVHNodeData,this.lightBVHNodeCount=this.emissiveTriangleBuilder.lightBVHNodeCount,this.emissiveTriangleData=this.emissiveTriangleBuilder.emissiveTriangleData||this.emissiveTriangleData}_createSpheres(){return[]}_reset(){this._disposeTextures(),this.triangles=[],this.triangleData=null,this.triangleCount=0,this.materials=[],this.meshTriangleRanges=null,this.maps=[],this.normalMaps=[],this.bumpMaps=[],this.roughnessMaps=[],this.metalnessMaps=[],this.emissiveMaps=[],this.displacementMaps=[],this.directionalLights=[],this.cameras=[],this.spheres=[],this.bvhRoot=null,this.bvhData=null,this.instanceTable=null,this.lightBVHNodeData=null,this.lightBVHNodeCount=0,this.performanceMetrics={textureCreationTime:0,geometryExtractionTime:0,bvhBuildTime:0,totalProcessingTime:0}}_disposeTextures(){[`albedoTextures`,`normalTextures`,`bumpTextures`,`roughnessTextures`,`metalnessTextures`,`emissiveTextures`,`displacementTextures`].forEach(e=>{this[e]&&(typeof this[e].dispose==`function`&&this[e].dispose(),this[e]=null)})}async rebuildMaterials(e){if(this.isProcessing)throw Error(`Already processing. Cannot rebuild materials during processing.`);this._log(`Rebuilding materials and textures`);let t=performance.now();try{this.isProcessing=!0;let n=this.geometryExtractor.extractMaterialsOnly(e);this._disposeMaterialTextures(),this.materials=n.materials,this.materialCount=this.materials.length,this.meshes=n.meshes,this.maps=n.maps,this.normalMaps=n.normalMaps,this.bumpMaps=n.bumpMaps,this.roughnessMaps=n.roughnessMaps,this.metalnessMaps=n.metalnessMaps,this.emissiveMaps=n.emissiveMaps,this.displacementMaps=n.displacementMaps,this.sceneFeatures=n.sceneFeatures;let r={materials:this.materials,triangles:this.triangleData,maps:this.maps,normalMaps:this.normalMaps,bumpMaps:this.bumpMaps,roughnessMaps:this.roughnessMaps,metalnessMaps:this.metalnessMaps,emissiveMaps:this.emissiveMaps,displacementMaps:this.displacementMaps,bvhRoot:this.bvhRoot},i=await this.textureCreator.createMaterialTextures(r);this.materialData=this.textureCreator.createMaterialRawData(this.materials),this.albedoTextures=i.albedoTexture,this.normalTextures=i.normalTexture,this.bumpTextures=i.bumpTexture,this.roughnessTextures=i.roughnessTexture,this.metalnessTextures=i.metalnessTexture,this.emissiveTextures=i.emissiveTexture,this.displacementTextures=i.displacementTexture;let a=performance.now()-t;return this._log(`Material rebuild complete (${a.toFixed(2)}ms)`,{materials:this.materials.length,textures:this.maps.length}),this}catch(e){throw console.error(`[SceneProcessor] Material rebuild error:`,e),e}finally{this.isProcessing=!1}}_disposeMaterialTextures(){[`albedoTextures`,`normalTextures`,`bumpTextures`,`roughnessTextures`,`metalnessTextures`,`emissiveTextures`,`displacementTextures`].forEach(e=>{if(this[e])try{typeof this[e].dispose==`function`&&this[e].dispose()}catch(t){console.warn(`[SceneProcessor] Error disposing ${e}:`,t)}finally{this[e]=null}}),this.textureCreator&&this.textureCreator.textureCache&&(this.textureCreator.textureCache.dispose(),this.textureCreator.textureCache=new this.textureCreator.textureCache.constructor)}getStatistics(){let e={triangleCount:this.triangleCount,materialCount:this.materials.length,textureCount:this.maps.length,lightCount:this.directionalLights.length,cameraCount:this.cameras.length,processingComplete:this.processingStage===`complete`,hasBVH:!!this.bvhRoot,hasTextures:!!this.materialData&&!!this.bvhData,useFloat32Array:this.config.useFloat32Array,triangleDataSize:this.triangleData?(this.triangleData.byteLength/(1024*1024)).toFixed(2)+`MB`:`0MB`};return this.performanceMetrics.totalProcessingTime>0&&(e.performance={totalTime:this.performanceMetrics.totalProcessingTime,textureTime:this.performanceMetrics.textureCreationTime,bvhTime:this.performanceMetrics.bvhBuildTime,extractionTime:this.performanceMetrics.geometryExtractionTime,texturePercentage:(this.performanceMetrics.textureCreationTime/this.performanceMetrics.totalProcessingTime*100).toFixed(1)+`%`}),this.textureCreator&&this.textureCreator.capabilities&&(e.textureCapabilities=this.textureCreator.capabilities),e}updateConfig(e){Object.assign(this.config,e),this.bvhBuilder&&(this.bvhBuilder.maxLeafSize=this.config.maxLeafSize,this.bvhBuilder.setTreeletConfig({enabled:this.config.enableTreeletOptimization,size:this.config.treeletSize,passes:this.config.treeletOptimizationPasses,minImprovement:this.config.treeletMinImprovement})),this._log(`Configuration updated`,this.config)}async refitBVH(e,t){if(!this.bvhData||!this.triangleData||!this.originalToBvhMap)throw Error(`No BVH data available for refit. Run buildBVH() first.`);if(!this._refitWorker)try{this._refitWorker=new Worker(Ja,{type:`module`})}catch(e){if(e.name!==`SecurityError`)throw e;this._refitWorker=await Ze(Ja)}if(!this._refitSharedBuffers){let t=new SharedArrayBuffer(this.bvhData.byteLength),n=new SharedArrayBuffer(this.triangleData.byteLength),r=new SharedArrayBuffer(e.byteLength),i=new Float32Array(t),a=new Float32Array(n);i.set(this.bvhData),a.set(this.triangleData),this.bvhData=i,this.triangleData=a;let o=this.originalToBvhMap.length,s=new Uint32Array(o);for(let e=0;e<o;e++)s[this.originalToBvhMap[e]]=e;this._refitSharedBuffers={bvhBuf:t,triBuf:n,posBuf:r,posView:new Float32Array(r)},this._refitWorker.postMessage({type:`init`,sharedBvhBuf:t,sharedTriBuf:n,sharedPosBuf:r,bvhToOriginal:s},[s.buffer])}return this._refitSharedBuffers.posView.set(e),new Promise((e,n)=>{this._refitWorker.onmessage=r=>{let i=r.data;i.type===`refitComplete`?(t&&this._patchSmoothNormals(t),e({refitTimeMs:i.refitTimeMs})):i.type===`error`&&n(Error(i.error))},this._refitWorker.postMessage({type:`refit`})})}_patchSmoothNormals(e){this._patchNormalsRange(e,0,this.originalToBvhMap.length)}refitBLASes(e,t,n){if(!this.instanceTable||!this.bvhData||!this.triangleData)throw Error(`No TLAS/BLAS data available. Run buildBVH() first.`);let r=performance.now();this._blasRefitter||=new Ta;for(let r of e){let e=this.instanceTable.entries[r];e&&(this._updateMeshTrianglePositions(e,t),n&&this._patchMeshSmoothNormals(e,n),this._blasRefitter.refitRange(this.bvhData,this.triangleData,e.blasOffset,e.blasNodeCount),this.instanceTable.recomputeAABB(r,this.bvhData,this.triangleData))}return this._refitTLAS(),{refitTimeMs:performance.now()-r}}computeBLASDirtyRanges(e){let t=B.FLOATS_PER_TRIANGLE,n=[],r=[];for(let i of e){let e=this.instanceTable.entries[i];e&&(n.push({offset:e.triOffset*t,count:e.triCount*t}),r.push({offset:e.blasOffset*16,count:e.blasNodeCount*16}))}return r.push({offset:0,count:this.instanceTable.tlasNodeCount*16}),{triRanges:n,bvhRanges:r}}uploadToPathTracer(e,t,n,r){return this.triangleData?(e.setTriangleData(this.triangleData,this.triangleCount),this.bvhData?(e.setBVHData(this.bvhData),e.setInstanceTable(this.instanceTable),this.materialData?e.materialData.setMaterialData(this.materialData):console.warn(`SceneProcessor: No material data, using defaults`),r&&e.environment.setEnvironmentTexture(r),e.materialData.setMaterialTextures({albedoMaps:this.albedoTextures,normalMaps:this.normalTextures,bumpMaps:this.bumpTextures,roughnessMaps:this.roughnessTextures,metalnessMaps:this.metalnessTextures,emissiveMaps:this.emissiveTextures,displacementMaps:this.displacementTextures}),this.emissiveTriangleData&&e.setEmissiveTriangleData(this.emissiveTriangleData,this.emissiveTriangleCount,this.emissiveTotalPower),this.lightBVHNodeData&&e.setLightBVHData(this.lightBVHNodeData,this.lightBVHNodeCount),t.transferSceneLights(n),!0):(console.error(`SceneProcessor: Failed to get BVH data`),!1)):(console.error(`SceneProcessor: Failed to get triangle data`),!1)}updateMaterialEmissive(e,t,n){if(!this.emissiveTriangleBuilder)return null;let r=this.materials[e];return!r||(t===`emissive`?r.emissive=n:t===`emissiveIntensity`&&(r.emissiveIntensity=n),!this.emissiveTriangleBuilder.updateMaterialEmissive(e,r,this.triangleData,this.materials,this.triangleCount))?null:{rawData:this.emissiveTriangleBuilder.createEmissiveRawData(),emissiveCount:this.emissiveTriangleBuilder.emissiveCount,totalPower:this.emissiveTriangleBuilder.totalEmissivePower}}_updateMeshTrianglePositions(e,t){let n=B.FLOATS_PER_TRIANGLE,r=B.POSITION_A_OFFSET,i=B.POSITION_B_OFFSET,a=B.POSITION_C_OFFSET,o=B.NORMAL_A_OFFSET,s=B.NORMAL_B_OFFSET,c=B.NORMAL_C_OFFSET,l=e.bvhToOriginal;for(let u=0;u<e.triCount;u++){let d=l[u],f=(e.triOffset+u)*n,p=(e.triOffset+d)*9,m=t[p],h=t[p+1],g=t[p+2],_=t[p+3],v=t[p+4],y=t[p+5],b=t[p+6],x=t[p+7],S=t[p+8];this.triangleData[f+r]=m,this.triangleData[f+r+1]=h,this.triangleData[f+r+2]=g,this.triangleData[f+i]=_,this.triangleData[f+i+1]=v,this.triangleData[f+i+2]=y,this.triangleData[f+a]=b,this.triangleData[f+a+1]=x,this.triangleData[f+a+2]=S;let C=_-m,w=v-h,T=y-g,E=b-m,D=x-h,O=S-g,k=w*O-T*D,A=T*E-C*O,j=C*D-w*E;this.triangleData[f+o]=k,this.triangleData[f+o+1]=A,this.triangleData[f+o+2]=j,this.triangleData[f+s]=k,this.triangleData[f+s+1]=A,this.triangleData[f+s+2]=j,this.triangleData[f+c]=k,this.triangleData[f+c+1]=A,this.triangleData[f+c+2]=j}}_patchMeshSmoothNormals(e,t){this._patchNormalsRange(t,e.triOffset,e.triCount)}_patchNormalsRange(e,t,n){let r=B.FLOATS_PER_TRIANGLE,i=B.NORMAL_A_OFFSET,a=B.NORMAL_B_OFFSET,o=B.NORMAL_C_OFFSET;for(let s=0;s<n;s++){let n=t+s,c=this.originalToBvhMap[n]*r,l=n*9;this.triangleData[c+i]=e[l],this.triangleData[c+i+1]=e[l+1],this.triangleData[c+i+2]=e[l+2],this.triangleData[c+a]=e[l+3],this.triangleData[c+a+1]=e[l+4],this.triangleData[c+a+2]=e[l+5],this.triangleData[c+o]=e[l+6],this.triangleData[c+o+1]=e[l+7],this.triangleData[c+o+2]=e[l+8]}}_refitTLAS(){let e=this.instanceTable.tlasNodeCount;(!this._tlasBounds||this._tlasBounds.length<e*6)&&(this._tlasBounds=new Float32Array(e*6)),this._blasOffsetMap||=new Map,this._blasOffsetMap.clear();for(let e of this.instanceTable.entries)e&&this._blasOffsetMap.set(e.blasOffset,e);for(let t=e-1;t>=0;t--){let e=t*16,n=this.bvhData[e+3];if(n===-2){let n=this.bvhData[e],r=this._blasOffsetMap.get(n);if(r&&r.worldAABB){let e=t*6;this._tlasBounds[e]=r.worldAABB.minX,this._tlasBounds[e+1]=r.worldAABB.minY,this._tlasBounds[e+2]=r.worldAABB.minZ,this._tlasBounds[e+3]=r.worldAABB.maxX,this._tlasBounds[e+4]=r.worldAABB.maxY,this._tlasBounds[e+5]=r.worldAABB.maxZ}}else if(n>=0){let n=this.bvhData[e+3],r=this.bvhData[e+7],i=n*6,a=r*6,o=this._tlasBounds;this.bvhData[e]=o[i],this.bvhData[e+1]=o[i+1],this.bvhData[e+2]=o[i+2],this.bvhData[e+4]=o[i+3],this.bvhData[e+5]=o[i+4],this.bvhData[e+6]=o[i+5],this.bvhData[e+8]=o[a],this.bvhData[e+9]=o[a+1],this.bvhData[e+10]=o[a+2],this.bvhData[e+12]=o[a+3],this.bvhData[e+13]=o[a+4],this.bvhData[e+14]=o[a+5];let s=t*6;o[s]=Math.min(o[i],o[a]),o[s+1]=Math.min(o[i+1],o[a+1]),o[s+2]=Math.min(o[i+2],o[a+2]),o[s+3]=Math.max(o[i+3],o[a+3]),o[s+4]=Math.max(o[i+4],o[a+4]),o[s+5]=Math.max(o[i+5],o[a+5])}}}scheduleBackgroundRebuild(e,t){if(!this.instanceTable||!this.triangleData)return;let n=B.FLOATS_PER_TRIANGLE;this._rebuildGeneration++;let r=this._rebuildGeneration,i=(e,i,a)=>{let o=this.triangleData.slice(i.triOffset*n,(i.triOffset+i.triCount)*n);this._pendingRebuilds.set(e,a),a.onmessage=n=>{let o=n.data;if(a.terminate(),this._pendingRebuilds.delete(e),o.error){console.error(`Background BLAS rebuild error (mesh ${e}):`,o.error);return}r===this._rebuildGeneration&&this._swapBLAS(e,i,o,t)},a.onerror=t=>{console.error(`Background BLAS rebuild worker error (mesh ${e}):`,t),a.terminate(),this._pendingRebuilds.delete(e)};let s=i.triCount>500;a.postMessage({triangleData:o.buffer,triangleByteOffset:o.byteOffset,triangleByteLength:o.byteLength,triangleCount:i.triCount,depth:this.config.bvhDepth,reportProgress:!1,sharedReorderBuffer:null,treeletOptimization:{enabled:s,size:this.config.treeletSize,passes:this.config.treeletOptimizationPasses,minImprovement:this.config.treeletMinImprovement},reinsertionOptimization:{enabled:this.bvhBuilder.enableReinsertionOptimization,batchSizeRatio:this.bvhBuilder.reinsertionBatchSizeRatio,maxIterations:this.bvhBuilder.reinsertionMaxIterations}},[o.buffer])};for(let t of e){let e=this.instanceTable.entries[t];if(!e)continue;let n=this._pendingRebuilds.get(t);n&&n.terminate();let r;try{r=new Worker(ga,{type:`module`}),i(t,e,r)}catch(n){if(n.name!==`SecurityError`)throw n;Ze(ga).then(n=>i(t,e,n))}}}_swapBLAS(e,t,n,r){let i=n.bvhData,a=i.length/16;if(a!==t.blasNodeCount){console.warn(`Background rebuild: node count mismatch for mesh ${e} (${a} vs ${t.blasNodeCount}), skipping swap`);return}let o=t.blasOffset*16;this.bvhData.set(i,o),this._offsetBLASInPlace(o,a,t.blasOffset,t.triOffset);let s=B.FLOATS_PER_TRIANGLE,c=n.triangles;c&&this.triangleData.set(c,t.triOffset*s);let l=n.originalToBvh;if(l){for(let e=0;e<t.triCount;e++)this.originalToBvhMap[t.triOffset+e]=t.triOffset+l[e];let e=new Uint32Array(t.triCount);for(let n=0;n<t.triCount;n++)e[l[n]]=n;t.bvhToOriginal=e}this.instanceTable.recomputeAABB(e,this.bvhData,this.triangleData),this._refitTLAS(),this._log(`Background BLAS rebuild complete for mesh ${e}`),r?.()}cancelBackgroundRebuilds(){for(let e of this._pendingRebuilds.values())e.terminate();this._pendingRebuilds.clear()}_disposeRefitWorker(){this._refitWorker&&=(this._refitWorker.terminate(),null),this._refitSharedBuffers=null,this.cancelBackgroundRebuilds()}dispose(){this._log(`Disposing resources`),this._disposeRefitWorker(),this._disposeTextures(),this._reset(),this.textureCreator&&=(this.textureCreator.dispose(),null),this.geometryExtractor=null,this.bvhBuilder=null,this.tlasBuilder=null,this._blasRefitter=null}},Xa=class{constructor(){this.lightData={directional:[],rectArea:[],point:[],spot:[]},this.directionalLightCache=[],this.areaLightCache=[],this.pointLightCache=[],this.spotLightCache=[]}clear(){this.lightData.directional=[],this.lightData.rectArea=[],this.lightData.point=[],this.lightData.spot=[],this.directionalLightCache=[],this.areaLightCache=[],this.pointLightCache=[],this.spotLightCache=[]}calculateLightImportance(e,t=`directional`){let n=.2126*e.color.r+.7152*e.color.g+.0722*e.color.b,r=e.intensity*n;if(t===`area`){let t=e.width*e.height;r*=Math.sqrt(t)}else if(t===`point`)r*=Math.sqrt(e.distance||100);else if(t===`spot`){let t=Math.sin(e.angle||Math.PI/4);r*=Math.sqrt(e.distance||100)*t}return r}addDirectionalLight(e){if(e.intensity<=0)return;e.updateMatrixWorld();let t=e.getWorldPosition(new r.Vector3),n;if(e.target){e.target.updateMatrixWorld();let i=e.target.getWorldPosition(new r.Vector3);n=t.sub(i).normalize()}else n=t.normalize();let i=this.calculateLightImportance(e,`directional`),a=e.userData.angle||e.angle||0;this.directionalLightCache.push({data:[n.x,n.y,n.z,e.color.r,e.color.g,e.color.b,e.intensity,a],importance:i,light:e})}addRectAreaLight(e){if(e.intensity<=0)return;e.updateMatrixWorld();let t=e.getWorldPosition(new r.Vector3),n=e.getWorldQuaternion(new r.Quaternion),i=e.getWorldScale(new r.Vector3),a=e.width*i.x*.5,o=e.height*i.y*.5,s=new r.Vector3(a,0,0).applyQuaternion(n),c=new r.Vector3(0,-o,0).applyQuaternion(n),l=this.calculateLightImportance(e,`area`);this.areaLightCache.push({data:[t.x,t.y,t.z,s.x,s.y,s.z,c.x,c.y,c.z,e.color.r,e.color.g,e.color.b,e.intensity],importance:l,light:e})}addPointLight(e){if(e.intensity<=0)return;e.updateMatrixWorld();let t=e.getWorldPosition(new r.Vector3),n=this.calculateLightImportance(e,`point`);this.pointLightCache.push({data:[t.x,t.y,t.z,e.color.r,e.color.g,e.color.b,e.intensity,e.distance||0,e.decay===void 0?2:e.decay],importance:n,light:e})}addSpotLight(e){if(e.intensity<=0)return;e.updateMatrixWorld();let t=e.getWorldPosition(new r.Vector3),n=(e.target?e.target.getWorldPosition(new r.Vector3):new r.Vector3(0,0,-1)).sub(t).normalize(),i=this.calculateLightImportance(e,`spot`);this.spotLightCache.push({data:[t.x,t.y,t.z,n.x,n.y,n.z,e.color.r,e.color.g,e.color.b,e.intensity,e.angle||Math.PI/4,e.penumbra||0,e.distance||0,e.decay===void 0?2:e.decay],importance:i,light:e})}preprocessLights(){this.directionalLightCache.sort((e,t)=>t.importance-e.importance),this.areaLightCache.sort((e,t)=>t.importance-e.importance),this.pointLightCache.sort((e,t)=>t.importance-e.importance),this.spotLightCache.sort((e,t)=>t.importance-e.importance),this.lightData.directional=[],this.lightData.rectArea=[],this.lightData.point=[],this.lightData.spot=[],this.directionalLightCache.forEach(e=>{this.lightData.directional.push(...e.data)}),this.areaLightCache.forEach(e=>{this.lightData.rectArea.push(...e.data)}),this.pointLightCache.forEach(e=>{this.lightData.point.push(...e.data)}),this.spotLightCache.forEach(e=>{this.lightData.spot.push(...e.data)}),this.areaLightCache.length>0&&console.log(`Preprocessed ${this.areaLightCache.length} area lights by importance`),this.pointLightCache.length>0&&console.log(`Preprocessed ${this.pointLightCache.length} point lights by importance`),this.spotLightCache.length>0&&console.log(`Preprocessed ${this.spotLightCache.length} spot lights by importance`)}updateShaderUniforms(e){let t=Math.floor(this.lightData.directional.length/8),n=Math.floor(this.lightData.rectArea.length/13),r=Math.floor(this.lightData.point.length/9),i=Math.floor(this.lightData.spot.length/14);e.defines.MAX_DIRECTIONAL_LIGHTS=t,e.defines.MAX_AREA_LIGHTS=n,e.defines.MAX_POINT_LIGHTS=r,e.defines.MAX_SPOT_LIGHTS=i,e.uniforms.directionalLights.value=new Float32Array(this.lightData.directional),e.uniforms.areaLights.value=new Float32Array(this.lightData.rectArea),e.uniforms.pointLights.value=new Float32Array(this.lightData.point),e.uniforms.spotLights.value=new Float32Array(this.lightData.spot),e.needsUpdate=!0}processSceneLights(e,t){this.clear(),e.traverse(e=>{e.isDirectionalLight?this.addDirectionalLight(e):e.isRectAreaLight?this.addRectAreaLight(e):e.isPointLight?this.addPointLight(e):e.isSpotLight&&this.addSpotLight(e)}),this.preprocessLights(),this.updateShaderUniforms(t)}getLightStatistics(){return{directionalLights:this.directionalLightCache.map(e=>({intensity:e.light.intensity,importance:e.importance,color:e.light.color})),areaLights:this.areaLightCache.map(e=>({intensity:e.light.intensity,importance:e.importance,color:e.light.color,size:e.light.width*e.light.height}))}}},Za=`https://assets.rayzee.atulmourya.com/noise/stbn_scalar_atlas.png`,Qa=`https://assets.rayzee.atulmourya.com/noise/stbn_vec2_atlas.png`,$a=4,eo=class extends I{constructor(e,t,n,i={}){super(`PathTracer`,{...i,executionMode:F.ALWAYS});let a=i.width||1920,o=i.height||1080;this.camera=n,this.width=a,this.height=o,this.renderer=e,this.scene=t,this.tileManager=new ve(a,o,z.tiles),this.sdfs=new Ya,this.lightSerializer=new Xa,this.accumulationEnabled=!0,this.isComplete=!1,this.cameras=[],this.performanceMonitor=je(),this.completionThreshold=0,this.renderLimitMode=`frames`,this._initDataTextures(),this.storageTextures=new Ne(0,0),this.uniforms=new We(a,o),this._defineUniformGetters(),this.materialData=new Xe(this.sdfs),this.materialData.callbacks.onReset=()=>this.reset(),this.materialData.callbacks.getTriangleData=()=>({array:this.triangleStorageAttr?.array,count:this.triangleCount}),this.materialData.callbacks.onTriangleDataChanged=()=>{this.triangleStorageAttr&&(this.triangleStorageAttr.needsUpdate=!0)},this.environment=new Dt(this.scene,this.uniforms),this.environment.callbacks.onReset=()=>this.reset(),this.environment.callbacks.getSceneTextureNodes=()=>this.shaderBuilder.getSceneTextureNodes(),this.shaderBuilder=new fa,this._initRenderingState(),this.setupBlueNoise(),this.tempVector2=new r.Vector2,this.lastCameraMatrix=new r.Matrix4,this.lastProjectionMatrix=new r.Matrix4,this.lastRenderMode=-1,this.tileCompletionFrame=0,this.renderModeChangeTimeout=null,this.renderModeChangeDelay=50,this.pendingRenderMode=null,this.adaptiveSamplingFrameToggle=!1,this.lastInteractionModeState=!1,this.cameraChanged=!1,this.tileChanged=!1,this.updateCompletionThreshold()}_initDataTextures(){this.triangleStorageAttr=null,this.triangleStorageNode=null,this.triangleCount=0,this.bvhStorageAttr=null,this.bvhStorageNode=null,this.bvhNodeCount=0,this.directionalLightsData=null,this.pointLightsData=null,this.spotLightsData=null,this.areaLightsData=null,this.stbnScalarTexture=null,this.stbnVec2Texture=null,this.lightStorageAttr=new t.StorageInstancedBufferAttribute(new Float32Array(16),4),this.lightStorageNode=(0,n.storage)(this.lightStorageAttr,`vec4`,1).toReadOnly(),this._lbvhDataCache=null,this._emissiveDataCache=null,this._instanceTable=null,this.adaptiveSamplingTexture=null,this.spheres=[]}_defineUniformGetters(){let e=this.uniforms;for(let t of e.keys())Object.defineProperty(this,t,{get:()=>e.get(t),configurable:!0});let t=e.getLightBufferNodes();for(let[e,n]of Object.entries(t))Object.defineProperty(this,`${e}LightsBufferNode`,{get:()=>n,configurable:!0})}_initRenderingState(){this.isReady=!1,this.frameCount=0}_initCameraOptimizer(){let e=this;this.cameraOptimizer=new ye(this.renderer,{uniforms:{maxBounceCount:{get value(){return e.maxBounces.value},set value(t){e.maxBounces.value=t}},numRaysPerPixel:{get value(){return e.samplesPerPixel.value},set value(t){e.samplesPerPixel.value=t}},useAdaptiveSampling:{get value(){return e.useAdaptiveSampling.value},set value(t){e.useAdaptiveSampling.value=t}},useEnvMapIS:{get value(){return e.useEnvMapIS.value},set value(t){e.useEnvMapIS.value=t}},enableAccumulation:{get value(){return e.enableAccumulation.value},set value(t){e.enableAccumulation.value=t}},enableEmissiveTriangleSampling:{get value(){return e.enableEmissiveTriangleSampling.value},set value(t){e.enableEmissiveTriangleSampling.value=t}},cameraIsMoving:{get value(){return e.cameraIsMoving.value},set value(t){e.cameraIsMoving.value=t}}}},{enabled:z.interactionModeEnabled,qualitySettings:{maxBounceCount:1,numRaysPerPixel:1,useAdaptiveSampling:!1,useEnvMapIS:!1,enableAccumulation:!1,enableEmissiveTriangleSampling:!1},onReset:()=>{this.reset(),this.emit(`pathtracer:viewpointChanged`)}})}setupBlueNoise(){let e=new r.TextureLoader;e.setCrossOrigin(`anonymous`);let t=e=>(e.minFilter=r.NearestFilter,e.magFilter=r.NearestFilter,e.wrapS=r.RepeatWrapping,e.wrapT=r.RepeatWrapping,e.generateMipmaps=!1,e);e.load(Za,e=>{this.stbnScalarTexture=t(e),ee.value=e,console.log(`PathTracer: STBN scalar atlas loaded ${e.image.width}x${e.image.height}`)}),e.load(Qa,e=>{this.stbnVec2Texture=t(e),te.value=e,console.log(`PathTracer: STBN vec2 atlas loaded ${e.image.width}x${e.image.height}`)})}setupEventListeners(){this.on(`pipeline:reset`,()=>{this.reset()}),this.on(`pipeline:resize`,e=>{e&&e.width&&e.height&&this.setSize(e.width,e.height)}),this.on(`pathtracer:setCompletionThreshold`,e=>{e&&e.threshold!==void 0&&(this.completionThreshold=e.threshold)})}async build(e){this.dispose(),this.scene=e,await this.sdfs.buildBVH(e),this.cameras=this.sdfs.cameras,this.materialData.injectMaterialFeatureDefines(),this.updateSceneUniforms(),this.updateLights(),this._initCameraOptimizer(),this.setupMaterial()}updateSceneUniforms(){this.setTriangleData(this.sdfs.triangleData,this.sdfs.triangleCount),this.setBVHData(this.sdfs.bvhData),this.setInstanceTable(this.sdfs.instanceTable),this.materialData.setMaterialData(this.sdfs.materialData),this.totalTriangleCount.value=this.sdfs.triangleCount||0,this.materialData.loadTexturesFromSdfs(),this.sdfs.emissiveTriangleData?this.setEmissiveTriangleData(this.sdfs.emissiveTriangleData,this.sdfs.emissiveTriangleCount||0):this.emissiveTriangleCount.value=0,this.sdfs.lightBVHNodeData?this.setLightBVHData(this.sdfs.lightBVHNodeData,this.sdfs.lightBVHNodeCount||0):this.lightBVHNodeCount.value=0,this._meshRefs=this._collectMeshRefs(this.scene),this.setMeshVisibilityData(this._meshRefs),this.spheres=this.sdfs.spheres||[]}updateLights(){let e={uniforms:{directionalLights:{value:null},pointLights:{value:null},spotLights:{value:null},areaLights:{value:null}},defines:{}};if(this.lightSerializer.processSceneLights(this.scene,e),this.directionalLightsData=e.uniforms.directionalLights.value,this.pointLightsData=e.uniforms.pointLights.value,this.spotLightsData=e.uniforms.spotLights.value,this.areaLightsData=e.uniforms.areaLights.value,this.hasSun.value){let t=this.environment.envParams.skySunIntensity*950,n={intensity:t,color:{r:1,g:1,b:1},userData:{angle:this.sunAngularSize.value},updateMatrixWorld:()=>{},getWorldPosition:e=>{let t=this.sunDirection.value;return e.set(t.x,t.y,t.z).multiplyScalar(1e10)}};this.lightSerializer.addDirectionalLight(n),this.lightSerializer.preprocessLights(),this.lightSerializer.updateShaderUniforms(e),this.directionalLightsData=e.uniforms.directionalLights.value,console.log(`Sun added as directional light (intensity: ${t.toFixed(2)})`)}this._updateLightBufferNodes()}_updateLightBufferNodes(){this.directionalLightsData&&this.directionalLightsData.length>0?(this.directionalLightsBufferNode.array=Array.from(this.directionalLightsData),this.numDirectionalLights.value=Math.floor(this.directionalLightsData.length/8)):this.numDirectionalLights.value=0,this.areaLightsData&&this.areaLightsData.length>0?(this.areaLightsBufferNode.array=Array.from(this.areaLightsData),this.numAreaLights.value=Math.floor(this.areaLightsData.length/13)):this.numAreaLights.value=0,this.pointLightsData&&this.pointLightsData.length>0?(this.pointLightsBufferNode.array=Array.from(this.pointLightsData),this.numPointLights.value=Math.floor(this.pointLightsData.length/9)):this.numPointLights.value=0,this.spotLightsData&&this.spotLightsData.length>0?(this.spotLightsBufferNode.array=Array.from(this.spotLightsData),this.numSpotLights.value=Math.floor(this.spotLightsData.length/14)):this.numSpotLights.value=0}reset(){this.frameCount=0,this.frame.value=0,this.hasPreviousAccumulated.value=0,this.storageTextures.currentTarget=0,this.tileManager.spiralOrder=this.tileManager.generateSpiralOrder(this.tileManager.tiles),this.updateCompletionThreshold(),this.isComplete=!1,this.performanceMonitor?.reset(),this.lastRenderMode=-1,this.tileCompletionFrame=0,this.lastInteractionModeState=!1}setTileCount(e){this.tileManager.setTileCount(e),this.updateCompletionThreshold(),this.reset()}setSize(e,t){this.width=e,this.height=t,this.resolution.value.set(e,t),this.tileManager.setSize(e,t),this.createStorageTextures(e,t),this.shaderBuilder.setSize(e,t)}setAccumulationEnabled(e){this.accumulationEnabled=e,this.enableAccumulation.value=+!!e}enterInteractionMode(){this.cameraOptimizer?.enterInteractionMode()}setInteractionModeEnabled(e){this.cameraOptimizer?.setInteractionModeEnabled(e)}get tiles(){return this.tileManager.tiles}get interactionMode(){return this.cameraOptimizer?.isInInteractionMode()??!1}setTriangleData(e,r){if(!e)return;let i=e.length/4;this.triangleStorageNode?(this.triangleStorageAttr=new t.StorageInstancedBufferAttribute(e,4),this.triangleStorageNode.value=this.triangleStorageAttr,this.triangleStorageNode.bufferCount=i):(this.triangleStorageAttr=new t.StorageInstancedBufferAttribute(e,4),this.triangleStorageNode=(0,n.storage)(this.triangleStorageAttr,`vec4`,i).toReadOnly()),this.triangleCount=r,console.log(`PathTracer: ${this.triangleCount} triangles (storage buffer)`)}setBVHData(e){if(!e)return;let r=e.length/4;this.bvhStorageNode?(this.bvhStorageAttr=new t.StorageInstancedBufferAttribute(e,4),this.bvhStorageNode.value=this.bvhStorageAttr,this.bvhStorageNode.bufferCount=r):(this.bvhStorageAttr=new t.StorageInstancedBufferAttribute(e,4),this.bvhStorageNode=(0,n.storage)(this.bvhStorageAttr,`vec4`,r).toReadOnly()),this.bvhNodeCount=Math.floor(r/$a),console.log(`PathTracer: ${this.bvhNodeCount} BVH nodes (storage buffer)`)}setInstanceTable(e){this._instanceTable=e}setMeshVisibilityData(e){if(!(!e||e.length===0||!this._instanceTable)){for(let t=0;t<e.length;t++)this._patchTLASLeafVisibility(t,this._isWorldVisible(e[t]));this.bvhStorageAttr&&(this.bvhStorageAttr.needsUpdate=!0)}}updateMeshVisibility(e,t){this._patchTLASLeafVisibility(e,t)&&this.bvhStorageAttr&&(this.bvhStorageAttr.needsUpdate=!0)}updateAllMeshVisibility(){if(!(!this._meshRefs||!this._instanceTable)){for(let e=0;e<this._meshRefs.length;e++)this._patchTLASLeafVisibility(e,this._isWorldVisible(this._meshRefs[e]));this.bvhStorageAttr&&(this.bvhStorageAttr.needsUpdate=!0)}}_patchTLASLeafVisibility(e,t){let n=this._instanceTable?.entries?.[e];return!n||n.tlasLeafIndex<0||!this.bvhStorageAttr?!1:(n.visible=t,this.bvhStorageAttr.array[n.tlasLeafIndex*16+2]=+!!t,!0)}_collectMeshRefs(e){if(!e)return[];let t=[];return e.traverse(e=>{e.isMesh&&e.userData.meshIndex!==void 0&&(t[e.userData.meshIndex]=e)}),t}_isWorldVisible(e){for(;e;){if(!e.visible)return!1;e=e.parent}return!0}_updateStorageBuffer(e,t){e&&(e.array.set(t),e.needsUpdate=!0)}updateTriangleData(e){this._updateStorageBuffer(this.triangleStorageAttr,e)}updateBVHData(e){this._updateStorageBuffer(this.bvhStorageAttr,e)}updateBufferRanges(e,t){if(this.triangleStorageAttr&&e.length>0){this.triangleStorageAttr.clearUpdateRanges();for(let t of e)this.triangleStorageAttr.addUpdateRange(t.offset,t.count);this.triangleStorageAttr.version++}if(this.bvhStorageAttr&&t.length>0){this.bvhStorageAttr.clearUpdateRanges();for(let e of t)this.bvhStorageAttr.addUpdateRange(e.offset,e.count);this.bvhStorageAttr.version++}}createStorageTextures(e,t){this.storageTextures.writeColor?this.storageTextures.setSize(e,t):this.storageTextures.create(e,t),this.resolution.value.set(e,t)}setupMaterial(){if(this.cameraOptimizer||this._initCameraOptimizer(),!this.triangleStorageNode){console.error(`PathTracer: Triangle data required`);return}if(!this.bvhStorageNode){console.error(`PathTracer: BVH data required`);return}if(this.isReady&&this.shaderBuilder.getSceneTextureNodes()){this.shaderBuilder.updateSceneTextures(this);return}this._ensureStorageTextures(),this.shaderBuilder.setupCompute({stage:this,storageTextures:this.storageTextures}),this.isReady=!0}_ensureStorageTextures(){let e=this.renderer.domElement,t=Math.max(1,e.width||this.width),n=Math.max(1,e.height||this.height);this.storageTextures.ensureSize(t,n)&&this.resolution.value.set(t,n)}render(e,t){if(!this.isReady)return;if(this.isComplete||this.frameCount>=this.completionThreshold){this.isComplete||=!0;return}if(this.performanceMonitor?.start(),e&&this.shaderBuilder.adaptiveSamplingTexNode){let t=e.getTexture(`adaptiveSampling:output`);t&&(this.shaderBuilder.adaptiveSamplingTexNode.value=t)}let n=this.frameCount,r=this.renderMode.value,i=null,a=null;r===1&&n===0&&(i=this.maxBounces.value,a=this.samplesPerPixel.value,this.maxBounces.value=1,this.samplesPerPixel.value=1),this._handleResize(),this.manageASVGFForRenderMode(r,n);let o=this.tileManager.handleTileRendering(this.renderer,r,n,null);if(e&&e.setState(`tileRenderingComplete`,o.isCompleteCycle),o.tileIndex>=0){let e=this.tileManager.calculateTileBounds(o.tileIndex,this.tileManager.tiles,this.width,this.height);this.emit(`tile:changed`,{tileIndex:o.tileIndex,tileBounds:e,renderMode:r}),this.tileChanged=!0}this.cameraChanged=this._updateCameraUniforms(),this.cameraOptimizer?.updateInteractionMode(this.cameraChanged),this._updateAccumulationUniforms(n,r),this.frame.value=n,o.tileIndex>=0&&o.tileBounds?this.shaderBuilder.setTileDispatch(o.tileBounds.x,o.tileBounds.y,o.tileBounds.width,o.tileBounds.height):this.shaderBuilder.setFullScreenDispatch();let s=this.storageTextures.getReadTextures();this.shaderBuilder.prevColorTexNode&&(this.shaderBuilder.prevColorTexNode.value=s.color,this.shaderBuilder.prevNormalDepthTexNode.value=s.normalDepth,this.shaderBuilder.prevAlbedoTexNode.value=s.albedo),this.renderer.compute(this.shaderBuilder.computeNode),this.storageTextures.copyToReadTargets(this.renderer);let c=this.storageTextures.getReadTextures();e&&this._publishTexturesToContext(e,c),this._emitStateEvents(),this.cameraOptimizer?.isInInteractionMode()||this.frameCount++,i!==null&&(this.maxBounces.value=i),a!==null&&(this.samplesPerPixel.value=a),this.performanceMonitor?.end()}_handleResize(){let{width:e,height:t}=this.renderer.domElement;(e!==this.storageTextures.renderWidth||t!==this.storageTextures.renderHeight)&&(this.createStorageTextures(e,t),this.shaderBuilder.setSize(e,t),this.frameCount=0),this.resolution.value.set(e,t)}_matricesApproxEqual(e,t,n=1e-10){let r=e.elements,i=t.elements;for(let e=0;e<16;e++)if(Math.abs(r[e]-i[e])>n)return!1;return!0}_updateCameraUniforms(){return!this._matricesApproxEqual(this.lastCameraMatrix,this.camera.matrixWorld)||!this._matricesApproxEqual(this.lastProjectionMatrix,this.camera.projectionMatrixInverse)?(this.cameraWorldMatrix.value.copy(this.camera.matrixWorld),this.cameraViewMatrix.value.copy(this.camera.matrixWorldInverse),this.cameraProjectionMatrix.value.copy(this.camera.projectionMatrix),this.cameraProjectionMatrixInverse.value.copy(this.camera.projectionMatrixInverse),this.lastCameraMatrix.copy(this.camera.matrixWorld),this.lastProjectionMatrix.copy(this.camera.projectionMatrixInverse),!0):!1}_updateAccumulationUniforms(e,t){let n=this.cameraOptimizer?.isInInteractionMode()??!1;this.lastInteractionModeState=n,this.accumulationEnabled?n?(this.accumulationAlpha.value=1,this.hasPreviousAccumulated.value=0):(this.accumulationAlpha.value=Ae(e,t,this.tileManager.totalTilesCache,!1),this.hasPreviousAccumulated.value=+(e>0)):(this.accumulationAlpha.value=1,this.hasPreviousAccumulated.value=0)}_publishTexturesToContext(e,t){e.setTexture(`pathtracer:color`,t.color),e.setTexture(`pathtracer:normalDepth`,t.normalDepth),e.setTexture(`pathtracer:albedo`,t.albedo),e.setState(`interactionMode`,this.cameraOptimizer?.isInInteractionMode()??!1),e.setState(`renderMode`,this.renderMode.value),e.setState(`tiles`,this.tileManager.tiles)}_emitStateEvents(){this.emit(`pathtracer:frameComplete`,{frame:this.frameCount,isComplete:this.isComplete}),this.cameraChanged&&=(this.emit(`camera:moved`),!1)}updateCompletionThreshold(){let e=this.renderMode.value,t=this.maxSamples.value;this.renderLimitMode===`time`?this.completionThreshold=1/0:this.completionThreshold=ke(e,t,this.tileManager.totalTilesCache)}setRenderLimitMode(e){this.renderLimitMode=e,this.updateCompletionThreshold()}manageASVGFForRenderMode(e,t){e!==this.lastRenderMode&&(this.renderModeChangeTimeout&&clearTimeout(this.renderModeChangeTimeout),this.pendingRenderMode=e,this.renderModeChangeTimeout=setTimeout(()=>{this.pendingRenderMode!==null&&this.pendingRenderMode!==this.lastRenderMode&&(this.lastRenderMode=this.pendingRenderMode,this._onRenderModeChanged(this.pendingRenderMode)),this.renderModeChangeTimeout=null,this.pendingRenderMode=null},this.renderModeChangeDelay)),e===1?this._handleTiledASVGF(t):this._handleFullQuadASVGF()}_onRenderModeChanged(e){e===1?this.emit(`asvgf:updateParameters`,{enableDebug:!1,temporalAlpha:.15}):this.emit(`asvgf:updateParameters`,{temporalAlpha:.1}),this.emit(`asvgf:reset`)}_handleTiledASVGF(e){let t=e===0,n=(t?-1:(e-1)%this.tileManager.totalTilesCache)==this.tileManager.totalTilesCache-1;t?this.emit(`asvgf:setTemporal`,{enabled:!0}):n?(this.emit(`asvgf:setTemporal`,{enabled:!0}),this.tileCompletionFrame=e):this.emit(`asvgf:setTemporal`,{enabled:!1})}_handleFullQuadASVGF(){this.emit(`asvgf:setTemporal`,{enabled:!0})}setUniform(e,t){this.uniforms.set(e,t)}setBlueNoiseTexture(e){this.stbnScalarTexture=e,e&&(ee.value=e)}_rebuildLightBuffer(){let e=this._lbvhDataCache,n=this._emissiveDataCache,r=e?e.length:0,i=n?n.length:0,a=Math.max(r+i,4),o=new Float32Array(a);e&&o.set(e,0),n&&o.set(n,r),this.lightStorageAttr=new t.StorageInstancedBufferAttribute(o,4),this.lightStorageNode.value=this.lightStorageAttr,this.lightStorageNode.bufferCount=o.length/4,this.emissiveVec4Offset.value=(this.lightBVHNodeCount.value||0)*4}setEmissiveTriangleData(e,t,n=0){e&&(this._emissiveDataCache=e,this.emissiveTriangleCount.value=t,this.emissiveTotalPower.value=n,this._rebuildLightBuffer(),console.log(`PathTracer: ${t} emissive triangles, totalPower=${n.toFixed(4)} (storage buffer)`))}setLightBVHData(e,t){e&&(this._lbvhDataCache=e,this.lightBVHNodeCount.value=t,this._rebuildLightBuffer(),console.log(`PathTracer: Light BVH ${t} nodes`))}updateUniforms(e){let t=!1;for(let[n,r]of Object.entries(e))this[n]&&this[n].value!==void 0&&this[n].value!==r&&(this[n].value=r,t=!0);t&&this.reset()}async rebuildMaterials(e){if(!this.sdfs)throw Error(`Scene not built yet. Call build() first.`);try{console.log(`PathTracer: Starting material rebuild...`),await this.sdfs.rebuildMaterials(e),this.updateSceneUniforms(),this.shaderBuilder.updateSceneTextures(this),this.updateLights(),this.reset(),console.log(`PathTracer materials rebuilt successfully`)}catch(e){console.error(`Error rebuilding PathTracer materials:`,e);try{console.warn(`Attempting recovery by resetting path tracer...`),this.reset()}catch(e){console.error(`Recovery failed:`,e)}throw e}}dispose(){this.renderModeChangeTimeout&&=(clearTimeout(this.renderModeChangeTimeout),null),this.tileManager?.dispose(),this.cameraOptimizer?.dispose(),this.materialData?.dispose(),this.environment?.dispose(),this.shaderBuilder?.dispose(),this.uniforms?.dispose(),this.storageTextures?.dispose(),this.stbnScalarTexture?.dispose(),this.stbnVec2Texture?.dispose(),this.placeholderTexture?.dispose(),this.triangleStorageAttr=null,this.triangleStorageNode=null,this.bvhStorageAttr=null,this.bvhStorageNode=null,this.placeholderTexture=null,this.isReady=!1}},to=class extends I{constructor(e,i={}){super(`NormalDepth`,{...i,executionMode:F.ALWAYS}),this.renderer=e,this.pathTracer=i.pathTracer,this._dirty=!0,this.cameraWorldMatrix=(0,n.uniform)(new r.Matrix4,`mat4`),this.cameraProjectionMatrixInverse=(0,n.uniform)(new r.Matrix4,`mat4`),this.resolutionWidth=(0,n.uniform)(i.width||1),this.resolutionHeight=(0,n.uniform)(i.height||1);let a=i.width||1,o=i.height||1;this._outputStorageTex=new t.StorageTexture(a,o),this._outputStorageTex.type=r.HalfFloatType,this._outputStorageTex.format=r.RGBAFormat,this._outputStorageTex.minFilter=r.NearestFilter,this._outputStorageTex.magFilter=r.NearestFilter,this.renderTarget=new t.RenderTarget(a,o,{type:r.HalfFloatType,format:r.RGBAFormat,minFilter:r.NearestFilter,magFilter:r.NearestFilter,depthBuffer:!1,stencilBuffer:!1}),this._dispatchX=Math.ceil(a/8),this._dispatchY=Math.ceil(o/8),this._triStorageNode=null,this._bvhStorageNode=null,this._matStorageNode=null,this._lastTriAttr=null,this._lastBvhAttr=null,this._lastMatAttr=null,this._computeNode=null,this._computeBuilt=!1}setupEventListeners(){this.on(`camera:moved`,()=>{this._dirty=!0}),this.on(`pipeline:reset`,()=>{this._dirty=!0})}_syncStorageBuffers(){let e=this.pathTracer;if(!e)return!1;let t=e.materialData.materialStorageAttr,r=e.triangleStorageAttr&&e.triangleStorageAttr!==this._lastTriAttr,i=e.bvhStorageAttr&&e.bvhStorageAttr!==this._lastBvhAttr,a=t&&t!==this._lastMatAttr;return(r||i||a)&&(this._computeNode?.dispose?.(),this._computeNode=null,this._computeBuilt=!1,this._triStorageNode=null,this._bvhStorageNode=null,this._matStorageNode=null,this._dirty=!0),e.triangleStorageAttr&&!this._triStorageNode&&(this._triStorageNode=(0,n.storage)(e.triangleStorageAttr,`vec4`,e.triangleStorageAttr.count).toReadOnly()),e.bvhStorageAttr&&!this._bvhStorageNode&&(this._bvhStorageNode=(0,n.storage)(e.bvhStorageAttr,`vec4`,e.bvhStorageAttr.count).toReadOnly()),t&&!this._matStorageNode&&(this._matStorageNode=(0,n.storage)(t,`vec4`,t.count).toReadOnly()),this._lastTriAttr=e.triangleStorageAttr||this._lastTriAttr,this._lastBvhAttr=e.bvhStorageAttr||this._lastBvhAttr,this._lastMatAttr=t||this._lastMatAttr,!!(this._triStorageNode&&this._bvhStorageNode&&this._matStorageNode)}_buildCompute(){let e=this._triStorageNode,t=this._bvhStorageNode,r=this._matStorageNode,i=this.cameraWorldMatrix,a=this.cameraProjectionMatrixInverse,o=this.resolutionWidth,s=this.resolutionHeight,c=this._outputStorageTex;this._computeNode=(0,n.Fn)(([i,a])=>{let l=(0,n.int)(n.workgroupId.x).mul(8).add((0,n.int)(n.localId.x)),u=(0,n.int)(n.workgroupId.y).mul(8).add((0,n.int)(n.localId.y));(0,n.If)(l.lessThan((0,n.int)(o)).and(u.lessThan((0,n.int)(s))),()=>{let d=(0,n.vec3)((0,n.float)(l).add(.5).div(o).mul(2).sub(1),(0,n.float)(u).add(.5).div(s).mul(2).sub(1).negate(),1),f=a.mul((0,n.vec4)(d,1)),p=(0,n.normalize)((0,n.mat3)(i[0].xyz,i[1].xyz,i[2].xyz).mul(f.xyz.div(f.w))),m=Ot({origin:(0,n.vec3)(i[3]),direction:p}),h=jt.wrap(xn(m,t,e,r)),g=h.normal.mul(.5).add(.5),_=h.dst,v=h.didHit.select((0,n.vec4)(g,_),(0,n.vec4)(0,0,0,(0,n.float)(1e6)));(0,n.textureStore)(c,(0,n.uvec2)((0,n.uint)(l),(0,n.uint)(u)),v).toWriteOnly()})})(i,a).compute([this._dispatchX,this._dispatchY,1],[8,8,1]),this._computeBuilt=!0}render(e){if(!this.enabled||!this._syncStorageBuffers())return;this._computeBuilt||this._buildCompute();let t=this.pathTracer;if(t&&(this.cameraWorldMatrix.value.copy(t.uniforms.get(`cameraWorldMatrix`).value),this.cameraProjectionMatrixInverse.value.copy(t.uniforms.get(`cameraProjectionMatrixInverse`).value)),!this._dirty&&this.renderTarget.texture){e.setTexture(`pathtracer:normalDepth`,this.renderTarget.texture);return}let n=e.getTexture(`pathtracer:color`);if(n&&n.image){let e=n.image;e.width>0&&e.height>0&&(e.width!==this.renderTarget.width||e.height!==this.renderTarget.height)&&this.setSize(e.width,e.height)}this.renderer.compute(this._computeNode),this.renderer.copyTextureToTexture(this._outputStorageTex,this.renderTarget.texture),e.setTexture(`pathtracer:normalDepth`,this.renderTarget.texture),this._dirty=!1}reset(){this._dirty=!0}setSize(e,t){this._outputStorageTex.setSize(e,t),this.renderTarget.setSize(e,t),this.renderTarget.texture.needsUpdate=!0,this.resolutionWidth.value=e,this.resolutionHeight.value=t,this._dispatchX=Math.ceil(e/8),this._dispatchY=Math.ceil(t/8),this._computeNode&&(this._computeNode.dispatchSize=[this._dispatchX,this._dispatchY,1]),this._dirty=!0}dispose(){this._computeNode?.dispose(),this._outputStorageTex?.dispose(),this.renderTarget?.dispose()}},no=class extends I{constructor(e,i,a={}){super(`MotionVector`,{...a,executionMode:F.ALWAYS}),this.renderer=e,this.camera=i,this.pathTracer=a.pathTracer||null;let o=a.width||1,s=a.height||1;this.prevViewProjectionMatrix=new r.Matrix4,this.currentViewProjectionMatrix=new r.Matrix4,this.matricesInitialized=!1,this.isFirstFrame=!0,this.frameCount=0,this.cameraWorldMatrix=(0,n.uniform)(new r.Matrix4,`mat4`),this.cameraProjectionMatrixInverse=(0,n.uniform)(new r.Matrix4,`mat4`),this.prevVP=(0,n.uniform)(new r.Matrix4,`mat4`),this.isFirstFrameU=(0,n.uniform)(1),this.deltaTime=(0,n.uniform)(1/60),this.velocityScale=(0,n.uniform)(1),this.resolutionWidth=(0,n.uniform)(o),this.resolutionHeight=(0,n.uniform)(s),this._normalDepthTexNode=new t.TextureNode,this._screenSpaceStorageTex=new t.StorageTexture(o,s),this._screenSpaceStorageTex.type=r.HalfFloatType,this._screenSpaceStorageTex.format=r.RGBAFormat,this._screenSpaceStorageTex.minFilter=r.NearestFilter,this._screenSpaceStorageTex.magFilter=r.NearestFilter,this._worldSpaceStorageTex=new t.StorageTexture(o,s),this._worldSpaceStorageTex.type=r.HalfFloatType,this._worldSpaceStorageTex.format=r.RGBAFormat,this._worldSpaceStorageTex.minFilter=r.NearestFilter,this._worldSpaceStorageTex.magFilter=r.NearestFilter;let c={type:r.HalfFloatType,format:r.RGBAFormat,minFilter:r.NearestFilter,magFilter:r.NearestFilter,depthBuffer:!1,stencilBuffer:!1};this.screenSpaceTarget=new t.RenderTarget(o,s,c),this.worldSpaceTarget=new t.RenderTarget(o,s,c),this._dispatchX=Math.ceil(o/16),this._dispatchY=Math.ceil(s/16),this._buildScreenSpaceCompute(),this._buildWorldSpaceCompute()}_buildScreenSpaceCompute(){let e=this._normalDepthTexNode,t=this.cameraWorldMatrix,r=this.cameraProjectionMatrixInverse,i=this.prevVP,a=this.resolutionWidth,o=this.resolutionHeight,s=this._screenSpaceStorageTex;this._screenSpaceComputeNode=(0,n.Fn)(([t,r])=>{let c=(0,n.int)(n.workgroupId.x).mul(16).add((0,n.int)(n.localId.x)),l=(0,n.int)(n.workgroupId.y).mul(16).add((0,n.int)(n.localId.y));(0,n.If)(c.lessThan((0,n.int)(a)).and(l.lessThan((0,n.int)(o))),()=>{let u=(0,n.textureLoad)(e,(0,n.ivec2)(c,l)).w,d=(0,n.vec2)((0,n.float)(c).add(.5).div(a),(0,n.float)(l).add(.5).div(o)),f=(0,n.vec4)(0,0,u,1).toVar();(0,n.If)(u.lessThan((0,n.float)(1e5)),()=>{let e=(0,n.vec3)((0,n.float)(c).add(.5).div(a).mul(2).sub(1),(0,n.float)(l).add(.5).div(o).mul(2).sub(1).negate(),1),s=r.mul((0,n.vec4)(e,1)),p=(0,n.normalize)((0,n.mat3)(t[0].xyz,t[1].xyz,t[2].xyz).mul(s.xyz.div(s.w))),m=(0,n.vec3)(t[3]).add(p.mul(u)),h=i.mul((0,n.vec4)(m,1)),g=h.xy.div(h.w),_=(0,n.vec2)(g.x.mul(.5).add(.5),g.y.mul(-.5).add(.5)),v=d.sub(_),y=_.x.greaterThanEqual(0).and(_.x.lessThanEqual(1)).and(_.y.greaterThanEqual(0)).and(_.y.lessThanEqual(1));f.assign(y.select((0,n.vec4)(v,u,1),(0,n.vec4)((0,n.float)(1e3),(0,n.float)(1e3),u,0)))}),(0,n.textureStore)(s,(0,n.uvec2)((0,n.uint)(c),(0,n.uint)(l)),f).toWriteOnly()})})(t,r).compute([this._dispatchX,this._dispatchY,1],[16,16,1])}_buildWorldSpaceCompute(){let e=this._normalDepthTexNode,t=this.cameraWorldMatrix,r=this.cameraProjectionMatrixInverse,i=this.prevVP,a=this.isFirstFrameU,o=this.deltaTime,s=this.velocityScale,c=this.resolutionWidth,l=this.resolutionHeight,u=this._worldSpaceStorageTex;this._worldSpaceComputeNode=(0,n.Fn)(([t,r])=>{let d=(0,n.int)(n.workgroupId.x).mul(16).add((0,n.int)(n.localId.x)),f=(0,n.int)(n.workgroupId.y).mul(16).add((0,n.int)(n.localId.y));(0,n.If)(d.lessThan((0,n.int)(c)).and(f.lessThan((0,n.int)(l))),()=>{let p=(0,n.textureLoad)(e,(0,n.ivec2)(d,f)).w,m=(0,n.vec4)(0,0,0,0).toVar();(0,n.If)(a.lessThan(.5).and(p.lessThan((0,n.float)(1e5))),()=>{let e=(0,n.vec3)((0,n.float)(d).add(.5).div(c).mul(2).sub(1),(0,n.float)(f).add(.5).div(l).mul(2).sub(1).negate(),1),a=r.mul((0,n.vec4)(e,1)),u=(0,n.normalize)((0,n.mat3)(t[0].xyz,t[1].xyz,t[2].xyz).mul(a.xyz.div(a.w))),h=(0,n.vec3)(t[3]).add(u.mul(p)),g=(0,n.vec2)((0,n.float)(d).add(.5).div(c),(0,n.float)(f).add(.5).div(l)),_=i.mul((0,n.vec4)(h,1)),v=_.xy.div(_.w),y=(0,n.vec2)(v.x.mul(.5).add(.5),v.y.mul(-.5).add(.5)),b=y.x.greaterThanEqual(0).and(y.x.lessThanEqual(1)).and(y.y.greaterThanEqual(0)).and(y.y.lessThanEqual(1)),x=g.sub(y),S=(0,n.vec3)(x.x.div(o).mul(s),x.y.div(o).mul(s),0);m.assign(b.select((0,n.vec4)(S,1),(0,n.vec4)(0,0,0,.5)))}),(0,n.textureStore)(u,(0,n.uvec2)((0,n.uint)(d),(0,n.uint)(f)),m).toWriteOnly()})})(t,r).compute([this._dispatchX,this._dispatchY,1],[16,16,1])}_updateCameraMatrices(){let e=this.pathTracer,t,n,r,i;if(e&&e.uniforms)t=e.uniforms.get(`cameraWorldMatrix`).value,n=e.uniforms.get(`cameraViewMatrix`).value,r=e.uniforms.get(`cameraProjectionMatrix`).value,i=e.uniforms.get(`cameraProjectionMatrixInverse`).value;else{let e=this.camera;if(!e)return;t=e.matrixWorld,n=e.matrixWorldInverse,r=e.projectionMatrix,i=e.projectionMatrixInverse}this.matricesInitialized?this.prevViewProjectionMatrix.copy(this.currentViewProjectionMatrix):(this.currentViewProjectionMatrix.multiplyMatrices(r,n),this.prevViewProjectionMatrix.copy(this.currentViewProjectionMatrix),this.matricesInitialized=!0),this.currentViewProjectionMatrix.multiplyMatrices(r,n),this.cameraWorldMatrix.value.copy(t),this.cameraProjectionMatrixInverse.value.copy(i),this.prevVP.value.copy(this.prevViewProjectionMatrix)}setupEventListeners(){this.on(`pipeline:reset`,()=>{this.reset()})}render(e){if(!this.enabled)return;let t=e.getTexture(`pathtracer:normalDepth`);if(!t)return;this._updateCameraMatrices(),this.isFirstFrameU.value=+!!this.isFirstFrame,this.frameCount++;let n=t.image;n&&n.width>0&&n.height>0&&(n.width!==this.screenSpaceTarget.width||n.height!==this.screenSpaceTarget.height)&&this.setSize(n.width,n.height),this._normalDepthTexNode.value=t,this.renderer.compute(this._screenSpaceComputeNode),this.renderer.compute(this._worldSpaceComputeNode),this.renderer.copyTextureToTexture(this._screenSpaceStorageTex,this.screenSpaceTarget.texture),this.renderer.copyTextureToTexture(this._worldSpaceStorageTex,this.worldSpaceTarget.texture),e.setTexture(`motionVector:screenSpace`,this.screenSpaceTarget.texture),e.setTexture(`motionVector:worldSpace`,this.worldSpaceTarget.texture),e.setTexture(`motionVector:motion`,this.screenSpaceTarget.texture),this.emit(`motionvector:computed`,{frame:this.frameCount,isFirstFrame:this.isFirstFrame}),this.isFirstFrame=!1}reset(){this.matricesInitialized||(this.isFirstFrame=!0),this.frameCount=0}setSize(e,t){this._screenSpaceStorageTex.setSize(e,t),this._worldSpaceStorageTex.setSize(e,t),this.screenSpaceTarget.setSize(e,t),this.screenSpaceTarget.texture.needsUpdate=!0,this.worldSpaceTarget.setSize(e,t),this.worldSpaceTarget.texture.needsUpdate=!0,this.resolutionWidth.value=e,this.resolutionHeight.value=t,this._dispatchX=Math.ceil(e/16),this._dispatchY=Math.ceil(t/16),this._screenSpaceComputeNode&&(this._screenSpaceComputeNode.dispatchSize=[this._dispatchX,this._dispatchY,1]),this._worldSpaceComputeNode&&(this._worldSpaceComputeNode.dispatchSize=[this._dispatchX,this._dispatchY,1])}setVelocityScale(e){this.velocityScale.value=e}setDeltaTime(e){this.deltaTime.value=e}dispose(){this._screenSpaceComputeNode?.dispose(),this._worldSpaceComputeNode?.dispose(),this._screenSpaceStorageTex?.dispose(),this._worldSpaceStorageTex?.dispose(),this.screenSpaceTarget?.dispose(),this.worldSpaceTarget?.dispose(),this._normalDepthTexNode?.dispose()}};function ro(e,t,n={}){let r=n.textureIndex||0,i=t.isTexture===!0,a;i?(console.warn(`RenderTargetHelper: Direct Texture input is not supported. Pass a RenderTarget instead.`),a=null):a=t;let o={width:n.width||200,height:n.height||200,position:n.position||`bottom-right`,flipX:n.flipX===void 0?!1:n.flipX,flipY:n.flipY===void 0?!1:n.flipY,autoUpdate:n.autoUpdate||!1,theme:n.theme||`dark`,title:n.title||a?.name||`Render Target`},s=document.createElement(`div`);s.className=`render-target-helper`;let c={"bottom-right":{bottom:`48px`,right:`10px`},"bottom-left":{bottom:`10px`,left:`10px`},"top-right":{top:`10px`,right:`10px`},"top-left":{top:`10px`,left:`10px`}},l={light:{backgroundColor:`white`,border:`1px solid #ddd`,color:`#333`},dark:{backgroundColor:`#1e293b`,border:`1px solid #334155`,color:`#f8fafc`}};Object.assign(s.style,{display:`flex`,flexDirection:`column`,position:`fixed`,resize:`both`,overflow:`hidden`,padding:`8px`,borderRadius:`4px`,boxShadow:`0 5px 15px rgba(0,0,0,0.3)`,transition:`opacity 0.2s ease`,zIndex:`1000`,minWidth:`100px`,minHeight:`100px`,maxWidth:`500px`,maxHeight:`500px`,width:`${o.width}px`,height:`${o.height}px`,...c[o.position],...l[o.theme]});let u=document.createElement(`div`);u.style.display=`flex`,u.style.justifyContent=`space-between`,u.style.alignItems=`center`,u.style.marginBottom=`4px`,u.style.cursor=`move`,u.style.userSelect=`none`;let d=document.createElement(`span`);d.textContent=o.title,d.style.fontSize=`12px`,d.style.fontFamily=`monospace`,d.style.color=l[o.theme].color;let f=document.createElement(`div`),p=document.createElement(`button`);p.innerHTML=`×`,p.style.background=`none`,p.style.border=`none`,p.style.cursor=`pointer`,p.style.fontSize=`16px`,p.style.color=l[o.theme].color,p.style.padding=`0 4px`,p.title=`Close`,p.onclick=()=>{s.style.display=`none`,o.autoUpdate&&(cancelAnimationFrame(M),M=null)};let m=document.createElement(`button`);m.innerHTML=`⟳`,m.style.background=`none`,m.style.border=`none`,m.style.cursor=`pointer`,m.style.fontSize=`14px`,m.style.color=l[o.theme].color,m.style.padding=`0 4px`,m.title=`Refresh`,m.onclick=()=>{s.update()},f.appendChild(m),f.appendChild(p),u.appendChild(d),u.appendChild(f),s.appendChild(u);let h=document.createElement(`canvas`);h.style.width=`100%`,h.style.height=`calc(100% - 20px)`;let g=``;o.flipX&&(g+=`scaleX(-1) `),o.flipY&&(g+=`scaleY(-1) `),h.style.transform=g.trim(),s.appendChild(h);let _=a?a.width:1,v=a?a.height:1;h.width=_,h.height=v;let y=h.getContext(`2d`),b=new Uint8ClampedArray(4*_*v),x=!1,S=!1,C=0,w=0;u.addEventListener(`pointerdown`,e=>{S=!0,C=e.clientX-s.offsetLeft,w=e.clientY-s.offsetTop,document.body.style.userSelect=`none`});function T(e){if(!S)return;let t=e.clientX-C,n=e.clientY-w,r=window.innerWidth-s.offsetWidth,i=window.innerHeight-s.offsetHeight;s.style.left=`${Math.max(0,Math.min(t,r))}px`,s.style.top=`${Math.max(0,Math.min(n,i))}px`,s.style.bottom=`auto`,s.style.right=`auto`}function E(){S=!1,document.body.style.userSelect=``}window.addEventListener(`pointermove`,T),window.addEventListener(`pointerup`,E);function D(){if(!a)return;let e=a.width,t=a.height;(_!==e||v!==t)&&(_=e,v=t,h.width=_,h.height=v,b=new Uint8ClampedArray(4*_*v)),d.textContent=`${o.title} (${_}×${v})`}function O(e){let t=(e&32768)>>15,n=(e&31744)>>10,r=e&1023;return n===0?(t?-1:1)*2**-14*(r/1024):n===31?r?NaN:t?-1/0:1/0:(t?-1:1)*2**(n-15)*(1+r/1024)}function k(e){let t=Math.min(e.length,b.length);if(e instanceof Uint8Array||e instanceof Uint8ClampedArray)b.set(e.subarray(0,t));else if(e instanceof Uint16Array)for(let n=0;n<t;n++){let t=O(e[n]);b[n]=Math.min(255,Math.max(0,(t||0)*255))}else for(let n=0;n<t;n++)b[n]=Math.min(255,Math.max(0,e[n]*255));if(_===0||v===0)return;let n=new ImageData(b,_,v);y.putImageData(n,0,0)}s.update=function(){if(a){D();try{if(x)return;x=!0,e.readRenderTargetPixelsAsync(a,0,0,_,v,r).then(e=>{x=!1,k(e)}).catch(e=>{x=!1,console.error(`RenderTargetHelper: readback error:`,e)})}catch(e){console.error(`Error updating render target helper:`,e)}}};function A(){window.addEventListener(`mousemove`,D)}function j(){window.removeEventListener(`mousemove`,D)}s.addEventListener(`mousedown`,A),window.addEventListener(`mouseup`,j),window.addEventListener(`resize`,D);let M=null;return s.show=function(){s.style.display=`flex`,o.autoUpdate&&!M&&s.startAutoUpdate()},s.hide=function(){s.style.display=`none`,o.autoUpdate&&M&&(cancelAnimationFrame(M),M=null)},s.toggle=function(){return s.style.display===`none`?s.show():s.hide(),s.style.display!==`none`},s.startAutoUpdate=function(){if(M)return;let e=()=>{s.update(),M=requestAnimationFrame(e)};M=requestAnimationFrame(e)},s.stopAutoUpdate=function(){M&&=(cancelAnimationFrame(M),null)},s.dispose=function(){M&&=(cancelAnimationFrame(M),null),window.removeEventListener(`pointermove`,T),window.removeEventListener(`pointerup`,E),window.removeEventListener(`mouseup`,j),window.removeEventListener(`mousemove`,D),window.removeEventListener(`resize`,D),s.parentNode&&s.parentNode.removeChild(s),s.startAutoUpdate=null,s.stopAutoUpdate=null,s.show=null,s.hide=null,s.toggle=null,s.update=null,s.dispose=null,h&&(h.width=0,h.height=0),b=null},o.autoUpdate&&s.startAutoUpdate(),s.style.display===`none`&&(s.style.display=`flex`),s}var io=class extends I{constructor(e,i={}){super(`ASVGF`,{...i,executionMode:F.PER_CYCLE}),this.renderer=e,this.debugContainer=i.debugContainer||null,this.temporalAlpha=(0,n.uniform)(i.temporalAlpha??.1),this.phiColor=(0,n.uniform)(i.phiColor??10),this.maxAccumFrames=(0,n.uniform)(i.maxAccumFrames??32),this.varianceClip=(0,n.uniform)(i.varianceClip??1),this.resW=(0,n.uniform)(i.width||1),this.resH=(0,n.uniform)(i.height||1),this.temporalEnabled=!0,this.temporalEnabledU=(0,n.uniform)(1),this._colorTexNode=new t.TextureNode,this._motionTexNode=new t.TextureNode,this._readTemporalTexNode=new t.TextureNode;let a=i.width||1,o=i.height||1;this._temporalTexA=new t.StorageTexture(a,o),this._temporalTexA.type=r.HalfFloatType,this._temporalTexA.format=r.RGBAFormat,this._temporalTexA.minFilter=r.LinearFilter,this._temporalTexA.magFilter=r.LinearFilter,this._temporalTexB=new t.StorageTexture(a,o),this._temporalTexB.type=r.HalfFloatType,this._temporalTexB.format=r.RGBAFormat,this._temporalTexB.minFilter=r.LinearFilter,this._temporalTexB.magFilter=r.LinearFilter,this._gradientStorageTex=new t.StorageTexture(a,o),this._gradientStorageTex.type=r.HalfFloatType,this._gradientStorageTex.format=r.RGBAFormat,this._gradientStorageTex.minFilter=r.LinearFilter,this._gradientStorageTex.magFilter=r.LinearFilter,this.currentMoments=0,this._compiled=!1,this._dispatchX=Math.ceil(a/8),this._dispatchY=Math.ceil(o/8),this._buildGradientCompute(),this._buildTemporalCompute(),this.showHeatmap=!1,this.debugMode=(0,n.uniform)(0,`int`),this._heatmapStorageTex=new t.StorageTexture(a,o),this._heatmapStorageTex.type=r.FloatType,this._heatmapStorageTex.format=r.RGBAFormat,this._heatmapStorageTex.minFilter=r.NearestFilter,this._heatmapStorageTex.magFilter=r.NearestFilter,this.heatmapTarget=new t.RenderTarget(a,o,{type:r.FloatType,format:r.RGBAFormat,minFilter:r.NearestFilter,magFilter:r.NearestFilter,depthBuffer:!1,stencilBuffer:!1}),this._heatmapRawColorTexNode=new t.TextureNode,this._heatmapColorTexNode=new t.TextureNode,this._heatmapTemporalTexNode=new t.TextureNode,this._heatmapNDTexNode=new t.TextureNode,this._heatmapMotionTexNode=new t.TextureNode,this._heatmapGradientTexNode=new t.TextureNode,this._buildHeatmapCompute(),this.heatmapHelper=ro(this.renderer,this.heatmapTarget,{width:400,height:400,position:`bottom-right`,theme:`dark`,title:`ASVGF Debug`,autoUpdate:!1}),this.heatmapHelper.hide(),(this.debugContainer||document.body).appendChild(this.heatmapHelper),this.frameCount=0}_buildGradientCompute(){let e=this._colorTexNode,t=this._motionTexNode,r=this._readTemporalTexNode,i=this._gradientStorageTex,a=this.resW,o=this.resH,s=(0,n.workgroupArray)(`float`,100);this._gradientNode=(0,n.Fn)(()=>{let c=n.localId.x,l=n.localId.y,u=l.mul(8).add(c),d=(0,n.int)(n.workgroupId.x).mul(8).sub(1),f=(0,n.int)(n.workgroupId.y).mul(8).sub(1),p=u.mod(10),m=u.div(10),h=(0,n.textureLoad)(e,(0,n.ivec2)(d.add((0,n.int)(p)).clamp((0,n.int)(0),(0,n.int)(a).sub(1)),f.add((0,n.int)(m)).clamp((0,n.int)(0),(0,n.int)(o).sub(1)))).xyz;s.element(u).assign(Qt(h)),(0,n.If)(u.lessThan((0,n.uint)(36)),()=>{let t=u.add((0,n.uint)(64)),r=t.mod(10),i=t.div(10),c=(0,n.textureLoad)(e,(0,n.ivec2)(d.add((0,n.int)(r)).clamp((0,n.int)(0),(0,n.int)(a).sub(1)),f.add((0,n.int)(i)).clamp((0,n.int)(0),(0,n.int)(o).sub(1)))).xyz;s.element(t).assign(Qt(c))}),(0,n.workgroupBarrier)();let g=(0,n.int)(n.workgroupId.x).mul(8).add((0,n.int)(c)),_=(0,n.int)(n.workgroupId.y).mul(8).add((0,n.int)(l));(0,n.If)(g.lessThan((0,n.int)(a)).and(_.lessThan((0,n.int)(o))),()=>{let e=(0,n.float)(-1).toVar(),u=(0,n.int)(0).toVar(),d=(0,n.int)(0).toVar();for(let t=-1;t<=1;t++)for(let r=-1;r<=1;r++){let i=s.element(l.add(1+t).mul(10).add(c.add(1+r)));(0,n.If)(i.greaterThan(e),()=>{e.assign(i),u.assign((0,n.int)(r)),d.assign((0,n.int)(t))})}let f=g.add(u).clamp((0,n.int)(0),(0,n.int)(a).sub(1)),p=_.add(d).clamp((0,n.int)(0),(0,n.int)(o).sub(1)),m=(0,n.textureLoad)(t,(0,n.ivec2)(f,p)),h=(0,n.float)(f).sub(m.x.mul(a)),v=(0,n.float)(p).sub(m.y.mul(o)),y=(0,n.textureLoad)(r,(0,n.ivec2)((0,n.int)(h).clamp((0,n.int)(0),(0,n.int)(a).sub(1)),(0,n.int)(v).clamp((0,n.int)(0),(0,n.int)(o).sub(1)))).xyz,b=Qt(y),x=(0,n.abs)(e.sub(b)).div((0,n.max)(e,(0,n.float)(.001))).clamp(0,1);(0,n.textureStore)(i,(0,n.uvec2)((0,n.uint)(g),(0,n.uint)(_)),(0,n.vec4)(x,e,b,1)).toWriteOnly()})})().compute([this._dispatchX,this._dispatchY,1],[8,8,1])}_buildTemporalCompute(){this._temporalNodeA=this._buildTemporalForDirection(this._temporalTexA),this._temporalNodeB=this._buildTemporalForDirection(this._temporalTexB)}_buildTemporalForDirection(e){let t=this._colorTexNode,r=this._motionTexNode,i=this._readTemporalTexNode,a=this.temporalAlpha,o=this.maxAccumFrames,s=this.varianceClip,c=this.temporalEnabledU,l=this.resW,u=this.resH;return(0,n.Fn)(()=>{let d=(0,n.int)(n.workgroupId.x).mul(8).add((0,n.int)(n.localId.x)),f=(0,n.int)(n.workgroupId.y).mul(8).add((0,n.int)(n.localId.y));(0,n.If)(d.lessThan((0,n.int)(l)).and(f.lessThan((0,n.int)(u))),()=>{let p=(0,n.ivec2)(d,f),m=(0,n.textureLoad)(t,p).xyz,h=(0,n.vec4)(m,1).toVar();(0,n.If)(c.greaterThan(.5),()=>{let e=(0,n.textureLoad)(r,p),c=e.w.greaterThan(.5),g=(0,n.float)(d).sub(e.x.mul(l)),_=(0,n.float)(f).sub(e.y.mul(u)),v=g.greaterThanEqual(0).and(g.lessThan((0,n.float)(l))).and(_.greaterThanEqual(0)).and(_.lessThan((0,n.float)(u)));(0,n.If)(c.and(v),()=>{let e=(0,n.textureLoad)(i,(0,n.ivec2)((0,n.int)(g).clamp((0,n.int)(0),(0,n.int)(l).sub(1)),(0,n.int)(_).clamp((0,n.int)(0),(0,n.int)(u).sub(1)))),r=e.xyz,c=e.w,p=(0,n.vec3)(0).toVar(),v=(0,n.vec3)(0).toVar();for(let e=-1;e<=1;e++)for(let r=-1;r<=1;r++){let i=(0,n.textureLoad)(t,(0,n.ivec2)(d.add(r).clamp((0,n.int)(0),(0,n.int)(l).sub(1)),f.add(e).clamp((0,n.int)(0),(0,n.int)(u).sub(1)))).xyz;p.addAssign(i),v.addAssign(i.mul(i))}p.divAssign(9),v.divAssign(9);let y=(0,n.dot)((0,n.max)(v.sub(p.mul(p)),(0,n.vec3)(0)),(0,n.vec3)(1)),b=r.sub(p),x=(0,n.dot)(b,b),S=y.mul(s.mul(s)),C=x.div((0,n.max)(S,(0,n.float)(1e-6))).clamp(0,1),w=(0,n.mix)(r,m,(0,n.mix)((0,n.max)((0,n.float)(1).div(c.add(1)),a),(0,n.float)(1),C)),T=(0,n.mix)((0,n.min)(c.add(1),o),(0,n.float)(1),C);h.assign((0,n.vec4)(w,T))}).Else(()=>{h.assign((0,n.vec4)(m,1))})}),(0,n.textureStore)(e,(0,n.uvec2)((0,n.uint)(d),(0,n.uint)(f)),h).toWriteOnly()})})().compute([this._dispatchX,this._dispatchY,1],[8,8,1])}_buildHeatmapCompute(){let e=this._heatmapRawColorTexNode,t=this._heatmapColorTexNode,r=this._heatmapTemporalTexNode,i=this._heatmapNDTexNode,a=this._heatmapMotionTexNode,o=this._heatmapGradientTexNode,s=this._heatmapStorageTex,c=this.debugMode,l=this.resW,u=this.resH;this._heatmapComputeNode=(0,n.Fn)(()=>{let d=(0,n.int)(n.workgroupId.x).mul(8).add((0,n.int)(n.localId.x)),f=(0,n.int)(n.workgroupId.y).mul(8).add((0,n.int)(n.localId.y));(0,n.If)(d.lessThan((0,n.int)(l)).and(f.lessThan((0,n.int)(u))),()=>{let p=(0,n.ivec2)(d,f),m=(0,n.vec4)(0,0,0,1).toVar();(0,n.If)(c.equal((0,n.int)(0)),()=>{let e=(0,n.textureLoad)(t,p).xyz;m.assign((0,n.vec4)(e,1))}).ElseIf(c.equal((0,n.int)(1)),()=>{let t=(0,n.float)(0).toVar(),r=(0,n.float)(0).toVar();for(let i=-1;i<=1;i++)for(let a=-1;a<=1;a++){let o=(0,n.textureLoad)(e,(0,n.ivec2)(d.add(a).clamp((0,n.int)(0),(0,n.int)(l).sub(1)),f.add(i).clamp((0,n.int)(0),(0,n.int)(u).sub(1)))).xyz,s=(0,n.dot)(o,(0,n.vec3)(.2126,.7152,.0722));t.addAssign(s),r.addAssign(s.mul(s))}t.divAssign(9),r.divAssign(9);let i=(0,n.max)(r.sub(t.mul(t)),(0,n.float)(0)).div((0,n.max)(t.mul(t),(0,n.float)(1e-4))).mul(10).clamp(0,1),a=i.sub(.5).mul(4).clamp(0,1),o=i.mul(4).clamp(0,1).sub(i.sub(.75).mul(4).clamp(0,1)),s=(0,n.float)(1).sub(i.sub(.25).mul(4).clamp(0,1));m.assign((0,n.vec4)(a,o,s,1))}).ElseIf(c.equal((0,n.int)(2)),()=>{let e=(0,n.textureLoad)(r,p).w.div(32).clamp(0,1);m.assign((0,n.vec4)((0,n.float)(1).sub(e),e,(0,n.float)(.2),1))}).ElseIf(c.equal((0,n.int)(3)),()=>{let e=(0,n.textureLoad)(a,p),t=(0,n.abs)(e.x).mul(100).clamp(0,1),r=(0,n.abs)(e.y).mul(100).clamp(0,1),i=t.add(r).clamp(0,1);m.assign((0,n.vec4)(t,r,i.mul(.3),1))}).ElseIf(c.equal((0,n.int)(4)),()=>{let e=(0,n.textureLoad)(i,p);m.assign((0,n.vec4)(e.xyz,1))}).Else(()=>{let e=(0,n.textureLoad)(o,p).x.mul(5).clamp(0,1);m.assign((0,n.vec4)(e,e.mul(.5),(0,n.float)(1).sub(e),1))}),(0,n.textureStore)(s,(0,n.uvec2)((0,n.uint)(d),(0,n.uint)(f)),m).toWriteOnly()})})().compute([this._dispatchX,this._dispatchY,1],[8,8,1])}setupEventListeners(){this.on(`asvgf:reset`,()=>this.resetTemporalData()),this.on(`asvgf:setTemporal`,e=>{e&&e.enabled!==void 0&&(this.temporalEnabled=e.enabled,this.temporalEnabledU.value=+!!e.enabled)}),this.on(`asvgf:updateParameters`,e=>{e&&(e.temporalAlpha!==void 0&&(this.temporalAlpha.value=e.temporalAlpha),e.phiColor!==void 0&&(this.phiColor.value=e.phiColor))})}render(e){if(!this.enabled)return;let t=e.getTexture(`pathtracer:color`),n=e.getTexture(`pathtracer:normalDepth`),r=e.getTexture(`motionVector:screenSpace`);if(!t)return;let i=t.image;i&&i.width>0&&i.height>0&&(i.width!==this._temporalTexA.image.width||i.height!==this._temporalTexA.image.height)&&this.setSize(i.width,i.height),this._colorTexNode.value=t,r&&(this._motionTexNode.value=r),this._compiled||=(this.renderer.compute(this._gradientNode),this.renderer.compute(this._temporalNodeA),this.renderer.compute(this._temporalNodeB),!0);let a=this.currentMoments===0?this._temporalTexB:this._temporalTexA,o=this.currentMoments===0?this._temporalNodeA:this._temporalNodeB,s=this.currentMoments===0?this._temporalTexA:this._temporalTexB;this._readTemporalTexNode.value=a,this.renderer.compute(o),e.setTexture(`asvgf:output`,s),e.setTexture(`asvgf:temporalColor`,s),this.currentMoments=1-this.currentMoments,this.showHeatmap&&(this.renderer.compute(this._gradientNode),this._heatmapRawColorTexNode.value=t,this._heatmapColorTexNode.value=s,this._heatmapTemporalTexNode.value=s,n&&(this._heatmapNDTexNode.value=n),r&&(this._heatmapMotionTexNode.value=r),this._heatmapGradientTexNode.value=this._gradientStorageTex,this.renderer.compute(this._heatmapComputeNode),this.renderer.copyTextureToTexture(this._heatmapStorageTex,this.heatmapTarget.texture),this.heatmapHelper.update()),this.frameCount++}toggleHeatmap(e){this.showHeatmap=e,e?this.heatmapHelper.show():this.heatmapHelper.hide()}setTemporalEnabled(e){this.temporalEnabled=e}updateParameters(e){e&&(e.temporalAlpha!==void 0&&(this.temporalAlpha.value=e.temporalAlpha),e.phiColor!==void 0&&(this.phiColor.value=e.phiColor),e.debugMode!==void 0&&(this.debugMode.value=e.debugMode))}resetTemporalData(){this.frameCount=0,this.currentMoments=0}setSize(e,t){this._temporalTexA.setSize(e,t),this._temporalTexB.setSize(e,t),this._gradientStorageTex.setSize(e,t),this._heatmapStorageTex.setSize(e,t),this.heatmapTarget.setSize(e,t),this.heatmapTarget.texture.needsUpdate=!0,this.resW.value=e,this.resH.value=t,this._dispatchX=Math.ceil(e/8),this._dispatchY=Math.ceil(t/8),this._gradientNode.dispatchSize=[this._dispatchX,this._dispatchY,1],this._temporalNodeA.dispatchSize=[this._dispatchX,this._dispatchY,1],this._temporalNodeB.dispatchSize=[this._dispatchX,this._dispatchY,1],this._heatmapComputeNode.dispatchSize=[this._dispatchX,this._dispatchY,1]}reset(){}dispose(){this._gradientNode?.dispose(),this._temporalNodeA?.dispose(),this._temporalNodeB?.dispose(),this._temporalTexA?.dispose(),this._temporalTexB?.dispose(),this._gradientStorageTex?.dispose(),this._heatmapComputeNode?.dispose(),this._heatmapStorageTex?.dispose(),this.heatmapTarget?.dispose(),this._colorTexNode?.dispose(),this._motionTexNode?.dispose(),this._readTemporalTexNode?.dispose(),this._heatmapRawColorTexNode?.dispose(),this._heatmapColorTexNode?.dispose(),this._heatmapTemporalTexNode?.dispose(),this._heatmapNDTexNode?.dispose(),this._heatmapMotionTexNode?.dispose(),this._heatmapGradientTexNode?.dispose(),this.heatmapHelper?.dispose()}},ao=(0,n.wgslFn)(`
507
+ `),Ki=(0,n.Fn)(([e,t,r,i,a])=>{let o=(0,n.texture)(r,e.div(t),0),s=(0,n.int)(0).toVar();return(0,n.If)(o.b.greaterThan(.5),()=>{s.assign(0)}).Else(()=>{let e=(0,n.int)((0,n.floor)(o.r.mul((0,n.float)(a)).add(.5)));s.assign((0,n.clamp)(e,i,a))}),s}),qi=e=>{let{pixelCoord:t,writeColorTex:r,writeNDTex:i,writeAlbedoTex:a,resolution:o,frame:s,samplesPerPixel:c,visMode:l,cameraWorldMatrix:u,cameraProjectionMatrixInverse:d,cameraViewMatrix:f,cameraProjectionMatrix:p,bvhBuffer:m,triangleBuffer:h,materialBuffer:g,albedoMaps:_,normalMaps:v,bumpMaps:y,metalnessMaps:b,roughnessMaps:x,emissiveMaps:S,displacementMaps:C,directionalLightsBuffer:w,numDirectionalLights:T,areaLightsBuffer:E,numAreaLights:D,pointLightsBuffer:O,numPointLights:k,spotLightsBuffer:j,numSpotLights:M,envTexture:N,environmentIntensity:P,envMatrix:ee,envCDFBuffer:F,envTotalSum:I,envCompensationDelta:te,envResolution:ne,enableEnvironmentLight:re,useEnvMapIS:ie,maxBounceCount:L,transmissiveBounces:R,showBackground:se,transparentBackground:ce,backgroundIntensity:z,fireflyThreshold:le,globalIlluminationIntensity:ue,totalTriangleCount:de,enableEmissiveTriangleSampling:B,emissiveTriangleBuffer:fe,emissiveVec4Offset:pe,emissiveTriangleCount:me,emissiveTotalPower:he,emissiveBoost:ge,lightBVHBuffer:_e,lightBVHNodeCount:ve,debugVisScale:ye,enableAccumulation:be,hasPreviousAccumulated:xe,prevAccumTexture:Se,prevNormalDepthTexture:V,prevAlbedoTexture:Ce,accumulationAlpha:we,cameraIsMoving:Te,useAdaptiveSampling:Ee,adaptiveSamplingTexture:De,adaptiveSamplingMin:Oe,adaptiveSamplingMax:H,enableDOF:U,focalLength:ke,aperture:Ae,focusDistance:W,sceneScale:je,apertureScale:Me,anamorphicRatio:Ne}=e,Pe=(0,n.uvec2)((0,n.uint)((0,n.int)(t.x)),(0,n.uint)((0,n.int)(t.y))),Fe=t.div(o),Ie=t.div(o).mul(2).sub(1).toVar();Ie.y.assign(Ie.y.negate());let G=(0,n.vec4)(0).toVar(),K=(0,n.int)(0).toVar(),Le=oe({pixelCoord:t,rayIndex:(0,n.int)(0),frame:s}).toVar(),Re=(0,n.int)(t.y).mul((0,n.int)(o.x)).add((0,n.int)(t.x)).toVar(),ze=(0,n.vec3)(0,0,1).toVar(),q=(0,n.float)(1).toVar(),Be=(0,n.float)(0).toVar(),Ve=(0,n.int)(c).toVar();(0,n.If)(s.greaterThan((0,n.uint)(2)).and(Ee),()=>{let e=Ki(t,o,De,Oe,H);Ve.assign(e),(0,n.If)(Ve.equal((0,n.int)(0)),()=>{(0,n.If)(be.and(xe),()=>{let e=(0,n.texture)(Se,Fe,0);G.assign(e),Be.assign(e.w);let t=(0,n.texture)(V,Fe,0);ze.assign(t.xyz.mul(2).sub(1)),q.assign(t.w)}).Else(()=>{Ve.assign(1)})})});let He=(0,n.vec3)(0).toVar(),Ue=(0,n.vec3)(0).toVar(),We=(0,n.float)(-1e3).toVar(),Ge=(0,n.vec2)(2).div(o).toVar();(0,n.Loop)({start:(0,n.int)(0),end:Ve,type:`int`,condition:`<`},({i:e})=>{let r=A({state:Le.add((0,n.uint)(e))}).toVar(),i=ae(t,e,Ve,r,o,s).toVar();(0,n.If)(l.equal((0,n.int)(9)),()=>{G.assign((0,n.vec4)(i,1,1)),K.assign(1),(0,n.Break)()});let a=i.sub(.5).mul(Ge),c=Ie.add(a),oe=gt.wrap(pn(c,r,u,d,U,ke,Ae,W,je,Me,Ne)),be=(0,n.vec4)(0).toVar();(0,n.If)(l.greaterThan((0,n.int)(0)),()=>{be.assign(Wi(oe.origin,oe.direction,m,h,g,N,ee,P,re,l,ye,t,o,_,v,y,b,x,S,p,f,s))}).Else(()=>{let i=Ni.wrap(Bi(oe,r,e,Re,m,h,g,_,v,y,b,x,S,C,w,T,E,D,O,k,j,M,N,P,ee,F,I,te,ne,re,ie,L,R,z,se,ce,le,ue,de,B,fe,pe,me,he,ge,_e,ve,t,o,s));be.assign(i.radiance),(0,n.If)(e.equal((0,n.int)(0)),()=>{He.assign(i.objectNormal),Ue.assign(i.objectColor),We.assign(i.objectID),(0,n.If)(i.firstHitDistance.lessThan(1e9),()=>{ze.assign((0,n.normalize)(i.objectNormal)),q.assign(Gi({worldPos:i.firstHitPoint,cameraProjectionMatrix:p,cameraViewMatrix:f}))})})}),G.addAssign(be),Be.addAssign(be.w),K.addAssign(1)}),(0,n.If)(K.greaterThan((0,n.int)(0)),()=>{G.divAssign((0,n.float)(K)),Be.divAssign((0,n.float)(K))});let Ke=G.xyz.toVar(),qe=(0,n.vec4)(ze.mul(.5).add(.5),q).toVar(),Je=(0,n.vec3)(Ue).toVar(),Ye=(0,n.select)(ce,Be,(0,n.float)(1)).toVar();(0,n.If)(be.and(Te.not()).and(s.greaterThan((0,n.uint)(0))).and(xe),()=>{let e=(0,n.texture)(Se,Fe,0).toVar();Ke.assign((0,n.mix)(e.xyz,G.xyz,we)),qe.assign((0,n.mix)((0,n.texture)(V,Fe,0),qe,we)),Je.assign((0,n.mix)((0,n.texture)(Ce,Fe,0).xyz,Je,we)),(0,n.If)(ce,()=>{Ye.assign((0,n.mix)(e.w,Be,we))})}),(0,n.textureStore)(r,Pe,(0,n.vec4)(Ke.xyz,Ye)).toWriteOnly(),(0,n.textureStore)(i,Pe,qe).toWriteOnly(),(0,n.textureStore)(a,Pe,(0,n.vec4)(Je,1)).toWriteOnly()},Ji=class{constructor(e=`Build`){this.label=e,this.entries=new Map,this.order=[],this.totalStart=performance.now()}start(e){return this.entries.set(e,{start:performance.now(),end:null}),this.order.includes(e)||this.order.push(e),this}end(e){let t=this.entries.get(e);return t&&(t.end=performance.now(),t.duration=t.end-t.start),this}getDuration(e){return this.entries.get(e)?.duration??0}print(){let e=performance.now()-this.totalStart,t=this.order.map(e=>{let t=this.entries.get(e)?.duration??0;return t>=1?`${e} ${Math.round(t)}ms`:null}).filter(Boolean);return console.log(`[${this.label}] ${Math.round(e)}ms`+(t.length?` | ${t.join(` · `)}`:``)),{steps:Object.fromEntries(this.order.map(e=>[e,Math.round(this.entries.get(e)?.duration??0)])),total:Math.round(e)}}},Yi=8,Xi=class{constructor(){this.computeNode=null,this.prevColorTexNode=null,this.prevNormalDepthTexNode=null,this.prevAlbedoTexNode=null,this.adaptiveSamplingTexNode=null,this.tileOffsetX=(0,n.uniform)(0,`int`),this.tileOffsetY=(0,n.uniform)(0,`int`),this.renderWidth=(0,n.uniform)(1920,`int`),this.renderHeight=(0,n.uniform)(1080,`int`),this._dispatchX=0,this._dispatchY=0,this._dispatchSize=[0,0,1],this._sceneTextureNodes=null,this._compiled=!1}setupCompute(e){let{stage:t,storageTextures:n}=e,r=new Ji(`setupCompute`);r.start(`Create texture nodes`);let i=this._createTextureNodes(t,n);r.end(`Create texture nodes`),r.start(`Build compute node (TSL)`);let a=n.renderWidth,o=n.renderHeight;this._dispatchX=Math.ceil(a/Yi),this._dispatchY=Math.ceil(o/Yi),this.renderWidth.value=a,this.renderHeight.value=o;let s=n.getWriteTextures();this.computeNode=this._buildComputeNode(t,i,s.color,s.normalDepth,s.albedo),this._compiled=!1,r.end(`Build compute node (TSL)`),r.print()}updateSceneTextures(e){let t=this._sceneTextureNodes,n=e.environment,r=e.materialData;n.environmentTexture&&t.envTex&&(t.envTex.value=n.environmentTexture),r.albedoMaps&&t.albedoMapsTex&&(t.albedoMapsTex.value=r.albedoMaps),r.normalMaps&&t.normalMapsTex&&(t.normalMapsTex.value=r.normalMaps),r.bumpMaps&&t.bumpMapsTex&&(t.bumpMapsTex.value=r.bumpMaps),r.metalnessMaps&&t.metalnessMapsTex&&(t.metalnessMapsTex.value=r.metalnessMaps),r.roughnessMaps&&t.roughnessMapsTex&&(t.roughnessMapsTex.value=r.roughnessMaps),r.emissiveMaps&&t.emissiveMapsTex&&(t.emissiveMapsTex.value=r.emissiveMaps),r.displacementMaps&&t.displacementMapsTex&&(t.displacementMapsTex.value=r.displacementMaps),console.log(`ShaderBuilder: Scene textures updated in-place`)}getSceneTextureNodes(){return this._sceneTextureNodes}setSize(e,t){this._dispatchX=Math.ceil(e/Yi),this._dispatchY=Math.ceil(t/Yi),this.computeNode&&(this._dispatchSize[0]=this._dispatchX,this._dispatchSize[1]=this._dispatchY,this.computeNode.dispatchSize=this._dispatchSize),this.renderWidth.value=e,this.renderHeight.value=t,this.tileOffsetX.value=0,this.tileOffsetY.value=0}setTileDispatch(e,t,n,r){this.tileOffsetX.value=e,this.tileOffsetY.value=t;let i=Math.ceil(n/Yi),a=Math.ceil(r/Yi);this.computeNode&&(this._dispatchSize[0]=i,this._dispatchSize[1]=a,this.computeNode.dispatchSize=this._dispatchSize)}setFullScreenDispatch(){this.tileOffsetX.value=0,this.tileOffsetY.value=0,this.computeNode&&(this._dispatchSize[0]=this._dispatchX,this._dispatchSize[1]=this._dispatchY,this.computeNode.dispatchSize=this._dispatchSize)}forceCompile(e){this._compiled||!this.computeNode||!e||(this._compiled=!0,e.compute(this.computeNode))}_createTextureNodes(e,i){let a=e.triangleStorageNode,o=e.bvhStorageNode,s=e.materialData.materialStorageNode,c=e.lightStorageNode;zr(e.uniforms.get(`enableAlphaShadows`));let l=(0,n.texture)(e.environment.environmentTexture),u=new t.TextureNode;this.adaptiveSamplingTexNode=u;let d=e.environment.envCDFStorageNode,f=i.getReadTextures();this.prevColorTexNode=(0,n.texture)(f.color),this.prevNormalDepthTexNode=(0,n.texture)(f.normalDepth),this.prevAlbedoTexNode=(0,n.texture)(f.albedo);let p=()=>{let e=new r.DataArrayTexture(new Uint8Array([255,255,255,255]),1,1,1);return e.minFilter=r.LinearFilter,e.magFilter=r.LinearFilter,e.generateMipmaps=!1,e.needsUpdate=!0,(0,n.texture)(e)},m=e.materialData,h=m.albedoMaps?(0,n.texture)(m.albedoMaps):p(),g=m.normalMaps?(0,n.texture)(m.normalMaps):p(),_=m.bumpMaps?(0,n.texture)(m.bumpMaps):p(),v=m.metalnessMaps?(0,n.texture)(m.metalnessMaps):p(),y=m.roughnessMaps?(0,n.texture)(m.roughnessMaps):p(),b=m.emissiveMaps?(0,n.texture)(m.emissiveMaps):p(),x=m.displacementMaps?(0,n.texture)(m.displacementMaps):p();Rr(h);let S={triStorage:a,bvhStorage:o,matStorage:s,lightBufferStorage:c,envTex:l,adaptiveSamplingTex:u,envCDFStorage:d,albedoMapsTex:h,normalMapsTex:g,bumpMapsTex:_,metalnessMapsTex:v,roughnessMapsTex:y,emissiveMapsTex:b,displacementMapsTex:x};return this._sceneTextureNodes=S,S}_buildComputeNode(e,t,r,i,a){let{triStorage:o,bvhStorage:s,matStorage:c,lightBufferStorage:l,envTex:u,adaptiveSamplingTex:d,envCDFStorage:f,albedoMapsTex:p,normalMapsTex:m,bumpMapsTex:h,metalnessMapsTex:g,roughnessMapsTex:_,emissiveMapsTex:v,displacementMapsTex:y}=t,b=this.tileOffsetX,x=this.tileOffsetY,S=this.renderWidth,C=this.renderHeight,w=this.prevColorTexNode,T=this.prevNormalDepthTexNode,E=this.prevAlbedoTexNode;return(0,n.Fn)(()=>{let t=b.add((0,n.int)(n.workgroupId.x).mul(Yi)).add((0,n.int)(n.localId.x)),D=x.add((0,n.int)(n.workgroupId.y).mul(Yi)).add((0,n.int)(n.localId.y));(0,n.If)(t.lessThan(S).and(D.lessThan(C)),()=>{qi({pixelCoord:(0,n.vec2)((0,n.float)(t).add(.5),(0,n.float)(D).add(.5)),writeColorTex:r,writeNDTex:i,writeAlbedoTex:a,prevAccumTexture:w,prevNormalDepthTexture:T,prevAlbedoTexture:E,resolution:e.resolution,frame:e.frame,samplesPerPixel:e.samplesPerPixel,visMode:e.visMode,cameraWorldMatrix:e.cameraWorldMatrix,cameraProjectionMatrixInverse:e.cameraProjectionMatrixInverse,cameraViewMatrix:e.cameraViewMatrix,cameraProjectionMatrix:e.cameraProjectionMatrix,bvhBuffer:s,triangleBuffer:o,materialBuffer:c,albedoMaps:p,normalMaps:m,bumpMaps:h,metalnessMaps:g,roughnessMaps:_,emissiveMaps:v,displacementMaps:y,directionalLightsBuffer:e.directionalLightsBufferNode,numDirectionalLights:e.numDirectionalLights,areaLightsBuffer:e.areaLightsBufferNode,numAreaLights:e.numAreaLights,pointLightsBuffer:e.pointLightsBufferNode,numPointLights:e.numPointLights,spotLightsBuffer:e.spotLightsBufferNode,numSpotLights:e.numSpotLights,envTexture:u,environmentIntensity:e.environmentIntensity,envMatrix:e.environmentMatrix,envCDFBuffer:f,envTotalSum:e.envTotalSum,envCompensationDelta:e.envCompensationDelta,envResolution:e.envResolution,enableEnvironmentLight:e.enableEnvironment,useEnvMapIS:e.useEnvMapIS,maxBounceCount:e.maxBounces,transmissiveBounces:e.transmissiveBounces,showBackground:e.showBackground,transparentBackground:e.transparentBackground,backgroundIntensity:e.backgroundIntensity,fireflyThreshold:e.fireflyThreshold,globalIlluminationIntensity:e.globalIlluminationIntensity,totalTriangleCount:e.totalTriangleCount,enableEmissiveTriangleSampling:e.enableEmissiveTriangleSampling,emissiveTriangleBuffer:l,emissiveTriangleCount:e.emissiveTriangleCount,emissiveTotalPower:e.emissiveTotalPower,emissiveBoost:e.emissiveBoost,emissiveVec4Offset:e.emissiveVec4Offset,lightBVHBuffer:l,lightBVHNodeCount:e.lightBVHNodeCount,debugVisScale:e.debugVisScale,enableAccumulation:e.enableAccumulation,hasPreviousAccumulated:e.hasPreviousAccumulated,accumulationAlpha:e.accumulationAlpha,cameraIsMoving:e.cameraIsMoving,useAdaptiveSampling:e.useAdaptiveSampling,adaptiveSamplingTexture:d,adaptiveSamplingMin:e.adaptiveSamplingMin,adaptiveSamplingMax:e.adaptiveSamplingMax,enableDOF:e.enableDOF,focalLength:e.focalLength,aperture:e.aperture,focusDistance:e.focusDistance,sceneScale:e.sceneScale,apertureScale:e.apertureScale,anamorphicRatio:e.anamorphicRatio})})})().compute([this._dispatchX,this._dispatchY,1],[Yi,Yi,1])}dispose(){this.computeNode?.dispose(),this.computeNode=null,this.prevColorTexNode=null,this.prevNormalDepthTexNode=null,this.prevAlbedoTexNode=null,this.adaptiveSamplingTexNode=null,this._sceneTextureNodes=null,this._compiled=!1}},Zi=class{constructor(e,t){this.traversalCost=e,this.intersectionCost=t,this.maxTreeletLeaves=7,this.minImprovement=.02,this.topologyCache=new Map;for(let e=3;e<=this.maxTreeletLeaves;e++)this.topologyCache.set(e,this.generateTopologies(e));this.stats={treeletsProcessed:0,treeletsImproved:0,totalSAHImprovement:0,averageSAHImprovement:0,optimizationTime:0}}generateTopologies(e){if(e===1)return[0];if(e===2)return[[0,1]];let t=[];for(let n=1;n<e;n++){let r=this.generateTopologies(n),i=this.generateTopologies(e-n);for(let e of r)for(let r of i)t.push([e,this.offsetTopology(r,n)])}return t}offsetTopology(e,t){return typeof e==`number`?e+t:[this.offsetTopology(e[0],t),this.offsetTopology(e[1],t)]}optimizeBVH(e){let t=performance.now();this.stats={treeletsProcessed:0,treeletsImproved:0,totalSAHImprovement:0,averageSAHImprovement:0,optimizationTime:0};let n=this.identifyTreeletRoots(e);for(let e=0;e<n.length;e++){if(performance.now()-t>3e4){console.warn(`TreeletOptimizer: timeout after ${e}/${n.length} treelets`);break}this.optimizeTreelet(n[e])}return this.stats.optimizationTime=performance.now()-t,this.stats.averageSAHImprovement=this.stats.treeletsProcessed>0?this.stats.totalSAHImprovement/this.stats.treeletsProcessed:0,e}identifyTreeletRoots(e){let t=[],n=new Set,r=[{node:e,visited:!1}];for(;r.length>0;){let e=r[r.length-1];if(e.visited){r.pop();let i=e.node;if(i.triangleCount>0||n.has(i))continue;let a=this.countLeaves(i);a>=3&&a<=this.maxTreeletLeaves&&(t.push(i),this.markSubtree(i,n))}else{e.visited=!0;let t=e.node;if(t.triangleCount>0)continue;t.rightChild&&r.push({node:t.rightChild,visited:!1}),t.leftChild&&r.push({node:t.leftChild,visited:!1})}}return t}countLeaves(e){return e?e.triangleCount>0?1:this.countLeaves(e.leftChild)+this.countLeaves(e.rightChild):0}markSubtree(e,t){e&&(t.add(e),!(e.triangleCount>0)&&(this.markSubtree(e.leftChild,t),this.markSubtree(e.rightChild,t)))}optimizeTreelet(e){let t=[];this.extractLeaves(e,t);let n=t.length;if(n<3||n>this.maxTreeletLeaves)return;this.stats.treeletsProcessed++;let r=this.evaluateSubtreeSAH(e),i=this.topologyCache.get(n);if(!i||i.length===0)return;let a=r,o=null,s=null;if(n<=5){let e=this.generatePermutations(n);for(let n of i)for(let r of e){let e=this.evaluateTopology(n,t,r);e<a&&(a=e,o=n,s=r)}}else{let e=Array.from({length:n},(e,t)=>t);for(let n of i){let r=this.evaluateTopology(n,t,e);r<a&&(a=r,o=n,s=e);let i=this.greedySwapOptimize(n,t,e,r);i.cost<a&&(a=i.cost,o=n,s=i.perm)}}let c=(r-a)/r;o&&c>this.minImprovement&&(this.reconstructTreelet(e,o,t,s),this.stats.treeletsImproved++,this.stats.totalSAHImprovement+=c)}extractLeaves(e,t){if(e){if(e.triangleCount>0){t.push({minX:e.minX,minY:e.minY,minZ:e.minZ,maxX:e.maxX,maxY:e.maxY,maxZ:e.maxZ,triangleOffset:e.triangleOffset,triangleCount:e.triangleCount});return}this.extractLeaves(e.leftChild,t),this.extractLeaves(e.rightChild,t)}}evaluateSubtreeSAH(e){if(!e)return 0;if(e.triangleCount>0)return this.surfaceAreaFlat(e.minX,e.minY,e.minZ,e.maxX,e.maxY,e.maxZ)*e.triangleCount*this.intersectionCost;let t=this.evaluateSubtreeSAH(e.leftChild),n=this.evaluateSubtreeSAH(e.rightChild);return this.surfaceAreaFlat(e.minX,e.minY,e.minZ,e.maxX,e.maxY,e.maxZ)*this.traversalCost+t+n}evaluateTopology(e,t,n){return this.evalTopoRecursive(e,t,n).cost}evalTopoRecursive(e,t,n){if(typeof e==`number`){let r=t[n[e]];return{cost:this.surfaceAreaFlat(r.minX,r.minY,r.minZ,r.maxX,r.maxY,r.maxZ)*r.triangleCount*this.intersectionCost,minX:r.minX,minY:r.minY,minZ:r.minZ,maxX:r.maxX,maxY:r.maxY,maxZ:r.maxZ}}let r=this.evalTopoRecursive(e[0],t,n),i=this.evalTopoRecursive(e[1],t,n),a=Math.min(r.minX,i.minX),o=Math.min(r.minY,i.minY),s=Math.min(r.minZ,i.minZ),c=Math.max(r.maxX,i.maxX),l=Math.max(r.maxY,i.maxY),u=Math.max(r.maxZ,i.maxZ);return{cost:this.surfaceAreaFlat(a,o,s,c,l,u)*this.traversalCost+r.cost+i.cost,minX:a,minY:o,minZ:s,maxX:c,maxY:l,maxZ:u}}surfaceAreaFlat(e,t,n,r,i,a){let o=r-e,s=i-t,c=a-n;return 2*(o*s+s*c+c*o)}generatePermutations(e){let t=[],n=Array.from({length:e},(e,t)=>t),r=i=>{if(i===e){t.push([...n]);return}for(let t=i;t<e;t++)[n[i],n[t]]=[n[t],n[i]],r(i+1),[n[i],n[t]]=[n[t],n[i]]};return r(0),t}greedySwapOptimize(e,t,n,r){let i=[...n],a=r,o=!0;for(;o;){o=!1;for(let n=0;n<i.length-1;n++)for(let r=n+1;r<i.length;r++){[i[n],i[r]]=[i[r],i[n]];let s=this.evaluateTopology(e,t,i);s<a?(a=s,o=!0):[i[n],i[r]]=[i[r],i[n]]}}return{perm:i,cost:a}}reconstructTreelet(e,t,n,r){let i=this.buildSubtree(t,n,r);e.minX=i.minX,e.minY=i.minY,e.minZ=i.minZ,e.maxX=i.maxX,e.maxY=i.maxY,e.maxZ=i.maxZ,e.leftChild=i.leftChild,e.rightChild=i.rightChild,e.triangleOffset=i.triangleOffset,e.triangleCount=i.triangleCount}buildSubtree(e,t,n){if(typeof e==`number`){let r=t[n[e]],i=new Qi;return i.minX=r.minX,i.minY=r.minY,i.minZ=r.minZ,i.maxX=r.maxX,i.maxY=r.maxY,i.maxZ=r.maxZ,i.triangleOffset=r.triangleOffset,i.triangleCount=r.triangleCount,i}let r=this.buildSubtree(e[0],t,n),i=this.buildSubtree(e[1],t,n),a=new Qi;return a.leftChild=r,a.rightChild=i,a.minX=Math.min(r.minX,i.minX),a.minY=Math.min(r.minY,i.minY),a.minZ=Math.min(r.minZ,i.minZ),a.maxX=Math.max(r.maxX,i.maxX),a.maxY=Math.max(r.maxY,i.maxY),a.maxZ=Math.max(r.maxZ,i.maxZ),a}setTreeletSize(e){this.maxTreeletLeaves=Math.max(3,Math.min(7,e));for(let e=3;e<=this.maxTreeletLeaves;e++)this.topologyCache.has(e)||this.topologyCache.set(e,this.generateTopologies(e))}setMinImprovement(e){this.minImprovement=Math.max(.001,e)}setMaxTreelets(){}getStatistics(){return{...this.stats}}},Qi=class{constructor(){this.minX=0,this.minY=0,this.minZ=0,this.maxX=0,this.maxY=0,this.maxZ=0,this.leftChild=null,this.rightChild=null,this.triangleOffset=0,this.triangleCount=0}},$i=class{constructor(e,t){this.traversalCost=e,this.intersectionCost=t,this.batchSizeRatio=.02,this.maxIterations=2,this.timeBudgetMs=15e3,this.stats={reinsertionsApplied:0,iterations:0,timeMs:0}}setBatchSizeRatio(e){this.batchSizeRatio=Math.max(.005,Math.min(.1,e))}setMaxIterations(e){this.maxIterations=Math.max(1,Math.min(5,e))}getStatistics(){return{...this.stats}}surfaceArea(e){let t=e.maxX-e.minX,n=e.maxY-e.minY,r=e.maxZ-e.minZ;return t*n+n*r+r*t}buildParentMap(e){let t=new Map;t.set(e,{parent:null,isLeft:!1});let n=[e];for(;n.length>0;){let e=n.pop();e.triangleCount>0||(e.leftChild&&(t.set(e.leftChild,{parent:e,isLeft:!0}),n.push(e.leftChild)),e.rightChild&&(t.set(e.rightChild,{parent:e,isLeft:!1}),n.push(e.rightChild)))}return t}findCandidates(e,t,n){let r=[],i=[e];for(;i.length>0;){let a=i.pop();if(a!==e&&n.get(a).parent!==e){let e=this.surfaceArea(a);r.length<t?(r.push({node:a,cost:e}),r.length===t&&this._heapify(r)):e>r[0].cost&&(r[0]={node:a,cost:e},this._siftDown(r,0))}a.triangleCount===0&&(a.leftChild&&i.push(a.leftChild),a.rightChild&&i.push(a.rightChild))}return r}_heapify(e){for(let t=(e.length>>1)-1;t>=0;t--)this._siftDown(e,t)}_siftDown(e,t){let n=e.length;for(;;){let r=t,i=2*t+1,a=2*t+2;if(i<n&&e[i].cost<e[r].cost&&(r=i),a<n&&e[a].cost<e[r].cost&&(r=a),r===t)break;let o=e[t];e[t]=e[r],e[r]=o,t=r}}findReinsertion(e,t,n){let r=n.get(e),i=r.parent;if(!i)return null;let a=r.isLeft?i.rightChild:i.leftChild,o=this.surfaceArea(e),s=this.surfaceArea(i),c=null,l=0,u=s,d=a.minX,f=a.minY,p=a.minZ,m=a.maxX,h=a.maxY,g=a.maxZ,_=a,v=i,y=[];do{for(y.length=0,y.push(u,_);y.length>0;){let t=y.pop(),n=y.pop();if(n-o<=l)continue;let r=Math.min(t.minX,e.minX),i=Math.min(t.minY,e.minY),a=Math.min(t.minZ,e.minZ),s=Math.max(t.maxX,e.maxX),u=Math.max(t.maxY,e.maxY),d=Math.max(t.maxZ,e.maxZ),f=s-r,p=u-i,m=d-a,h=n-(f*p+p*m+m*f);if(h>l&&(c=t,l=h),t.triangleCount===0&&t.leftChild&&t.rightChild){let e=h+this.surfaceArea(t);y.push(e,t.leftChild),y.push(e,t.rightChild)}}let t=n.get(v);if(!t||t.parent===null)break;if(v!==i){d=Math.min(d,_.minX),f=Math.min(f,_.minY),p=Math.min(p,_.minZ),m=Math.max(m,_.maxX),h=Math.max(h,_.maxY),g=Math.max(g,_.maxZ);let e=m-d,t=h-f,n=g-p,r=e*t+t*n+n*e;u+=this.surfaceArea(v)-r}let r=t.parent;_=t.isLeft?r.rightChild:r.leftChild,v=r}while(n.get(v).parent!==null);return c===a||c===i?null:c?{from:e,to:c,areaDiff:l}:null}getConflicts(e,t,n){let r=n.get(e);return[t,e,r.isLeft?r.parent.rightChild:r.parent.leftChild,n.get(t).parent,r.parent]}reinsertNode(e,t,n){let r=n.get(e),i=r.parent,a=r.isLeft?i.rightChild:i.leftChild,o=n.get(i),s=o.parent,c=n.get(t),l=c.parent;o.isLeft?s.leftChild=a:s.rightChild=a,i.leftChild=e,i.rightChild=t,i.triangleOffset=0,i.triangleCount=0,i.minX=Math.min(e.minX,t.minX),i.minY=Math.min(e.minY,t.minY),i.minZ=Math.min(e.minZ,t.minZ),i.maxX=Math.max(e.maxX,t.maxX),i.maxY=Math.max(e.maxY,t.maxY),i.maxZ=Math.max(e.maxZ,t.maxZ),c.isLeft?l.leftChild=i:l.rightChild=i,n.set(a,{parent:s,isLeft:o.isLeft}),n.set(i,{parent:l,isLeft:c.isLeft}),n.set(e,{parent:i,isLeft:!0}),n.set(t,{parent:i,isLeft:!1}),this.refitFrom(s,n),this.refitFrom(l,n)}refitFrom(e,t){let n=e;for(;n;){if(n.triangleCount===0&&n.leftChild&&n.rightChild){let e=n.leftChild,t=n.rightChild;n.minX=Math.min(e.minX,t.minX),n.minY=Math.min(e.minY,t.minY),n.minZ=Math.min(e.minZ,t.minZ),n.maxX=Math.max(e.maxX,t.maxX),n.maxY=Math.max(e.maxY,t.maxY),n.maxZ=Math.max(e.maxZ,t.maxZ)}let e=t.get(n);n=e?e.parent:null}}optimizeBVH(e,t){let n=performance.now();this.stats={reinsertionsApplied:0,iterations:0,timeMs:0};for(let r=0;r<this.maxIterations&&!(performance.now()-n>this.timeBudgetMs);r++){let i=this.buildParentMap(e),a=i.size,o=Math.max(1,Math.floor(a*this.batchSizeRatio));t&&t(`Reinsertion iter ${r+1}/${this.maxIterations}: selecting ${o} candidates`);let s=this.findCandidates(e,o,i),c=[];for(let t=0;t<s.length&&!(performance.now()-n>this.timeBudgetMs);t++){let n=this.findReinsertion(s[t].node,e,i);n&&n.areaDiff>0&&c.push(n)}c.sort((e,t)=>t.areaDiff-e.areaDiff);let l=new Set,u=0;for(let e of c){let t=this.getConflicts(e.from,e.to,i);if(!t.some(e=>l.has(e))){for(let e of t)l.add(e);this.reinsertNode(e.from,e.to,i),u++}}if(this.stats.reinsertionsApplied+=u,this.stats.iterations=r+1,t&&t(`Reinsertion iter ${r+1}: applied ${u} reinsertions`),u===0)break}return this.stats.timeMs=performance.now()-n,this.stats}},ea=``+(typeof document>`u`&&typeof location>`u`?require(`url`).pathToFileURL(__dirname+`/assets/BVHWorker-CNJ0UBQz.js`).href:new URL(`assets/BVHWorker-CNJ0UBQz.js`,typeof document>`u`?location.href:document.currentScript&&document.currentScript.tagName.toUpperCase()===`SCRIPT`&&document.currentScript.src||document.baseURI).href),ta={FLOATS_PER_TRIANGLE:32,POSITION_A_OFFSET:0,POSITION_B_OFFSET:4,POSITION_C_OFFSET:8,NORMAL_A_OFFSET:12,NORMAL_B_OFFSET:16,NORMAL_C_OFFSET:20,UV_AB_OFFSET:24,UV_C_MAT_OFFSET:28},na=ta.FLOATS_PER_TRIANGLE,ra=class{constructor(){this.minX=0,this.minY=0,this.minZ=0,this.maxX=0,this.maxY=0,this.maxZ=0,this.leftChild=null,this.rightChild=null,this.triangleOffset=0,this.triangleCount=0}},ia=class{constructor(){this.useWorker=!0,this.maxLeafSize=8,this.numBins=32,this.minBins=8,this.maxBins=64,this.totalNodes=0,this.processedTriangles=0,this.totalTriangles=0,this.lastProgressUpdate=0,this.progressUpdateInterval=100,this.traversalCost=1,this.intersectionCost=2.5,this.useMortonCodes=!0,this.mortonBits=10,this.mortonClusterThreshold=128,this.enableObjectMedianFallback=!0,this.enableSpatialMedianFallback=!0,this.splitStats={sahSplits:0,objectMedianSplits:0,spatialMedianSplits:0,failedSplits:0,avgBinsUsed:0,totalSplitAttempts:0,mortonSortTime:0,totalBuildTime:0,treeletOptimizationTime:0,treeletsProcessed:0,treeletsImproved:0,averageSAHImprovement:0,reinsertionOptimizationTime:0,reinsertionsApplied:0,reinsertionIterations:0},this.enableTreeletOptimization=!0,this.treeletSize=5,this.treeletOptimizationPasses=1,this.treeletMinImprovement=.02,this.maxTreeletDepth=3,this.maxTreeletsPerScene=20,this.treeletComplexityThreshold=5e4,this.enableReinsertionOptimization=!0,this.reinsertionBatchSizeRatio=.02,this.reinsertionMaxIterations=2,this.initializeBinArrays(),this._partResult={mid:0,lMinX:0,lMinY:0,lMinZ:0,lMaxX:0,lMaxY:0,lMaxZ:0,rMinX:0,rMinY:0,rMinZ:0,rMaxX:0,rMaxY:0,rMaxZ:0},this.centroids=null,this.bMin=null,this.bMax=null,this.indices=null,this.mortonCodes=null,this.triangles=null,this.reorderedTriangleData=null}initializeBinArrays(){let e=this.maxBins;this.binBoundsMin=new Float32Array(e*3),this.binBoundsMax=new Float32Array(e*3),this.binCounts=new Uint32Array(e),this.leftPrefixMin=new Float32Array(e*3),this.leftPrefixMax=new Float32Array(e*3),this.leftPrefixCount=new Uint32Array(e),this.rightPrefixMin=new Float32Array(e*3),this.rightPrefixMax=new Float32Array(e*3),this.rightPrefixCount=new Uint32Array(e)}getOptimalBinCount(e){return e<=16?this.minBins:e<=64?16:e<=256?32:e<=1024?48:this.maxBins}setAdaptiveBinConfig(e){e.minBins!==void 0&&(this.minBins=Math.max(4,e.minBins)),e.maxBins!==void 0&&(this.maxBins=Math.min(128,e.maxBins)),e.baseBins!==void 0&&(this.numBins=e.baseBins),e.maxBins!==void 0&&this.initializeBinArrays()}setMortonConfig(e){e.enabled!==void 0&&(this.useMortonCodes=e.enabled),e.bits!==void 0&&(this.mortonBits=Math.max(6,Math.min(10,e.bits))),e.threshold!==void 0&&(this.mortonClusterThreshold=Math.max(16,e.threshold))}setFallbackConfig(e){e.objectMedian!==void 0&&(this.enableObjectMedianFallback=e.objectMedian),e.spatialMedian!==void 0&&(this.enableSpatialMedianFallback=e.spatialMedian)}setTreeletConfig(e){e.enabled!==void 0&&(this.enableTreeletOptimization=e.enabled),e.size!==void 0&&(this.treeletSize=Math.max(3,Math.min(12,e.size))),e.passes!==void 0&&(this.treeletOptimizationPasses=Math.max(1,Math.min(3,e.passes))),e.minImprovement!==void 0&&(this.treeletMinImprovement=Math.max(.001,e.minImprovement))}disableTreeletOptimization(){this.enableTreeletOptimization=!1}setReinsertionConfig(e){e.enabled!==void 0&&(this.enableReinsertionOptimization=e.enabled),e.batchSizeRatio!==void 0&&(this.reinsertionBatchSizeRatio=Math.max(.005,Math.min(.1,e.batchSizeRatio))),e.maxIterations!==void 0&&(this.reinsertionMaxIterations=Math.max(1,Math.min(5,e.maxIterations)))}initializeTriangleArrays(){let e=this.totalTriangles,t=this.triangles,n=ta.POSITION_A_OFFSET,r=ta.POSITION_B_OFFSET,i=ta.POSITION_C_OFFSET;for(let a=0;a<e;a++){let e=a*na,o=t[e+n],s=t[e+n+1],c=t[e+n+2],l=t[e+r],u=t[e+r+1],d=t[e+r+2],f=t[e+i],p=t[e+i+1],m=t[e+i+2],h=a*3;this.centroids[h]=(o+l+f)/3,this.centroids[h+1]=(s+u+p)/3,this.centroids[h+2]=(c+d+m)/3,this.bMin[h]=o<l?o<f?o:f:l<f?l:f,this.bMin[h+1]=s<u?s<p?s:p:u<p?u:p,this.bMin[h+2]=c<d?c<m?c:m:d<m?d:m,this.bMax[h]=o>l?o>f?o:f:l>f?l:f,this.bMax[h+1]=s>u?s>p?s:p:u>p?u:p,this.bMax[h+2]=c>d?c>m?c:m:d>m?d:m,this.indices[a]=a}}expandBits(e){return e=e*65537&4278190335,e=e*257&251719695,e=e*17&3272356035,e=e*5&1227133513,e}morton3D(e,t,n){return(this.expandBits(n)<<2)+(this.expandBits(t)<<1)+this.expandBits(e)}computeMortonCodeForIndex(e,t,n,r,i,a,o){let s=this.centroids,c=e*3,l=(1<<this.mortonBits)-1,u=i>0?(s[c]-t)/i:0,d=a>0?(s[c+1]-n)/a:0,f=o>0?(s[c+2]-r)/o:0,p=Math.max(0,Math.min(l,Math.floor(u*l))),m=Math.max(0,Math.min(l,Math.floor(d*l))),h=Math.max(0,Math.min(l,Math.floor(f*l)));return this.morton3D(p,m,h)}sortTrianglesByMortonCode(){let e=this.totalTriangles;if(!this.useMortonCodes||e<this.mortonClusterThreshold)return;let t=performance.now(),n=this.centroids,r=this.indices,i=1/0,a=1/0,o=1/0,s=-1/0,c=-1/0,l=-1/0;for(let t=0;t<e;t++){let e=r[t]*3,u=n[e],d=n[e+1],f=n[e+2];u<i&&(i=u),d<a&&(a=d),f<o&&(o=f),u>s&&(s=u),d>c&&(c=d),f>l&&(l=f)}let u=s-i,d=c-a,f=l-o,p=this.mortonCodes,m=(1<<this.mortonBits)-1,h=u>0?m/u:0,g=d>0?m/d:0,_=f>0?m/f:0;for(let t=0;t<e;t++){let e=r[t],s=e*3,c=(n[s]-i)*h,l=(n[s+1]-a)*g,u=(n[s+2]-o)*_;c=c<0?0:(c>m?m:c)|0,l=l<0?0:(l>m?m:l)|0,u=u<0?0:(u>m?m:u)|0,c=c*65537&4278190335,c=c*257&251719695,c=c*17&3272356035,c=c*5&1227133513,l=l*65537&4278190335,l=l*257&251719695,l=l*17&3272356035,l=l*5&1227133513,u=u*65537&4278190335,u=u*257&251719695,u=u*17&3272356035,u=u*5&1227133513,p[e]=(u<<2)+(l<<1)+c}let v=new Uint32Array(e),y=new Uint32Array(256);for(let t=0;t<32;t+=8){y.fill(0);for(let n=0;n<e;n++)y[p[r[n]]>>>t&255]++;let n=0;for(let e=0;e<256;e++){let t=y[e];y[e]=n,n+=t}for(let n=0;n<e;n++){let e=p[r[n]]>>>t&255;v[y[e]++]=r[n]}r.set(v)}this.splitStats.mortonSortTime+=performance.now()-t}build(e,t=30,n=null){return this.totalTriangles=e.byteLength/(na*4),this.processedTriangles=0,this.lastProgressUpdate=performance.now(),this.useWorker&&typeof Worker<`u`?new Promise((r,i)=>{let a=a=>{let o=this.totalTriangles,s=typeof SharedArrayBuffer<`u`;console.log(`[BVHBuilder] SharedArrayBuffer: ${s?`enabled`:`unavailable (using transfer fallback)`}`);let c=s?new SharedArrayBuffer(o*na*4):null;a.onmessage=e=>{let{bvhData:t,triangles:o,originalToBvh:s,error:l,progress:u,treeletStats:d}=e.data;if(l){a.terminate(),i(Error(l));return}if(u!==void 0&&n){n(u);return}d&&(this.splitStats=d),a.terminate(),r({bvhData:t,bvhRoot:!0,reorderedTriangles:c?new Float32Array(c):o,originalToBvh:s||null})},a.onerror=e=>{a.terminate(),i(e)};let l=e.buffer,u={triangleData:l,triangleByteOffset:e.byteOffset,triangleByteLength:e.byteLength,triangleCount:o,depth:t,reportProgress:!!n,sharedReorderBuffer:c,treeletOptimization:{enabled:this.enableTreeletOptimization,size:this.treeletSize,passes:this.treeletOptimizationPasses,minImprovement:this.treeletMinImprovement},reinsertionOptimization:{enabled:this.enableReinsertionOptimization,batchSizeRatio:this.reinsertionBatchSizeRatio,maxIterations:this.reinsertionMaxIterations}};a.postMessage(u,[l])};try{a(new Worker(ea,{type:`module`}))}catch(i){i.name===`SecurityError`?q(ea).then(a).catch(()=>{console.warn(`Worker fetch fallback failed, using synchronous build`),r(this._buildSyncAndFlatten(e,t,n))}):(console.warn(`Worker creation failed, falling back to synchronous build:`,i),r(this._buildSyncAndFlatten(e,t,n)))}}):new Promise(r=>{r(this._buildSyncAndFlatten(e,t,n))})}_buildSyncAndFlatten(e,t,n){let r=this.buildSync(e,t,n);return{bvhData:this.flattenBVH(r),bvhRoot:!0,reorderedTriangles:this.reorderedTriangleData||null,originalToBvh:this.originalToBvhMap||null}}buildSync(e,t=30,n=null,r=null){let i=performance.now();this.totalNodes=0,this.processedTriangles=0,this.triangles=e,this.totalTriangles=e.byteLength/(na*4),this.lastProgressUpdate=performance.now(),this.splitStats={sahSplits:0,objectMedianSplits:0,spatialMedianSplits:0,failedSplits:0,avgBinsUsed:0,totalSplitAttempts:0,mortonSortTime:0,totalBuildTime:0,treeletOptimizationTime:0,treeletsProcessed:0,treeletsImproved:0,averageSAHImprovement:0,reinsertionOptimizationTime:0,reinsertionsApplied:0,reinsertionIterations:0,saOrderTime:0,initTime:0,sahBuildTime:0,reorderTime:0};let a=this.totalTriangles,o=performance.now();this.centroids=new Float32Array(a*3),this.bMin=new Float32Array(a*3),this.bMax=new Float32Array(a*3),this.indices=new Uint32Array(a),this.mortonCodes=new Uint32Array(a),this.initializeTriangleArrays(),this.splitStats.initTime=performance.now()-o,this.sortTrianglesByMortonCode();let s=performance.now(),c=this.buildNodeRecursive(0,a,t,n);if(this.splitStats.sahBuildTime=performance.now()-s,this.enableTreeletOptimization&&this.totalTriangles>1e3){let e=this.totalTriangles>this.treeletComplexityThreshold,t=e?3:this.treeletSize,r=e?10:this.maxTreeletsPerScene,i=new Zi(this.traversalCost,this.intersectionCost);i.setTreeletSize(t),i.setMinImprovement(this.treeletMinImprovement),i.setMaxTreelets(r);let a=performance.now();for(let e=0;e<this.treeletOptimizationPasses;e++){let t=n?t=>{n(`Treelet optimization pass ${e+1}/${this.treeletOptimizationPasses}: ${t}`)}:null;try{i.optimizeBVH(c,t)}catch(t){console.error(`TreeletOptimizer: Error in pass ${e+1}:`,t);break}let r=i.getStatistics(),o=performance.now()-a;if(r.treeletsImproved===0&&e>0||o>15e3)break}let o=performance.now()-a;this.splitStats.treeletOptimizationTime=o;let s=i.getStatistics();this.splitStats.treeletsProcessed=s.treeletsProcessed,this.splitStats.treeletsImproved=s.treeletsImproved,this.splitStats.averageSAHImprovement=s.averageSAHImprovement}if(this.enableReinsertionOptimization&&this.totalTriangles>1e3){let e=new $i(this.traversalCost,this.intersectionCost);e.setBatchSizeRatio(this.reinsertionBatchSizeRatio),e.setMaxIterations(this.reinsertionMaxIterations);let t=n?e=>{n(e)}:null;try{e.optimizeBVH(c,t)}catch(e){console.error(`ReinsertionOptimizer: Error:`,e)}let r=e.getStatistics();this.splitStats.reinsertionOptimizationTime=r.timeMs,this.splitStats.reinsertionsApplied=r.reinsertionsApplied,this.splitStats.reinsertionIterations=r.iterations}let l=performance.now();this.applySAOrdering(c),this.splitStats.saOrderTime=performance.now()-l;let u=performance.now(),d=this.triangles,f=r||new Float32Array(a*na);for(let e=0;e<a;e++){let t=this.indices[e]*na,n=e*na;f.set(d.subarray(t,t+na),n)}this.reorderedTriangleData=f;let p=new Uint32Array(a);for(let e=0;e<a;e++)p[this.indices[e]]=e;this.originalToBvhMap=p,this.splitStats.reorderTime=performance.now()-u,this.splitStats.totalBuildTime=performance.now()-i;let m=this.splitStats.totalBuildTime,h=this.splitStats;return console.log(`[BVH] ${a.toLocaleString()} tris → ${this.totalNodes} nodes in ${Math.round(m)}ms | SAH ${h.sahSplits} objMed ${h.objectMedianSplits} spatMed ${h.spatialMedianSplits} failed ${h.failedSplits}`+(h.treeletsProcessed?` | treelets ${h.treeletsImproved}/${h.treeletsProcessed} improved`:``)+(h.reinsertionsApplied?` | reinsertions ${h.reinsertionsApplied}`:``)),n&&n(100),this.centroids=null,this.bMin=null,this.bMax=null,this.mortonCodes=null,c}updateProgress(e,t){if(!t)return;this.processedTriangles+=e;let n=performance.now();n-this.lastProgressUpdate<this.progressUpdateInterval||(this.lastProgressUpdate=n,t(Math.min(Math.floor(this.processedTriangles/this.totalTriangles*100),99)))}buildNodeRecursiveToDepth(e,t,n,r,i,a,o,s,c,l,u){let d=new ra;this.totalNodes++;let f=t-e;if(a===void 0?this.updateNodeBounds(d,e,t):(d.minX=a,d.minY=o,d.minZ=s,d.maxX=c,d.maxY=l,d.maxZ=u),f<=this.maxLeafSize||n<=0)return d.triangleOffset=e,d.triangleCount=f,this.updateProgress(f,i),d;if(r<=0&&f>this.maxLeafSize*16){let r=this.frontierTasks.length;return d.triangleOffset=e,d.triangleCount=f,d.isFrontier=!0,d.frontierTaskId=r,this.frontierTasks.push({taskId:r,start:e,end:t,depth:n,preMinX:d.minX,preMinY:d.minY,preMinZ:d.minZ,preMaxX:d.maxX,preMaxY:d.maxY,preMaxZ:d.maxZ}),d}let p=this.findBestSplitPositionSAH(e,t,d);if(!p.success){if(this.splitStats.failedSplits++,r>0||f<=this.maxLeafSize*16)return d.triangleOffset=e,d.triangleCount=f,this.updateProgress(f,i),d;let a=this.frontierTasks.length;return d.triangleOffset=e,d.triangleCount=f,d.isFrontier=!0,d.frontierTaskId=a,this.frontierTasks.push({taskId:a,start:e,end:t,depth:n,preMinX:d.minX,preMinY:d.minY,preMinZ:d.minZ,preMaxX:d.maxX,preMaxY:d.maxY,preMaxZ:d.maxZ}),d}p.method===`SAH`?this.splitStats.sahSplits++:p.method===`object_median`?this.splitStats.objectMedianSplits++:p.method===`spatial_median`&&this.splitStats.spatialMedianSplits++,this.partitionWithBounds(e,t,p.axis,p.pos);let m=this._partResult,h=m.mid,g=m.lMinX,_=m.lMinY,v=m.lMinZ,y=m.lMaxX,b=m.lMaxY,x=m.lMaxZ,S=m.rMinX,C=m.rMinY,w=m.rMinZ,T=m.rMaxX,E=m.rMaxY,D=m.rMaxZ;return h===e||h===t?(d.triangleOffset=e,d.triangleCount=f,this.updateProgress(f,i),d):(d.leftChild=this.buildNodeRecursiveToDepth(e,h,n-1,r-1,i,g,_,v,y,b,x),d.rightChild=this.buildNodeRecursiveToDepth(h,t,n-1,r-1,i,S,C,w,T,E,D),d)}buildNodeRecursive(e,t,n,r,i,a,o,s,c,l){let u=new ra;this.totalNodes++;let d=t-e;if(i===void 0?this.updateNodeBounds(u,e,t):(u.minX=i,u.minY=a,u.minZ=o,u.maxX=s,u.maxY=c,u.maxZ=l),d<=this.maxLeafSize||n<=0)return u.triangleOffset=e,u.triangleCount=d,this.updateProgress(d,r),u;let f=this.findBestSplitPositionSAH(e,t,u);if(!f.success)return this.splitStats.failedSplits++,u.triangleOffset=e,u.triangleCount=d,this.updateProgress(d,r),u;f.method===`SAH`?this.splitStats.sahSplits++:f.method===`object_median`?this.splitStats.objectMedianSplits++:f.method===`spatial_median`&&this.splitStats.spatialMedianSplits++,this.partitionWithBounds(e,t,f.axis,f.pos);let p=this._partResult,m=p.mid,h=p.lMinX,g=p.lMinY,_=p.lMinZ,v=p.lMaxX,y=p.lMaxY,b=p.lMaxZ,x=p.rMinX,S=p.rMinY,C=p.rMinZ,w=p.rMaxX,T=p.rMaxY,E=p.rMaxZ;return m===e||m===t?(u.triangleOffset=e,u.triangleCount=d,this.updateProgress(d,r),u):(u.leftChild=this.buildNodeRecursive(e,m,n-1,r,h,g,_,v,y,b),u.rightChild=this.buildNodeRecursive(m,t,n-1,r,x,S,C,w,T,E),u)}partitionWithBounds(e,t,n,r){let i=this.indices,a=this.centroids,o=this.bMin,s=this.bMax,c=e,l=t-1,u=1/0,d=1/0,f=1/0,p=-1/0,m=-1/0,h=-1/0,g=1/0,_=1/0,v=1/0,y=-1/0,b=-1/0,x=-1/0;for(;c<=l;){let e=i[c],t=e*3;a[t+n]<=r?(o[t]<u&&(u=o[t]),o[t+1]<d&&(d=o[t+1]),o[t+2]<f&&(f=o[t+2]),s[t]>p&&(p=s[t]),s[t+1]>m&&(m=s[t+1]),s[t+2]>h&&(h=s[t+2]),c++):(o[t]<g&&(g=o[t]),o[t+1]<_&&(_=o[t+1]),o[t+2]<v&&(v=o[t+2]),s[t]>y&&(y=s[t]),s[t+1]>b&&(b=s[t+1]),s[t+2]>x&&(x=s[t+2]),i[c]=i[l],i[l]=e,l--)}let S=this._partResult;return S.mid=c,S.lMinX=u,S.lMinY=d,S.lMinZ=f,S.lMaxX=p,S.lMaxY=m,S.lMaxZ=h,S.rMinX=g,S.rMinY=_,S.rMinZ=v,S.rMaxX=y,S.rMaxY=b,S.rMaxZ=x,S}updateNodeBounds(e,t,n){let r=1/0,i=1/0,a=1/0,o=-1/0,s=-1/0,c=-1/0,l=this.indices,u=this.bMin,d=this.bMax;for(let e=t;e<n;e++){let t=l[e]*3;u[t]<r&&(r=u[t]),u[t+1]<i&&(i=u[t+1]),u[t+2]<a&&(a=u[t+2]),d[t]>o&&(o=d[t]),d[t+1]>s&&(s=d[t+1]),d[t+2]>c&&(c=d[t+2])}e.minX=r,e.minY=i,e.minZ=a,e.maxX=o,e.maxY=s,e.maxZ=c}findBestSplitPositionSAH(e,t,n){let r=1/0,i=-1,a=0,o=this.computeSurfaceAreaFlat(n.minX,n.minY,n.minZ,n.maxX,n.maxY,n.maxZ),s=t-e,c=this.intersectionCost*s,l=this.getOptimalBinCount(s);this.splitStats.totalSplitAttempts++,this.splitStats.avgBinsUsed=(this.splitStats.avgBinsUsed*(this.splitStats.totalSplitAttempts-1)+l)/this.splitStats.totalSplitAttempts;let u=this.indices,d=this.centroids,f=this.bMin,p=this.bMax,m=this.binBoundsMin,h=this.binBoundsMax,g=this.binCounts,_=this.leftPrefixMin,v=this.leftPrefixMax,y=this.leftPrefixCount,b=this.rightPrefixMin,x=this.rightPrefixMax,S=this.rightPrefixCount,C=1/0,w=-1/0,T=1/0,E=-1/0,D=1/0,O=-1/0;for(let n=e;n<t;n++){let e=u[n]*3,t=d[e],r=d[e+1],i=d[e+2];t<C&&(C=t),t>w&&(w=t),r<T&&(T=r),r>E&&(E=r),i<D&&(D=i),i>O&&(O=i)}let k=[C,T,D],A=[w,E,O];for(let n=0;n<3;n++){let s=k[n],C=A[n];if(C-s<1e-6)continue;for(let e=0;e<l;e++){g[e]=0;let t=e*3;m[t]=1/0,m[t+1]=1/0,m[t+2]=1/0,h[t]=-1/0,h[t+1]=-1/0,h[t+2]=-1/0}let w=l/(C-s);for(let r=e;r<t;r++){let e=u[r],t=d[e*3+n],i=Math.floor((t-s)*w);i>=l&&(i=l-1),g[i]++;let a=i*3,o=e*3;f[o]<m[a]&&(m[a]=f[o]),f[o+1]<m[a+1]&&(m[a+1]=f[o+1]),f[o+2]<m[a+2]&&(m[a+2]=f[o+2]),p[o]>h[a]&&(h[a]=p[o]),p[o+1]>h[a+1]&&(h[a+1]=p[o+1]),p[o+2]>h[a+2]&&(h[a+2]=p[o+2])}y[0]=g[0],_[0]=m[0],_[1]=m[1],_[2]=m[2],v[0]=h[0],v[1]=h[1],v[2]=h[2];for(let e=1;e<l;e++){let t=e*3,n=(e-1)*3;y[e]=y[e-1]+g[e];let r=_[n],i=m[t],a=_[n+1],o=m[t+1],s=_[n+2],c=m[t+2];_[t]=r<i?r:i,_[t+1]=a<o?a:o,_[t+2]=s<c?s:c;let l=v[n],u=h[t],d=v[n+1],f=h[t+1],p=v[n+2],b=h[t+2];v[t]=l>u?l:u,v[t+1]=d>f?d:f,v[t+2]=p>b?p:b}let T=l-1,E=T*3;S[T]=g[T],b[E]=m[E],b[E+1]=m[E+1],b[E+2]=m[E+2],x[E]=h[E],x[E+1]=h[E+1],x[E+2]=h[E+2];for(let e=T-1;e>=0;e--){let t=e*3,n=(e+1)*3;S[e]=S[e+1]+g[e];let r=b[n],i=m[t],a=b[n+1],o=m[t+1],s=b[n+2],c=m[t+2];b[t]=r<i?r:i,b[t+1]=a<o?a:o,b[t+2]=s<c?s:c;let l=x[n],u=h[t],d=x[n+1],f=h[t+1],p=x[n+2],_=h[t+2];x[t]=l>u?l:u,x[t+1]=d>f?d:f,x[t+2]=p>_?p:_}for(let e=1;e<l;e++){let t=(e-1)*3,u=e*3,d=y[e-1],f=S[e];if(d===0||f===0)continue;let p=v[t]-_[t],m=v[t+1]-_[t+1],h=v[t+2]-_[t+2],g=2*(p*m+m*h+h*p),w=x[u]-b[u],T=x[u+1]-b[u+1],E=x[u+2]-b[u+2],D=2*(w*T+T*E+E*w),O=this.traversalCost+g/o*d*this.intersectionCost+D/o*f*this.intersectionCost;O<r&&O<c&&(r=O,i=n,a=s+(C-s)*e/l)}}return i===-1?this.enableObjectMedianFallback?this.findObjectMedianSplit(e,t):this.enableSpatialMedianFallback?this.findSpatialMedianSplit(e,t):{success:!1,method:`fallbacks_disabled`}:{success:!0,axis:i,pos:a,method:`SAH`,binsUsed:l}}findObjectMedianSplit(e,t){let n=this.indices,r=this.centroids,i=-1,a=-1;for(let o=0;o<3;o++){let s=1/0,c=-1/0;for(let i=e;i<t;i++){let e=r[n[i]*3+o];e<s&&(s=e),e>c&&(c=e)}let l=c-s;l>a&&(a=l,i=o)}if(i===-1||a<1e-10)return this.enableSpatialMedianFallback?this.findSpatialMedianSplit(e,t):{success:!1,method:`object_median_failed`};let o=t-e,s=e+Math.floor(o/2);this.quickselect(e,t,s,i);let c=r[n[s]*3+i],l=!0;for(let e=s+1;e<t;e++)if(r[n[e]*3+i]>c){l=!1;break}if(l){let a=-1/0;for(let t=e;t<s;t++){let e=r[n[t]*3+i];e>a&&(a=e)}if(a<c)c=(a+c)*.5;else return this.enableSpatialMedianFallback?this.findSpatialMedianSplit(e,t):{success:!1,method:`object_median_degenerate`}}return{success:!0,axis:i,pos:c,method:`object_median`}}findSpatialMedianSplit(e,t){let n=this.indices,r=this.centroids,i=this.bMin,a=this.bMax,o=-1,s=-1,c=0,l=0;for(let r=0;r<3;r++){let u=1/0,d=-1/0;for(let o=e;o<t;o++){let e=n[o]*3+r;i[e]<u&&(u=i[e]),a[e]>d&&(d=a[e])}let f=d-u;f>s&&(s=f,o=r,c=u,l=d)}if(o===-1||s<1e-12)return{success:!1,method:`spatial_median_failed`};let u=(c+l)*.5,d=t-e,f=0;for(let i=e;i<t;i++)r[n[i]*3+o]<=u&&f++;if(f===0||f===d){let i=e+Math.floor(d/2);this.quickselect(e,t,i,o);let a=r[n[i]*3+o],s=!0;for(let i=e;i<t;i++)if(r[n[i]*3+o]!==a){s=!1;break}if(s)return{success:!1,method:`spatial_median_degenerate`};let c=-1/0;for(let t=e;t<i;t++){let e=r[n[t]*3+o];e>c&&(c=e)}if(c<a)u=(c+a)*.5;else{let e=1/0;for(let a=i+1;a<t;a++){let t=r[n[a]*3+o];t<e&&(e=t)}u=(a+e)*.5}}return{success:!0,axis:o,pos:u,method:`spatial_median`}}quickselect(e,t,n,r){let i=this.indices,a=this.centroids,o=e,s=t-1;for(;o<s;){let e=o+s>>>1,t=a[i[o]*3+r],c=a[i[e]*3+r],l=a[i[s]*3+r];if(t>c){let t=i[o];i[o]=i[e],i[e]=t}if(t>l){let e=i[o];i[o]=i[s],i[s]=e}if(c>l){let t=i[e];i[e]=i[s],i[s]=t}let u=a[i[e]*3+r],d=o,f=s;for(;d<=f;){for(;a[i[d]*3+r]<u;)d++;for(;a[i[f]*3+r]>u;)f--;if(d<=f){let e=i[d];i[d]=i[f],i[f]=e,d++,f--}}f<n&&(o=d),d>n&&(s=f)}}applySAOrdering(e){if(!e||!e.leftChild)return;let t=[e],n=[];for(;t.length>0;){let e=t.pop();!e.leftChild||!e.rightChild||(n.push(e),t.push(e.leftChild),t.push(e.rightChild))}for(let e=n.length-1;e>=0;e--){let t=n[e],r=t.leftChild,i=t.rightChild,a=r.maxX-r.minX,o=r.maxY-r.minY,s=r.maxZ-r.minZ,c=i.maxX-i.minX,l=i.maxY-i.minY,u=i.maxZ-i.minZ;c*l+l*u+u*c>a*o+o*s+s*a&&(t.leftChild=i,t.rightChild=r)}}flattenBVH(e){let t=[],n=[e];for(;n.length>0;){let e=n.pop();e._flatIndex=t.length,t.push(e),e.rightChild&&n.push(e.rightChild),e.leftChild&&n.push(e.leftChild)}let r=new Float32Array(t.length*16);for(let e=0;e<t.length;e++){let n=t[e],i=e*16;if(n.leftChild){let e=n.leftChild,t=n.rightChild;r[i]=e.minX,r[i+1]=e.minY,r[i+2]=e.minZ,r[i+3]=e._flatIndex,r[i+4]=e.maxX,r[i+5]=e.maxY,r[i+6]=e.maxZ,r[i+7]=t._flatIndex,r[i+8]=t.minX,r[i+9]=t.minY,r[i+10]=t.minZ,r[i+12]=t.maxX,r[i+13]=t.maxY,r[i+14]=t.maxZ}else r[i]=n.triangleOffset,r[i+1]=n.triangleCount,r[i+3]=-1}return r}flattenBVHWithFrontier(e){let t=[],n=[e];for(;n.length>0;){let e=n.pop();e._flatIndex=t.length,t.push(e),e.rightChild&&n.push(e.rightChild),e.leftChild&&n.push(e.leftChild)}let r=new Float32Array(t.length*16),i=[];for(let e=0;e<t.length;e++){let n=t[e],a=e*16;if(n.leftChild){let e=n.leftChild,t=n.rightChild;r[a]=e.minX,r[a+1]=e.minY,r[a+2]=e.minZ,r[a+3]=e._flatIndex,r[a+4]=e.maxX,r[a+5]=e.maxY,r[a+6]=e.maxZ,r[a+7]=t._flatIndex,r[a+8]=t.minX,r[a+9]=t.minY,r[a+10]=t.minZ,r[a+12]=t.maxX,r[a+13]=t.maxY,r[a+14]=t.maxZ}else if(n.isFrontier){let t=n.frontierTaskId;r[a]=n.triangleOffset,r[a+1]=n.triangleCount,r[a+2]=t,r[a+3]=-2,i.push({taskId:t,flatIndex:e})}else r[a]=n.triangleOffset,r[a+1]=n.triangleCount,r[a+3]=-1}return{flatData:r,frontierMap:i,nodeCount:t.length}}assembleParallelBVH(e,t,n,r){let i=[...r].sort((e,t)=>e.taskId-t.taskId),a=t;for(let e=0;e<i.length;e++)a+=i[e].nodeCount;let o=new Float32Array(a*16);o.set(e);let s=new Map;for(let e of n)s.set(e.taskId,e.flatIndex);let c=t;for(let e=0;e<i.length;e++){let t=i[e],n=t.flatData,r=t.nodeCount,a=c*16;o.set(n,a);for(let e=0;e<r;e++){let t=a+e*16;o[t+3]!==-1&&(o[t+3]+=c,o[t+7]+=c)}let l=s.get(t.taskId);if(l!==void 0){let e=l*16,t=a;for(let n=0;n<16;n++)o[e+n]=o[t+n]}c+=r}return o}computeSurfaceAreaFlat(e,t,n,r,i,a){let o=r-e,s=i-t,c=a-n;return 2*(o*s+s*c+c*o)}},Z={FLOATS_PER_TRIANGLE:32,POSITION_A_OFFSET:0,POSITION_B_OFFSET:4,POSITION_C_OFFSET:8,NORMAL_A_OFFSET:12,NORMAL_B_OFFSET:16,NORMAL_C_OFFSET:20},aa=Z.FLOATS_PER_TRIANGLE,oa=16,sa=-1,ca=-2,la=class{constructor(){this._bounds=null,this._boundsNodeCount=0}updateTrianglePositions(e,t,n){let r=n.length;for(let i=0;i<r;i++){let r=n[i],a=i*aa,o=r*9,s=t[o],c=t[o+1],l=t[o+2],u=t[o+3],d=t[o+4],f=t[o+5],p=t[o+6],m=t[o+7],h=t[o+8];e[a+Z.POSITION_A_OFFSET]=s,e[a+Z.POSITION_A_OFFSET+1]=c,e[a+Z.POSITION_A_OFFSET+2]=l,e[a+Z.POSITION_B_OFFSET]=u,e[a+Z.POSITION_B_OFFSET+1]=d,e[a+Z.POSITION_B_OFFSET+2]=f,e[a+Z.POSITION_C_OFFSET]=p,e[a+Z.POSITION_C_OFFSET+1]=m,e[a+Z.POSITION_C_OFFSET+2]=h;let g=u-s,_=d-c,v=f-l,y=p-s,b=m-c,x=h-l,S=_*x-v*b,C=v*y-g*x,w=g*b-_*y;e[a+Z.NORMAL_A_OFFSET]=S,e[a+Z.NORMAL_A_OFFSET+1]=C,e[a+Z.NORMAL_A_OFFSET+2]=w,e[a+Z.NORMAL_B_OFFSET]=S,e[a+Z.NORMAL_B_OFFSET+1]=C,e[a+Z.NORMAL_B_OFFSET+2]=w,e[a+Z.NORMAL_C_OFFSET]=S,e[a+Z.NORMAL_C_OFFSET+1]=C,e[a+Z.NORMAL_C_OFFSET+2]=w}}refitRange(e,t,n,r){r>this._boundsNodeCount&&(this._bounds=new Float32Array(r*6),this._boundsNodeCount=r);let i=this._bounds,a=n+r;for(let r=a-1;r>=n;r--){let a=r*oa,o=(r-n)*6;if(e[a+3]===sa){let n=e[a],r=e[a+1],s=1/0,c=1/0,l=1/0,u=-1/0,d=-1/0,f=-1/0;for(let e=0;e<r;e++){let r=(n+e)*aa,i=t[r+Z.POSITION_A_OFFSET],a=t[r+Z.POSITION_A_OFFSET+1],o=t[r+Z.POSITION_A_OFFSET+2],p=t[r+Z.POSITION_B_OFFSET],m=t[r+Z.POSITION_B_OFFSET+1],h=t[r+Z.POSITION_B_OFFSET+2],g=t[r+Z.POSITION_C_OFFSET],_=t[r+Z.POSITION_C_OFFSET+1],v=t[r+Z.POSITION_C_OFFSET+2];s=Math.min(s,i,p,g),c=Math.min(c,a,m,_),l=Math.min(l,o,h,v),u=Math.max(u,i,p,g),d=Math.max(d,a,m,_),f=Math.max(f,o,h,v)}i[o]=s,i[o+1]=c,i[o+2]=l,i[o+3]=u,i[o+4]=d,i[o+5]=f}else{let t=e[a+3],r=e[a+7],s=(t-n)*6,c=(r-n)*6,l=i[s],u=i[s+1],d=i[s+2],f=i[s+3],p=i[s+4],m=i[s+5],h=i[c],g=i[c+1],_=i[c+2],v=i[c+3],y=i[c+4],b=i[c+5];e[a]=l,e[a+1]=u,e[a+2]=d,e[a+4]=f,e[a+5]=p,e[a+6]=m,e[a+8]=h,e[a+9]=g,e[a+10]=_,e[a+12]=v,e[a+13]=y,e[a+14]=b,i[o]=Math.min(l,h),i[o+1]=Math.min(u,g),i[o+2]=Math.min(d,_),i[o+3]=Math.max(f,v),i[o+4]=Math.max(p,y),i[o+5]=Math.max(m,b)}}}refit(e,t,n){n!==this._boundsNodeCount&&(this._bounds=new Float32Array(n*6),this._boundsNodeCount=n);let r=this._bounds;for(let i=n-1;i>=0;i--){let n=i*oa,a=i*6,o=e[n+3];if(o===sa){let i=e[n],o=e[n+1],s=1/0,c=1/0,l=1/0,u=-1/0,d=-1/0,f=-1/0;for(let e=0;e<o;e++){let n=(i+e)*aa,r=t[n+Z.POSITION_A_OFFSET],a=t[n+Z.POSITION_A_OFFSET+1],o=t[n+Z.POSITION_A_OFFSET+2],p=t[n+Z.POSITION_B_OFFSET],m=t[n+Z.POSITION_B_OFFSET+1],h=t[n+Z.POSITION_B_OFFSET+2],g=t[n+Z.POSITION_C_OFFSET],_=t[n+Z.POSITION_C_OFFSET+1],v=t[n+Z.POSITION_C_OFFSET+2];s=Math.min(s,r,p,g),c=Math.min(c,a,m,_),l=Math.min(l,o,h,v),u=Math.max(u,r,p,g),d=Math.max(d,a,m,_),f=Math.max(f,o,h,v)}r[a]=s,r[a+1]=c,r[a+2]=l,r[a+3]=u,r[a+4]=d,r[a+5]=f}else if(o===ca){let t=e[n]*6;r[a]=r[t],r[a+1]=r[t+1],r[a+2]=r[t+2],r[a+3]=r[t+3],r[a+4]=r[t+4],r[a+5]=r[t+5]}else{let t=e[n+3],i=e[n+7],o=t*6,s=i*6,c=r[o],l=r[o+1],u=r[o+2],d=r[o+3],f=r[o+4],p=r[o+5],m=r[s],h=r[s+1],g=r[s+2],_=r[s+3],v=r[s+4],y=r[s+5];e[n]=c,e[n+1]=l,e[n+2]=u,e[n+4]=d,e[n+5]=f,e[n+6]=p,e[n+8]=m,e[n+9]=h,e[n+10]=g,e[n+12]=_,e[n+13]=v,e[n+14]=y,r[a]=Math.min(c,m),r[a+1]=Math.min(l,h),r[a+2]=Math.min(u,g),r[a+3]=Math.max(d,_),r[a+4]=Math.max(f,v),r[a+5]=Math.max(p,y)}}}},ua=``+(typeof document>`u`&&typeof location>`u`?require(`url`).pathToFileURL(__dirname+`/assets/BVHSubtreeWorker-D9GImjGj.js`).href:new URL(`assets/BVHSubtreeWorker-D9GImjGj.js`,typeof document>`u`?location.href:document.currentScript&&document.currentScript.tagName.toUpperCase()===`SCRIPT`&&document.currentScript.src||document.baseURI).href),da=32,fa=5e4,pa=8;function ma(e,t,n,r){let i=e.byteLength/(da*4),a=Math.min(navigator.hardwareConcurrency||4,pa),o=Math.ceil(Math.log2(a*2.5+1));return console.log(`[ParallelBVH] Parallel build: ${i.toLocaleString()} triangles, ${a} workers, parallelDepth=${o}`),new Promise((s,c)=>{(async()=>{let c=new SharedArrayBuffer(e.byteLength);new Float32Array(c).set(e);let l=new SharedArrayBuffer(i*3*4),u=new SharedArrayBuffer(i*3*4),d=new SharedArrayBuffer(i*3*4),f=new SharedArrayBuffer(i*4),p=new SharedArrayBuffer(i*4),m=new SharedArrayBuffer(i*da*4),h;try{h=new Worker(ea,{type:`module`})}catch(e){if(e.name!==`SecurityError`)throw e;h=await q(ea)}let g=null,_=[h],v={id:null},y=!1,b=()=>{v.id&&=(clearTimeout(v.id),null);for(let e of _)try{e.terminate()}catch{}},x=e=>{if(y)return;y=!0,console.warn(`[ParallelBVH] Parallel build failed (${e}), falling back to single worker`),b();let i=new ArrayBuffer(c.byteLength);new Float32Array(i).set(new Float32Array(c)),s(ga(new Float32Array(i),t,n,r))};h.onerror=e=>{x(`coordinator error: ${e.message}`)},h.onmessage=e=>{let t=e.data;if(t.error||t.type===`error`){x(t.error);return}if(t.type===`progress`&&n){n(Math.floor(t.progress*.3));return}if(t.type===`phase1Result`){g=t.splitStats,ha(t,a,c,l,u,d,f,m,i,n,h,_,b,x,s,v,r).catch(e=>x(e.message));return}if(t.type===`assembleResult`){y=!0,b();let e=new Float32Array(m);s({bvhData:t.bvhData,bvhRoot:!0,reorderedTriangles:e,originalToBvh:t.originalToBvh||null,splitStats:g||{}});return}},n&&n(0),h.postMessage({type:`buildPhase1`,sharedTriangleData:c,sharedCentroids:l,sharedBMin:u,sharedBMax:d,sharedIndices:f,sharedMortonCodes:p,triangleCount:i,depth:t,parallelDepth:o,reportProgress:!!n,treeletOptimization:r.treeletOptimization})})().catch(e=>{console.warn(`[ParallelBVH] Parallel build setup failed:`,e),c(e)})})}async function ha(e,t,n,r,i,a,o,s,c,l,u,d,f,p,m,h,g){let{topFlatData:_,topNodeCount:v,frontierTasks:y,frontierMap:b}=e;if(!y||y.length===0){console.log(`[ParallelBVH] No frontier tasks, assembling with top-level tree only`),u.postMessage({type:`assemble`,topFlatData:_,topNodeCount:v,frontierMap:[],subtreeResults:[],sharedTriangleData:n,sharedIndices:o,sharedReorderBuffer:s,triangleCount:c},[_.buffer]);return}console.log(`[ParallelBVH] Phase 2: distributing ${y.length} tasks across ${t} workers`);let x=[...y].sort((e,t)=>t.end-t.start-(e.end-e.start)),S=Array.from({length:Math.min(t,x.length)},()=>[]),C=Array(S.length).fill(0);for(let e of x){let t=0;for(let e=1;e<C.length;e++)C[e]<C[t]&&(t=e);S[t].push(e),C[t]+=e.end-e.start}let w=[],T=0,E=y.length,D=y.reduce((e,t)=>e+(t.end-t.start),0),O=0;h.id=setTimeout(()=>{p(`Phase 2 timeout (30s)`)},3e4);let k=()=>{clearTimeout(h.id),h.id=null,l&&l(85);let t=[];e.topFlatData&&e.topFlatData.buffer&&t.push(e.topFlatData.buffer);for(let e of w)e.flatData&&e.flatData.buffer&&t.push(e.flatData.buffer);u.postMessage({type:`assemble`,topFlatData:e.topFlatData,topNodeCount:v,frontierMap:b,subtreeResults:w,sharedTriangleData:n,sharedIndices:o,sharedReorderBuffer:s,triangleCount:c},t)},A=S.length;for(let e=0;e<A;e++){let t=S[e];if(t.length===0)continue;let s;try{s=new Worker(ua,{type:`module`})}catch(e){if(e.name!==`SecurityError`)throw e;s=await q(ua)}d.push(s),s.onerror=e=>{p(`subtree worker error: ${e.message}`)},s.onmessage=e=>{let t=e.data;if(t.type===`error`){p(`subtree task ${t.taskId} error: ${t.error}`);return}if(t.type===`progress`&&l){let e=30+Math.floor(O/D*55);l(Math.min(e,85));return}if(t.type===`subtreeResult`){w.push({taskId:t.taskId,flatData:t.flatData,nodeCount:t.nodeCount});let e=y.find(e=>e.taskId===t.taskId);if(e&&(O+=e.end-e.start),T++,l){let e=30+Math.floor(O/D*55);l(Math.min(e,85))}if(T===E){for(let e of d)if(e!==u)try{e.terminate()}catch{}k()}}},s.postMessage({tasks:t,sharedTriangleData:n,sharedCentroids:r,sharedBMin:i,sharedBMax:a,sharedIndices:o,triangleCount:c,maxLeafSize:g.maxLeafSize,numBins:g.numBins,maxBins:g.maxBins,minBins:g.minBins,treeletConfig:g.treeletOptimization,reinsertionConfig:g.reinsertionOptimization,reportProgress:!!l})}}function ga(e,t,n,r){return new Promise((i,a)=>{(async()=>{let o;try{o=new Worker(ea,{type:`module`})}catch(e){if(e.name!==`SecurityError`)throw e;o=await q(ea)}let s=e.byteLength/(da*4),c=typeof SharedArrayBuffer<`u`?new SharedArrayBuffer(s*da*4):null;o.onmessage=e=>{let{bvhData:t,triangles:r,originalToBvh:s,error:l,progress:u,treeletStats:d}=e.data;if(l){o.terminate(),a(Error(l));return}if(u!==void 0&&n){n(u);return}o.terminate(),i({bvhData:t,bvhRoot:!0,reorderedTriangles:c?new Float32Array(c):r,originalToBvh:s||null,splitStats:d||{}})},o.onerror=e=>{o.terminate(),a(e)};let l=e.buffer;o.postMessage({triangleData:l,triangleByteOffset:e.byteOffset,triangleByteLength:e.byteLength,triangleCount:s,depth:t,reportProgress:!!n,sharedReorderBuffer:c,treeletOptimization:r.treeletOptimization,reinsertionOptimization:r.reinsertionOptimization},[l])})().catch(e=>{console.warn(`[ParallelBVH] Single worker fallback failed:`,e),a(e)})})}function _a(e){return typeof Worker<`u`&&typeof SharedArrayBuffer<`u`&&e>=fa}var va=16,ya=class{constructor(){this.minX=0,this.minY=0,this.minZ=0,this.maxX=0,this.maxY=0,this.maxZ=0,this.leftChild=null,this.rightChild=null,this.entryIndex=-1}},ba=class{constructor(){this._flatBuffer=null,this._flatBufferCapacity=0}build(e){if(e.length===0)return{root:null,nodeCount:0};let t=[];for(let n=0;n<e.length;n++)t.push(n);let n=this._buildRecursive(e,t);return{root:n,nodeCount:this._countNodes(n)}}_buildRecursive(e,t){let n=new ya;if(t.length===1){let r=e[t[0]].worldAABB;return n.minX=r.minX,n.minY=r.minY,n.minZ=r.minZ,n.maxX=r.maxX,n.maxY=r.maxY,n.maxZ=r.maxZ,n.entryIndex=t[0],n}let r=1/0,i=1/0,a=1/0,o=-1/0,s=-1/0,c=-1/0;for(let n of t){let t=e[n].worldAABB;t.minX<r&&(r=t.minX),t.minY<i&&(i=t.minY),t.minZ<a&&(a=t.minZ),t.maxX>o&&(o=t.maxX),t.maxY>s&&(s=t.maxY),t.maxZ>c&&(c=t.maxZ)}if(n.minX=r,n.minY=i,n.minZ=a,n.maxX=o,n.maxY=s,n.maxZ=c,t.length===2)return n.leftChild=this._buildRecursive(e,[t[0]]),n.rightChild=this._buildRecursive(e,[t[1]]),n;let l=this._surfaceArea(r,i,a,o,s,c),u=1/0,d=0,f=0;if(l>0&&isFinite(l))for(let n=0;n<3;n++){let r=t.slice().sort((t,r)=>{let i=e[t].worldAABB,a=e[r].worldAABB;return this._centroid(i,n)-this._centroid(a,n)});for(let t=1;t<r.length;t++){let i=this._computeGroupAABB(e,r,0,t),a=this._computeGroupAABB(e,r,t,r.length),o=this._surfaceArea(i.minX,i.minY,i.minZ,i.maxX,i.maxY,i.maxZ),s=this._surfaceArea(a.minX,a.minY,a.minZ,a.maxX,a.maxY,a.maxZ),c=1+(o*t+s*(r.length-t))/l;c<u&&(u=c,d=n,f=t)}}if(f<=0||f>=t.length){d=0;let e=o-r,n=s-i,l=c-a;n>e&&n>l?d=1:l>e&&(d=2),f=t.length>>1}let p=t.slice().sort((t,n)=>this._centroid(e[t].worldAABB,d)-this._centroid(e[n].worldAABB,d)),m=p.slice(0,f),h=p.slice(f);return n.leftChild=this._buildRecursive(e,m),n.rightChild=this._buildRecursive(e,h),n}flatten(e,t){if(!e)return new Float32Array;let n=[],r=[e];for(;r.length>0;){let e=r.pop();e._flatIndex=n.length,n.push(e),e.rightChild&&r.push(e.rightChild),e.leftChild&&r.push(e.leftChild)}let i=n.length*va;i>this._flatBufferCapacity&&(this._flatBuffer=new Float32Array(i),this._flatBufferCapacity=i);let a=this._flatBuffer;a.fill(0,0,i);for(let e=0;e<n.length;e++){let r=n[e],i=e*va;if(r.leftChild){let e=r.leftChild,t=r.rightChild;a[i]=e.minX,a[i+1]=e.minY,a[i+2]=e.minZ,a[i+3]=e._flatIndex,a[i+4]=e.maxX,a[i+5]=e.maxY,a[i+6]=e.maxZ,a[i+7]=t._flatIndex,a[i+8]=t.minX,a[i+9]=t.minY,a[i+10]=t.minZ,a[i+12]=t.maxX,a[i+13]=t.maxY,a[i+14]=t.maxZ}else{let n=t[r.entryIndex];a[i]=n.blasOffset,a[i+1]=r.entryIndex,a[i+2]=n.visible===!1?0:1,a[i+3]=ke.BLAS_POINTER_LEAF,n.tlasLeafIndex=e}}return a.subarray(0,i)}_centroid(e,t){return t===0?(e.minX+e.maxX)*.5:t===1?(e.minY+e.maxY)*.5:(e.minZ+e.maxZ)*.5}_surfaceArea(e,t,n,r,i,a){let o=r-e,s=i-t,c=a-n;return 2*(o*s+s*c+c*o)}_computeGroupAABB(e,t,n,r){let i=1/0,a=1/0,o=1/0,s=-1/0,c=-1/0,l=-1/0;for(let u=n;u<r;u++){let n=e[t[u]].worldAABB;n.minX<i&&(i=n.minX),n.minY<a&&(a=n.minY),n.minZ<o&&(o=n.minZ),n.maxX>s&&(s=n.maxX),n.maxY>c&&(c=n.maxY),n.maxZ>l&&(l=n.maxZ)}return{minX:i,minY:a,minZ:o,maxX:s,maxY:c,maxZ:l}}_countNodes(e){if(!e)return 0;let t=0,n=[e];for(;n.length>0;){let e=n.pop();t++,e.leftChild&&n.push(e.leftChild),e.rightChild&&n.push(e.rightChild)}return t}},xa=class{constructor(){this.entries=[],this.totalBLASNodes=0,this.tlasNodeCount=0}allocate(e){this.entries=Array(e).fill(null)}setEntry({meshIndex:e,blasNodeCount:t,triOffset:n,triCount:r,originalToBvhMap:i,bvhData:a}){this.entries[e]={meshIndex:e,blasOffset:0,blasNodeCount:t,triOffset:n,triCount:r,worldAABB:null,originalToBvhMap:i,bvhData:a,visible:!0,tlasLeafIndex:-1}}setVisibility(e,t){let n=this.entries[e];n&&(n.visible=t)}computeAABBs(e){for(let t of this.entries)t&&(t.worldAABB=this._readRootAABB(t.bvhData,t,e))}recomputeAABB(e,t,n){let r=this.entries[e],i=t.subarray(r.blasOffset*16,r.blasOffset*16+16);r.worldAABB=this._readRootAABB(i,r,n)}_readRootAABB(e,t,n){if(e[3]===-1)return this._computeAABBFromTriangles(t,n);let r=e[0],i=e[1],a=e[2],o=e[4],s=e[5],c=e[6],l=e[8],u=e[9],d=e[10],f=e[12],p=e[13],m=e[14];return{minX:Math.min(r,l),minY:Math.min(i,u),minZ:Math.min(a,d),maxX:Math.max(o,f),maxY:Math.max(s,p),maxZ:Math.max(c,m)}}_computeAABBFromTriangles(e,t){let n=H.FLOATS_PER_TRIANGLE,r=1/0,i=1/0,a=1/0,o=-1/0,s=-1/0,c=-1/0;for(let l=0;l<e.triCount;l++){let u=(e.triOffset+l)*n;for(let e=0;e<=8;e+=4){let n=t[u+e],l=t[u+e+1],d=t[u+e+2];n<r&&(r=n),l<i&&(i=l),d<a&&(a=d),n>o&&(o=n),l>s&&(s=l),d>c&&(c=d)}}return{minX:r,minY:i,minZ:a,maxX:o,maxY:s,maxZ:c}}assignOffsets(e){this.tlasNodeCount=e;let t=e;for(let e of this.entries)e&&(e.blasOffset=t,t+=e.blasNodeCount);this.totalBLASNodes=t-e}get totalNodeCount(){return this.tlasNodeCount+this.totalBLASNodes}get count(){return this.entries.length}clear(){this.entries=[],this.totalBLASNodes=0,this.tlasNodeCount=0}},Sa=``+(typeof document>`u`&&typeof location>`u`?require(`url`).pathToFileURL(__dirname+`/assets/TexturesWorker-DBqGmVdR.js`).href:new URL(`assets/TexturesWorker-DBqGmVdR.js`,typeof document>`u`?location.href:document.currentScript&&document.currentScript.tagName.toUpperCase()===`SCRIPT`&&document.currentScript.src||document.baseURI).href),Ca=class{constructor(){this.canvasContextPairs=[],this.maxPoolSize=Ae.CANVAS_POOL_SIZE}getCanvasWithContext(e,t,n=!1,r={}){let i={willReadFrequently:!0,alpha:!0,desynchronized:!0,...r},a=this.canvasContextPairs.pop();if(!a){let r;r=n&&typeof OffscreenCanvas<`u`?new OffscreenCanvas(e,t):document.createElement(`canvas`);let o=r.getContext(`2d`,i);a={canvas:r,context:o}}return a.canvas.width=e,a.canvas.height=t,a}releaseCanvasWithContext(e){this.canvasContextPairs.length<this.maxPoolSize&&(e.context.globalAlpha=1,e.context.globalCompositeOperation=`source-over`,e.context.imageSmoothingEnabled=!0,e.context.clearRect(0,0,e.canvas.width,e.canvas.height),e.canvas.width=1,e.canvas.height=1,this.canvasContextPairs.push(e))}getCanvas(e,t,n=!1){return this.getCanvasWithContext(e,t,n).canvas}getContext(e,t={}){let n=this.canvasContextPairs.find(t=>t.canvas===e);return n?n.context:e.getContext(`2d`,{willReadFrequently:!0,alpha:!0,desynchronized:!0,...t})}dispose(){this.canvasContextPairs=[]}},wa=class{constructor(e={}){this.pools=new Map,this.memoryUsage=0,this.maxMemoryUsage=e.maxMemory||Ne.MAX_BUFFER_MEMORY,this.allocatedBuffers=new WeakMap,this.sizeStrategy=e.sizeStrategy||`adaptive`}getOptimalSize(e){switch(this.sizeStrategy){case`exact`:return e;case`power2`:return 2**Math.ceil(Math.log2(e));default:return e<1024?e:e<1024*1024?Math.ceil(e/1024)*1024:2**Math.ceil(Math.log2(e))}}getBuffer(e,t=Float32Array){let n=this.getOptimalSize(e),r=`${t.name}-${n}`,i=(this.pools.get(r)||[]).pop();if(!i)try{i=new t(n),this.memoryUsage+=i.byteLength,this.allocatedBuffers.set(i,!0)}catch{this.cleanup();try{i=new t(n),this.memoryUsage+=i.byteLength,this.allocatedBuffers.set(i,!0)}catch(e){let r=n*t.BYTES_PER_ELEMENT/(1024*1024),i=this.memoryUsage/(1024*1024);throw Error(`Buffer allocation failed: requested ${r.toFixed(1)}MB, current usage: ${i.toFixed(1)}MB, max: ${(this.maxMemoryUsage/(1024*1024)).toFixed(1)}MB. Original error: ${e.message}`)}}return this.memoryUsage>this.maxMemoryUsage*Ne.CLEANUP_THRESHOLD&&this.cleanup(),this.checkMemoryHealth(),i.byteOffset+e*t.BYTES_PER_ELEMENT>i.buffer.byteLength&&(i=new t(e),this.memoryUsage+=i.byteLength),new t(i.buffer,i.byteOffset,e)}releaseBuffer(e,t=Float32Array){let n=(e.buffer.byteLength-e.byteOffset)/t.BYTES_PER_ELEMENT,r=this.getOptimalSize(n),i=`${t.name}-${r}`,a=this.pools.get(i)||[];a.length<Ae.BUFFER_POOL_SIZE?(a.push(new t(e.buffer,e.byteOffset,n)),this.pools.set(i,a)):this.allocatedBuffers.has(e)&&(this.memoryUsage-=e.byteLength,this.allocatedBuffers.delete(e))}cleanup(){let e=Array.from(this.pools.entries());e.slice(0,Math.floor(e.length/2)).forEach(([e,t])=>{t.forEach(e=>{this.allocatedBuffers.has(e)&&(this.memoryUsage-=e.byteLength,this.allocatedBuffers.delete(e))}),this.pools.delete(e)})}dispose(){this.pools.forEach(e=>{e.forEach(e=>{this.allocatedBuffers.has(e)&&this.allocatedBuffers.delete(e)})}),this.pools.clear(),this.memoryUsage=0}getMemoryStats(){return{currentUsage:this.memoryUsage,maxUsage:this.maxMemoryUsage,utilizationPercentage:this.memoryUsage/this.maxMemoryUsage*100,poolCount:this.pools.size,allocatedBufferCount:this.allocatedBuffers&&this.allocatedBuffers.size||0}}checkMemoryHealth(){let e=this.getMemoryStats();return e.utilizationPercentage>90?(console.warn(`Memory pool critical: ${e.utilizationPercentage.toFixed(1)}% used (${(e.currentUsage/(1024*1024)).toFixed(1)}MB / ${(e.maxUsage/(1024*1024)).toFixed(1)}MB)`),`critical`):e.utilizationPercentage>70?(console.warn(`Memory pool high: ${e.utilizationPercentage.toFixed(1)}% used (${(e.currentUsage/(1024*1024)).toFixed(1)}MB / ${(e.maxUsage/(1024*1024)).toFixed(1)}MB)`),`high`):`normal`}},Ta=class{constructor(e=Ae.CACHE_SIZE_LIMIT){this.cache=new Map,this.accessOrder=[],this.maxSize=e}generateHash(e){let t=``;for(let n of e)if(n?.image){let e=n.image.width||0,r=n.image.height||0,i=n.image.src||n.uuid||``,a=n.flipY===!1?`n`:`f`;t+=`${e}x${r}_${i.slice(-8)}_${a}_`}return t+e.length}get(e){if(this.cache.has(e)){let t=this.accessOrder.indexOf(e);return t>-1&&this.accessOrder.splice(t,1),this.accessOrder.push(e),this.cache.get(e)}return null}set(e,t){if(this.cache.has(e)){let t=this.accessOrder.indexOf(e);t>-1&&this.accessOrder.splice(t,1)}else this.cache.size>=this.maxSize&&this.evictLRU();this.cache.set(e,t),this.accessOrder.push(e)}evictLRU(){if(this.accessOrder.length>0){let e=this.accessOrder.shift(),t=this.cache.get(e);t&&t.dispose&&t.dispose(),this.cache.delete(e)}}dispose(){this.cache.forEach(e=>{e&&e.dispose&&e.dispose()}),this.cache.clear(),this.accessOrder=[]}},Ea=class{constructor(e={}){this.useWorkers=typeof Worker<`u`,this.maxConcurrentWorkers=Ae.MAX_CONCURRENT_WORKERS,this.activeWorkers=0,this.canvasPool=new Ca,this.bufferPool=new wa({maxMemory:e.maxBufferMemory||Ne.MAX_BUFFER_MEMORY,sizeStrategy:e.bufferSizeStrategy||`adaptive`}),this.textureCache=new Ta,this.capabilities=this.detectCapabilities(),this.optimalMethod=this.selectOptimalMethod()}detectCapabilities(){return{offscreenCanvas:typeof OffscreenCanvas<`u`,imageBitmap:typeof createImageBitmap<`u`,workers:typeof Worker<`u`,hardwareConcurrency:navigator.hardwareConcurrency||4}}selectOptimalMethod(){return this.capabilities.workers&&this.capabilities.offscreenCanvas?`worker-offscreen`:this.capabilities.imageBitmap?`imageBitmap`:`canvas`}async createTexturesToDataTexture(e){if(!e||e.length===0)return null;let t=this.textureCache.generateHash(e),n=this.textureCache.get(t);if(n)return n;let{normalized:r,bitmapsToClose:i}=await this._normalizeTexturesForProcessing(e),a=this.selectProcessingStrategy(r),o;try{switch(a.method){case`worker-direct`:o=await this.processWithWorkerDirect(r);break;case`worker-chunked`:o=await this.processWithWorkerChunked(r,a.chunkSize);break;case`main-batch`:o=await this.processOnMainThreadBatch(r,a.batchSize);break;case`main-streaming`:o=await this.processOnMainThreadStreaming(r);break;default:o=await this.processOnMainThreadSync(r)}return o&&this.textureCache.set(t,o),o}catch(e){return console.warn(`Texture processing failed, trying fallback:`,e),await this.processOnMainThreadSync(r)}finally{for(let e of i)e.close()}}selectProcessingStrategy(e){let t=e.reduce((e,t)=>e+(t.image?.width||0)*(t.image?.height||0),0),n=t*4;return this.capabilities.workers&&n>Ne.MAX_TEXTURE_MEMORY?{method:`worker-chunked`,chunkSize:Math.max(1,Math.floor(e.length/4))}:this.capabilities.workers&&t>2097152?{method:`worker-direct`}:t>524288?{method:`main-batch`,batchSize:Math.min(4,e.length)}:e.length>8?{method:`main-streaming`}:{method:`main-sync`}}async processWithWorkerDirect(e){for(;this.activeWorkers>=this.maxConcurrentWorkers;)await new Promise(e=>setTimeout(e,10));this.activeWorkers++;try{let t;try{t=new Worker(Sa,{type:`module`})}catch(e){if(e.name!==`SecurityError`)throw e;t=await q(Sa)}let n=await this.prepareTexturesForWorkerDirect(e),r=await new Promise((e,r)=>{t.onmessage=t=>{t.data.error?r(Error(t.data.error)):e(t.data)},t.onerror=r;let i=[];n.forEach(e=>{e.data instanceof ArrayBuffer?i.push(e.data):e.bitmap&&i.push(e.bitmap)}),t.postMessage({textures:n,maxTextureSize:Ae.MAX_TEXTURE_SIZE,method:`direct-transfer`},i)});return t.terminate(),this.createDataArrayTextureFromResult(r)}finally{this.activeWorkers--}}async prepareTexturesForWorkerDirect(e){let t=[];for(let n of e){if(!n?.image)continue;let e=n.flipY!==!1;try{if(typeof createImageBitmap<`u`&&n.image instanceof HTMLImageElement){let r=await createImageBitmap(n.image,{imageOrientation:e?`flipY`:`none`});t.push({bitmap:r,width:n.image.width,height:n.image.height,isDirect:!0})}else{let r=n.image.width,i=n.image.height,a=await createImageBitmap(n.image,{imageOrientation:e?`flipY`:`none`}),o=this.canvasPool.getCanvasWithContext(r,i);o.context.drawImage(a,0,0),a.close();let s=o.context.getImageData(0,0,r,i);t.push({data:s.data.buffer,width:r,height:i,isImageData:!0}),this.canvasPool.releaseCanvasWithContext(o)}}catch(e){console.warn(`Failed to prepare texture for worker:`,e)}}return t}async processWithWorkerChunked(e,t){let n=[];for(let r=0;r<e.length;r+=t){let i=e.slice(r,r+t),a=await this.processWithWorkerDirect(i);n.push(a)}return this.combineTextureResults(n)}async processOnMainThreadBatch(e,t){let n=e.filter(e=>e?.image);if(n.length===0)return this.createFallbackTexture();let{maxWidth:r,maxHeight:i}=this.calculateOptimalDimensions(n),a=n.length,o=this.bufferPool.getBuffer(r*i*a*4,Uint8Array);for(let e=0;e<n.length;e+=t){let a=Math.min(e+t,n.length),s=[];for(let t=e;t<a;t++){let e=n[t],a=e.flipY!==!1,o=createImageBitmap(e.image,{resizeWidth:r,resizeHeight:i,resizeQuality:`high`,imageOrientation:a?`flipY`:`none`});s.push(o.then(e=>({bitmap:e,index:t})))}let c=await Promise.all(s),l=this.canvasPool.getCanvasWithContext(r,i);l.context.imageSmoothingEnabled=!1;for(let{bitmap:e,index:t}of c){l.context.clearRect(0,0,r,i),l.context.drawImage(e,0,0);let n=l.context.getImageData(0,0,r,i),a=r*i*4*t;o.set(n.data,a),e.close()}this.canvasPool.releaseCanvasWithContext(l)}return this.createDataArrayTextureFromBuffer(o,r,i,a)}async processOnMainThreadStreaming(e){let t=e.filter(e=>e?.image);if(t.length===0)return this.createFallbackTexture();let{maxWidth:n,maxHeight:r}=this.calculateOptimalDimensions(t),i=t.length,a=this.bufferPool.getBuffer(n*r*i*4,Uint8Array),o=this.canvasPool.getCanvasWithContext(n,r);o.context.imageSmoothingEnabled=!0,o.context.imageSmoothingQuality=`high`;for(let e=0;e<t.length;e++){let i=t[e],s=await createImageBitmap(i.image,{resizeWidth:n,resizeHeight:r,resizeQuality:`high`,imageOrientation:i.flipY===!1?`none`:`flipY`});o.context.clearRect(0,0,n,r),o.context.drawImage(s,0,0),s.close();let c=o.context.getImageData(0,0,n,r),l=n*r*4*e;a.set(c.data,l),e%Ne.STREAM_BATCH_SIZE===0&&await new Promise(e=>setTimeout(e,0))}return this.canvasPool.releaseCanvasWithContext(o),this.createDataArrayTextureFromBuffer(a,n,r,i)}async processOnMainThreadSync(e){let t=e.filter(e=>e?.image);if(t.length===0)return this.createFallbackTexture();let{maxWidth:n,maxHeight:r}=this.calculateOptimalDimensions(t),i=t.length,a=this.bufferPool.getBuffer(n*r*i*4,Uint8Array),o=this.canvasPool.getCanvasWithContext(n,r);o.context.imageSmoothingEnabled=!0,o.context.imageSmoothingQuality=`high`;for(let e=0;e<t.length;e++){let i=t[e],s=await createImageBitmap(i.image,{resizeWidth:n,resizeHeight:r,resizeQuality:`high`,imageOrientation:i.flipY===!1?`none`:`flipY`});o.context.clearRect(0,0,n,r),o.context.drawImage(s,0,0),s.close();let c=o.context.getImageData(0,0,n,r),l=n*r*4*e;a.set(c.data,l)}return this.canvasPool.releaseCanvasWithContext(o),this.createDataArrayTextureFromBuffer(a,n,r,i)}createMaterialRawData(e){let t=U.FLOATS_PER_MATERIAL,n=e.length,r=n*t,i=new Float32Array(r);for(let r=0;r<n;r++){let n=e[r],a=r*t,o=n.mapMatrix??W,s=n.normalMapMatrices??W,c=n.roughnessMapMatrices??W,l=n.metalnessMapMatrices??W,u=n.emissiveMapMatrices??W,d=n.bumpMapMatrices??W,f=n.displacementMapMatrices??W,p=[n.ior,n.transmission,n.thickness,n.emissiveIntensity,n.attenuationColor.r,n.attenuationColor.g,n.attenuationColor.b,n.attenuationDistance,n.opacity,n.side,n.transparent,n.alphaTest,n.alphaMode,n.depthWrite,n.normalScale?.x??1,n.normalScale?.y??1,n.color.r,n.color.g,n.color.b,n.metalness,n.emissive.r,n.emissive.g,n.emissive.b,n.roughness,n.map,n.normalMap,n.roughnessMap,n.metalnessMap,n.emissiveMap,n.bumpMap,n.clearcoat,n.clearcoatRoughness,n.dispersion,n.visible,n.sheen,n.sheenRoughness,n.sheenColor.r,n.sheenColor.g,n.sheenColor.b,1,n.specularIntensity,n.specularColor.r,n.specularColor.g,n.specularColor.b,n.iridescence,n.iridescenceIOR,n.iridescenceThicknessRange[0],n.iridescenceThicknessRange[1],n.bumpScale,n.displacementScale,n.displacementMap,0,o[0],o[1],o[2],o[3],o[4],o[5],o[6],1,s[0],s[1],s[2],s[3],s[4],s[5],s[6],1,c[0],c[1],c[2],c[3],c[4],c[5],c[6],1,l[0],l[1],l[2],l[3],l[4],l[5],l[6],1,u[0],u[1],u[2],u[3],u[4],u[5],u[6],1,d[0],d[1],d[2],d[3],d[4],d[5],d[6],1,f[0],f[1],f[2],f[3],f[4],f[5],f[6],1];i.set(p,a)}return i}createBVHRawData(e){let t=[],n=e=>{let r=t.length;if(t.push(e),e.leftChild){let t=n(e.leftChild),r=n(e.rightChild);e.leftChild=t,e.rightChild=r}return r};n(e);let r=Ae.VEC4_PER_BVH_NODE*Ae.FLOATS_PER_VEC4,i=t.length*r,a=new Float32Array(i);for(let e=0;e<t.length;e++){let n=e*r,i=t[e];if(i.leftChild!==null){let e=i.leftChild,r=i.rightChild,o=t[e],s=t[r];a[n]=o.boundsMin.x,a[n+1]=o.boundsMin.y,a[n+2]=o.boundsMin.z,a[n+3]=e,a[n+4]=o.boundsMax.x,a[n+5]=o.boundsMax.y,a[n+6]=o.boundsMax.z,a[n+7]=r,a[n+8]=s.boundsMin.x,a[n+9]=s.boundsMin.y,a[n+10]=s.boundsMin.z,a[n+12]=s.boundsMax.x,a[n+13]=s.boundsMax.y,a[n+14]=s.boundsMax.z}else a[n]=i.triangleOffset,a[n+1]=i.triangleCount,a[n+3]=-1}return a}async createMaterialTextures(e){let{materials:t,maps:n,normalMaps:i,bumpMaps:a,roughnessMaps:o,metalnessMaps:s,emissiveMaps:c,displacementMaps:l}=e;console.log(`[TextureCreator] Creating material textures only`);let u=performance.now();try{if(!t||t.length===0)throw Error(`No materials provided for texture creation`);this.textureCache.dispose(),this.textureCache=new Ta;let e=[];n&&n.length>0&&e.push(this.createTexturesToDataTexture(n).then(e=>({type:`albedo`,texture:e})).catch(e=>(console.warn(`Failed to create albedo textures:`,e),{type:`albedo`,texture:null}))),i&&i.length>0&&e.push(this.createTexturesToDataTexture(i).then(e=>({type:`normal`,texture:e})).catch(e=>(console.warn(`Failed to create normal textures:`,e),{type:`normal`,texture:null}))),a&&a.length>0&&e.push(this.createTexturesToDataTexture(a).then(e=>({type:`bump`,texture:e})).catch(e=>(console.warn(`Failed to create bump textures:`,e),{type:`bump`,texture:null}))),o&&o.length>0&&e.push(this.createTexturesToDataTexture(o).then(e=>({type:`roughness`,texture:e})).catch(e=>(console.warn(`Failed to create roughness textures:`,e),{type:`roughness`,texture:null}))),s&&s.length>0&&e.push(this.createTexturesToDataTexture(s).then(e=>({type:`metalness`,texture:e})).catch(e=>(console.warn(`Failed to create metalness textures:`,e),{type:`metalness`,texture:null}))),c&&c.length>0&&e.push(this.createTexturesToDataTexture(c).then(e=>({type:`emissive`,texture:e})).catch(e=>(console.warn(`Failed to create emissive textures:`,e),{type:`emissive`,texture:null}))),l&&l.length>0&&e.push(this.createTexturesToDataTexture(l).then(e=>({type:`displacement`,texture:e})).catch(e=>(console.warn(`Failed to create displacement textures:`,e),{type:`displacement`,texture:null})));let d=await Promise.allSettled(e),f={};d.forEach(e=>{if(e.status===`fulfilled`&&e.value){let{type:t,texture:n}=e.value;if(n)switch(t){case`albedo`:n.colorSpace=r.SRGBColorSpace,f.albedoTexture=n;break;case`normal`:f.normalTexture=n;break;case`bump`:f.bumpTexture=n;break;case`roughness`:f.roughnessTexture=n;break;case`metalness`:f.metalnessTexture=n;break;case`emissive`:n.colorSpace=r.SRGBColorSpace,f.emissiveTexture=n;break;case`displacement`:f.displacementTexture=n;break}}});let p=performance.now()-u;return console.log(`[TextureCreator] Material texture creation complete (${p.toFixed(2)}ms)`),f}catch(e){throw console.error(`[TextureCreator] Material texture creation error:`,e),Error(`Material texture creation failed: ${e.message}`)}}calculateOptimalDimensions(e){let t=0,n=0;for(let r of e)t=Math.max(t,r.image.width),n=Math.max(n,r.image.height);for(t=2**Math.ceil(Math.log2(t)),n=2**Math.ceil(Math.log2(n));t>=Ae.MAX_TEXTURE_SIZE/2||n>=Ae.MAX_TEXTURE_SIZE/2;)t=Math.max(1,Math.floor(t/2)),n=Math.max(1,Math.floor(n/2));return{maxWidth:t,maxHeight:n}}createDataArrayTextureFromResult(e){let t=(e.data instanceof ArrayBuffer,new Uint8Array(e.data));return this.createDataArrayTextureFromBuffer(t,e.width,e.height,e.depth)}createDataArrayTextureFromBuffer(e,t,n,i){let a=new r.DataArrayTexture(e,t,n,i);a.minFilter=r.LinearFilter,a.magFilter=r.LinearFilter,a.format=r.RGBAFormat,a.type=r.UnsignedByteType,a.needsUpdate=!0,a.generateMipmaps=!1,a.userData={buffer:e,bufferType:Uint8Array};let o=a.dispose.bind(a);return a.dispose=()=>{a.userData.buffer&&(this.bufferPool.releaseBuffer(a.userData.buffer,a.userData.bufferType),a.userData.buffer=null),o()},a}async _normalizeTexturesForProcessing(e){let t=[],n=[],i=[];for(let n of e)if(n?.image){if(n.isCompressedTexture&&n.format===r.RGBAFormat&&n.mipmaps?.[0]?.data){let e=n.mipmaps[0],r=t.length;t.push(null),i.push({index:r,flipY:n.flipY,promise:Da(e.data,e.width,e.height)});continue}if(n.isCompressedTexture){console.warn(`[TextureCreator] GPU-compressed texture in mixed group — using placeholder`),t.push(null);continue}if(n.image.data&&!(n.image instanceof HTMLImageElement)&&!(n.image instanceof HTMLCanvasElement)&&!(typeof ImageBitmap<`u`&&n.image instanceof ImageBitmap)){let e=t.length;t.push(null),i.push({index:e,flipY:n.flipY,promise:Da(n.image.data,n.image.width,n.image.height)});continue}t.push(n)}if(i.length>0){let e=await Promise.allSettled(i.map(e=>e.promise));for(let r=0;r<i.length;r++){let{index:a,flipY:o}=i[r],s=e[r];if(s.status===`fulfilled`){let e=s.value;n.push(e),t[a]={image:e,flipY:o}}else console.warn(`[TextureCreator] Failed to create ImageBitmap:`,s.reason)}}for(let e=0;e<t.length;e++)if(t[e]===null){let r=new Uint8ClampedArray([255,255,255,255]),i=await createImageBitmap(new ImageData(r,1,1));n.push(i),t[e]={image:i,flipY:!1}}return{normalized:t,bitmapsToClose:n}}createFallbackTexture(){let e=new r.DataArrayTexture(new Uint8Array([255,255,255,255]),1,1,1);return e.minFilter=r.LinearFilter,e.magFilter=r.LinearFilter,e.format=r.RGBAFormat,e.type=r.UnsignedByteType,e.needsUpdate=!0,e.generateMipmaps=!1,e}combineTextureResults(e){return e[0]}dispose(){this.canvasPool.dispose(),this.bufferPool.dispose(),this.textureCache.dispose()}};function Da(e,t,n){let r=new Uint8ClampedArray(e.buffer,e.byteOffset,e.byteLength);return createImageBitmap(new ImageData(r,t,n))}var Oa=128,ka=class{constructor(){this._vectorPool={vec3:Array(9).fill().map(()=>new r.Vector3),vec2:[,,,,,,].fill().map(()=>new r.Vector2)},this._matrixPool={mat3:new r.Matrix3,mat4:new r.Matrix4},this.resetArrays(),this.triangleCount=0,this.currentTriangleIndex=0}_getVec3(e=0){return this._vectorPool.vec3[e%this._vectorPool.vec3.length]}_getVec2(e=0){return this._vectorPool.vec2[e%this._vectorPool.vec2.length]}extract(e){return this.resetArrays(),this._triangleCapacity=1024,this.triangleData=new Float32Array(this._triangleCapacity*H.FLOATS_PER_TRIANGLE),this.currentTriangleIndex=0,this.traverseObject(e),this.logStats(),this.getExtractedData()}_ensureCapacity(e){if(e<=this._triangleCapacity)return;let t=this._triangleCapacity;for(;t<e;)t*=2;let n=new Float32Array(t*H.FLOATS_PER_TRIANGLE);n.set(this.triangleData),this.triangleData=n,this._triangleCapacity=t}traverseObject(e){if(e.isMesh?this.processMesh(e):e.isDirectionalLight?this.directionalLights.push(e):e.isCamera&&this.cameras.push(e),e.children)for(let t of e.children)this.traverseObject(t)}processMesh(e){if(!e.geometry||!e.material){console.warn(`Skipping mesh with missing geometry or material:`,e);return}let t=this.processMaterial(e.material);e.userData.materialIndex=t;let n=this.meshes.length;this.meshes.push(e),e.userData.meshIndex=n;let r=this.currentTriangleIndex;this.extractGeometry(e,t,n),this.meshTriangleRanges.push({start:r,count:this.currentTriangleIndex-r})}processMaterial(e){let t=this._materialUuidMap.get(e.uuid)??-1;if(t===-1){e.depthWrite===!1&&(e.depthWrite=!0,console.warn(`Depth write is disabled in material, enabling it for rastered rendering`));let n=this.createMaterialObject(e);this.materials.push(n),t=this.materials.length-1,this._materialUuidMap.set(e.uuid,t),n.clearcoat>0&&(this.sceneFeatures.hasClearcoat=!0),n.transmission>0&&(this.sceneFeatures.hasTransmission=!0),n.dispersion>0&&(this.sceneFeatures.hasDispersion=!0),n.iridescence>0&&(this.sceneFeatures.hasIridescence=!0),n.sheen>0&&(this.sceneFeatures.hasSheen=!0),(n.transparent||n.opacity<1||n.alphaTest>0)&&(this.sceneFeatures.hasTransparency=!0),[n.clearcoat>0,n.transmission>0,n.iridescence>0,n.sheen>0].filter(Boolean).length>=2&&(this.sceneFeatures.hasMultiLobeMaterials=!0)}return t}getMaterialAlphaMode(e){if(e.userData?.gltfExtensions?.KHR_materials_unlit?.alphaMode){let t=e.userData.gltfExtensions.KHR_materials_unlit.alphaMode;return t===`BLEND`?2:+(t===`MASK`)}return e.alphaTest>0?1:e.transparent&&e.opacity<1||e.map&&e.map.format===r.RGBAFormat&&e.transparent?2:0}getMaterialType(e){return e.isMeshPhysicalMaterial?`physical`:e.isMeshStandardMaterial?`standard`:e.isMeshPhongMaterial?`phong`:e.isMeshLambertMaterial?`lambert`:e.isMeshBasicMaterial?`basic`:e.isMeshToonMaterial?`toon`:`unknown`}getPhysicalDefaults(){return{emissive:new r.Color(0,0,0),emissiveIntensity:1,roughness:1,metalness:0,ior:1.5,opacity:1,transmission:0,thickness:.1,attenuationColor:new r.Color(16777215),attenuationDistance:1/0,dispersion:0,sheen:0,sheenRoughness:1,sheenColor:new r.Color(0),specularIntensity:1,specularColor:new r.Color(16777215),clearcoat:0,clearcoatRoughness:0,iridescence:0,iridescenceIOR:1.3,iridescenceThicknessRange:[100,400],normalScale:{x:1,y:1},bumpScale:1,displacementScale:1,alphaTest:0}}mapLegacyMaterialToPhysical(e,t){let n={};switch(t){case`basic`:n.emissive=e.color.clone(),n.emissiveIntensity=1,n.color=new r.Color(0),n.roughness=1,n.metalness=0;break;case`lambert`:n.roughness=1,n.metalness=0,n.specularIntensity=0;break;case`phong`:{let t=e.shininess||30;n.roughness=Math.sqrt(2/(t+2)),n.metalness=0}if(e.specular){let t=e.specular.r*.299+e.specular.g*.587+e.specular.b*.114;n.specularIntensity=Math.min(t*2,1),n.specularColor=e.specular.clone()}break;case`toon`:n.roughness=.9,n.metalness=0;break;case`standard`:case`physical`:break}return n}createMaterialObject(e){let t=this.getPhysicalDefaults(),n=this.getMaterialType(e),i=this.mapLegacyMaterialToPhysical(e,n),a=(e.metalness??i.metalness??0)>.1,o=t.ior;a?o=2.5:e.transmission>0&&(o=1.5);let s=e.color||new r.Color(16777215);return n===`basic`&&!e.map&&(s=new r.Color(0)),{uuid:e.uuid,color:s,emissive:i.emissive??e.emissive??t.emissive,emissiveIntensity:i.emissiveIntensity??e.emissiveIntensity??t.emissiveIntensity,roughness:Math.max(.05,i.roughness??e.roughness??t.roughness),metalness:i.metalness??e.metalness??t.metalness,ior:e.ior??o,opacity:e.opacity??t.opacity,transmission:e.transmission??t.transmission,thickness:e.thickness??t.thickness,attenuationColor:e.attenuationColor??t.attenuationColor,attenuationDistance:e.attenuationDistance??t.attenuationDistance,dispersion:e.dispersion??t.dispersion,sheen:e.sheen??t.sheen,sheenRoughness:e.sheenRoughness??t.sheenRoughness,sheenColor:e.sheenColor??t.sheenColor,clearcoat:e.clearcoat??t.clearcoat,clearcoatRoughness:e.clearcoatRoughness??t.clearcoatRoughness,iridescence:e.iridescence??t.iridescence,iridescenceIOR:e.iridescenceIOR??t.iridescenceIOR,iridescenceThicknessRange:e.iridescenceThicknessRange??t.iridescenceThicknessRange,specularIntensity:i.specularIntensity??e.specularIntensity??t.specularIntensity,specularColor:i.specularColor??e.specularColor??t.specularColor,normalScale:e.normalScale??t.normalScale,bumpScale:e.bumpScale??t.bumpScale,displacementScale:e.displacementScale??t.displacementScale,transparent:+!!e.transparent,alphaTest:e.alphaTest??t.alphaTest,alphaMode:this.getMaterialAlphaMode(e),side:this.getMaterialSide(e),depthWrite:e.depthWrite??!0?1:0,map:this.processTexture(e.map,this.maps),normalMap:this.processTexture(e.normalMap,this.normalMaps),bumpMap:this.processTexture(e.bumpMap,this.bumpMaps),roughnessMap:this.processTexture(e.roughnessMap,this.roughnessMaps),metalnessMap:this.processTexture(e.metalnessMap,this.metalnessMaps),emissiveMap:this.processTexture(e.emissiveMap,this.emissiveMaps),displacementMap:this.processTexture(e.displacementMap,this.displacementMaps),clearcoatMap:this.processTexture(e.clearcoatMap,[]),clearcoatRoughnessMap:this.processTexture(e.clearcoatRoughnessMap,[]),transmissionMap:this.processTexture(e.transmissionMap,[]),thicknessMap:this.processTexture(e.thicknessMap,[]),sheenColorMap:this.processTexture(e.sheenColorMap,[]),sheenRoughnessMap:this.processTexture(e.sheenRoughnessMap,[]),specularIntensityMap:this.processTexture(e.specularIntensityMap,[]),specularColorMap:this.processTexture(e.specularColorMap,[]),iridescenceMap:this.processTexture(e.iridescenceMap,[]),iridescenceThicknessMap:this.processTexture(e.iridescenceThicknessMap,[]),mapMatrix:this.getTextureMatrix(e.map),normalMapMatrices:this.getTextureMatrix(e.normalMap),bumpMapMatrices:this.getTextureMatrix(e.bumpMap),roughnessMapMatrices:this.getTextureMatrix(e.roughnessMap),metalnessMapMatrices:this.getTextureMatrix(e.metalnessMap),emissiveMapMatrices:this.getTextureMatrix(e.emissiveMap),displacementMapMatrices:this.getTextureMatrix(e.displacementMap),originalType:n}}getTextureMatrix(e){return e?(e.updateMatrix(),e.matrix.elements):new r.Matrix3().elements}getMaterialSide(e){if(e.transmission>0)return 2;switch(e.side){case r.FrontSide:return 0;case r.BackSide:return 1;case r.DoubleSide:return 2;default:return 0}}processTexture(e,t){if(!e)return-1;let n=this._textureIndexCache.get(t);n||(n=new Map,this._textureIndexCache.set(t,n));let r=e.source.uuid,i=n.get(r);if(i!==void 0)return i;if(t.length<Oa){t.push(e);let i=t.length-1;return n.set(r,i),i}return-1}extractGeometry(e,t,n){e.updateMatrix(),e.updateMatrixWorld();let r=e.geometry;r.attributes.normal||r.computeVertexNormals();let i=r.attributes.position,a=r.attributes.normal,o=r.attributes.uv,s=r.index?r.index.array:null;this._matrixPool.mat4.copy(e.matrixWorld),this._matrixPool.mat3.getNormalMatrix(this._matrixPool.mat4);let c=s?s.length/3:i.count/3;this.extractTrianglesInBatch(i,a,o,s,c,t,n)}extractTrianglesInBatch(e,t,n,r,i,a,o){let s=this._getVec3(0),c=this._getVec3(1),l=this._getVec3(2),u=this._getVec3(3),d=this._getVec3(4),f=this._getVec3(5),p=this._getVec2(0),m=this._getVec2(1),h=this._getVec2(2);this._ensureCapacity(this.currentTriangleIndex+i);for(let g=0;g<i;g++){let i=g*3,_=r?r[i+0]:i+0,v=r?r[i+1]:i+1,y=r?r[i+2]:i+2;this.getVertex(e,_,s),this.getVertex(e,v,c),this.getVertex(e,y,l),this.getVertex(t,_,u),this.getVertex(t,v,d),this.getVertex(t,y,f),n?(this.getVertex(n,_,p),this.getVertex(n,v,m),this.getVertex(n,y,h)):(p.set(0,0),m.set(0,0),h.set(0,0)),s.applyMatrix4(this._matrixPool.mat4),c.applyMatrix4(this._matrixPool.mat4),l.applyMatrix4(this._matrixPool.mat4),u.applyMatrix3(this._matrixPool.mat3).normalize(),d.applyMatrix3(this._matrixPool.mat3).normalize(),f.applyMatrix3(this._matrixPool.mat3).normalize(),this.packTriangleDataTextureFormat(this.currentTriangleIndex,s,c,l,u,d,f,p,m,h,a,o),this.currentTriangleIndex++}}packTriangleDataTextureFormat(e,t,n,r,i,a,o,s,c,l,u,d){let f=e*H.FLOATS_PER_TRIANGLE;this.triangleData[f+H.POSITION_A_OFFSET+0]=t.x,this.triangleData[f+H.POSITION_A_OFFSET+1]=t.y,this.triangleData[f+H.POSITION_A_OFFSET+2]=t.z,this.triangleData[f+H.POSITION_A_OFFSET+3]=0,this.triangleData[f+H.POSITION_B_OFFSET+0]=n.x,this.triangleData[f+H.POSITION_B_OFFSET+1]=n.y,this.triangleData[f+H.POSITION_B_OFFSET+2]=n.z,this.triangleData[f+H.POSITION_B_OFFSET+3]=0,this.triangleData[f+H.POSITION_C_OFFSET+0]=r.x,this.triangleData[f+H.POSITION_C_OFFSET+1]=r.y,this.triangleData[f+H.POSITION_C_OFFSET+2]=r.z,this.triangleData[f+H.POSITION_C_OFFSET+3]=0,this.triangleData[f+H.NORMAL_A_OFFSET+0]=i.x,this.triangleData[f+H.NORMAL_A_OFFSET+1]=i.y,this.triangleData[f+H.NORMAL_A_OFFSET+2]=i.z;{let e=this.materials[u],t=e&&!(e.alphaMode|0)&&!(e.transparent|0)&&(e.transmission||0)===0&&(e.opacity??1)>=1?1:0;this.triangleData[f+H.NORMAL_A_OFFSET+3]=t}this.triangleData[f+H.NORMAL_B_OFFSET+0]=a.x,this.triangleData[f+H.NORMAL_B_OFFSET+1]=a.y,this.triangleData[f+H.NORMAL_B_OFFSET+2]=a.z,this.triangleData[f+H.NORMAL_B_OFFSET+3]=0,this.triangleData[f+H.NORMAL_C_OFFSET+0]=o.x,this.triangleData[f+H.NORMAL_C_OFFSET+1]=o.y,this.triangleData[f+H.NORMAL_C_OFFSET+2]=o.z,this.triangleData[f+H.NORMAL_C_OFFSET+3]=this.materials[u]?.side??0,this.triangleData[f+H.UV_AB_OFFSET+0]=s.x,this.triangleData[f+H.UV_AB_OFFSET+1]=s.y,this.triangleData[f+H.UV_AB_OFFSET+2]=c.x,this.triangleData[f+H.UV_AB_OFFSET+3]=c.y,this.triangleData[f+H.UV_C_MAT_OFFSET+0]=l.x,this.triangleData[f+H.UV_C_MAT_OFFSET+1]=l.y,this.triangleData[f+H.UV_C_MAT_OFFSET+2]=u,this.triangleData[f+H.UV_C_MAT_OFFSET+3]=d}getTriangleData(){return this.triangleData?this.triangleData.subarray(0,this.currentTriangleIndex*H.FLOATS_PER_TRIANGLE):null}getTriangleCount(){return this.currentTriangleIndex}getVertex(e,t,n){return e.itemSize===2?(n.x=e.getX(t),n.y=e.getY(t)):e.itemSize>=3&&(n.x=e.getX(t),n.y=e.getY(t),n.z=e.getZ(t)),n}logStats(){let e=this.currentTriangleIndex*H.FLOATS_PER_TRIANGLE*4;console.log(`materials:`,this.materials.length),console.log(`triangles:`,this.currentTriangleIndex),console.log(`triangle data size (MB):`,(e/(1024*1024)).toFixed(2)),console.log(`maps:`,this.maps.length)}extractMaterialsOnly(e){return this.resetArrays(),this._traverseMaterialsOnly(e),this.getExtractedData()}_traverseMaterialsOnly(e){if(e.isMesh&&e.geometry&&e.material){let t=this.processMaterial(e.material);e.userData.materialIndex=t;let n=this.meshes.length;this.meshes.push(e),e.userData.meshIndex=n}else e.isDirectionalLight?this.directionalLights.push(e):e.isCamera&&this.cameras.push(e);if(e.children)for(let t of e.children)this._traverseMaterialsOnly(t)}resetArrays(){this.triangleData=null,this.triangleCount=0,this.currentTriangleIndex=0,this.materials=[],this.meshes=[],this.meshTriangleRanges=[],this.maps=[],this.normalMaps=[],this.bumpMaps=[],this.metalnessMaps=[],this.emissiveMaps=[],this.roughnessMaps=[],this.displacementMaps=[],this.directionalLights=[],this.cameras=[],this._materialUuidMap=new Map,this._textureIndexCache=new WeakMap,this.sceneFeatures={hasClearcoat:!1,hasTransmission:!1,hasDispersion:!1,hasIridescence:!1,hasSheen:!1,hasTransparency:!1,hasMultiLobeMaterials:!1,hasMRTOutputs:!0}}getExtractedData(){return{triangleData:this.getTriangleData(),triangleCount:this.getTriangleCount(),materials:this.materials,meshes:this.meshes,meshTriangleRanges:this.meshTriangleRanges,maps:this.maps,normalMaps:this.normalMaps,bumpMaps:this.bumpMaps,metalnessMaps:this.metalnessMaps,emissiveMaps:this.emissiveMaps,roughnessMaps:this.roughnessMaps,displacementMaps:this.displacementMaps,directionalLights:this.directionalLights,cameras:this.cameras,sceneFeatures:this.sceneFeatures}}},Aa=class{constructor(){this.maxLeafSize=8}build(e){let t=e.length;if(t===0){let e=new Float32Array(16);return e[7]=1,{nodeData:e,nodeCount:1,sortedPerm:new Int32Array}}let n=new Int32Array(t);for(let e=0;e<t;e++)n[e]=e;let r=2*t+4,i=new Float32Array(r*16),a=0,o=(t,r)=>{let s=a++,c=s*16,l=1/0,u=1/0,d=1/0,f=-1/0,p=-1/0,m=-1/0,h=0,g=1/0,_=1/0,v=1/0,y=-1/0,b=-1/0,x=-1/0;for(let i=t;i<r;i++){let t=e[n[i]];l=Math.min(l,t.bMinX),u=Math.min(u,t.bMinY),d=Math.min(d,t.bMinZ),f=Math.max(f,t.bMaxX),p=Math.max(p,t.bMaxY),m=Math.max(m,t.bMaxZ),h+=t.power,g=Math.min(g,t.cx),_=Math.min(_,t.cy),v=Math.min(v,t.cz),y=Math.max(y,t.cx),b=Math.max(b,t.cy),x=Math.max(x,t.cz)}i[c+0]=l,i[c+1]=u,i[c+2]=d,i[c+3]=h,i[c+4]=f,i[c+5]=p,i[c+6]=m,i[c+12]=0,i[c+13]=0,i[c+14]=0,i[c+15]=0;let S=r-t;if(S<=this.maxLeafSize)i[c+7]=1,i[c+8]=t,i[c+9]=S,i[c+10]=0,i[c+11]=0;else{let a=y-g,s=b-_,l=x-v,u;u=a>=s&&a>=l?0:s>=l?1:2;let d=[`cx`,`cy`,`cz`][u],f=t+r>>1;this._nthElement(n,e,t,r,f,d),i[c+7]=0;let p=o(t,f),m=o(f,r);i[c+8]=p,i[c+9]=m,i[c+10]=0,i[c+11]=0}return s};o(0,t);let s=new Int32Array(t);for(let e=0;e<t;e++)s[e]=n[e];let c=new Float32Array(a*16);return c.set(i.subarray(0,a*16)),console.log(`[LightBVHBuilder] Built BVH: ${a} nodes for ${t} emissive triangles`),{nodeData:c,nodeCount:a,sortedPerm:s}}_nthElement(e,t,n,r,i,a){for(;n<r-1;){let o=n+r>>1,s=t[e[o]][a],c=e[o];e[o]=e[r-1],e[r-1]=c;let l=n;for(let i=n;i<r-1;i++)t[e[i]][a]<s&&(c=e[i],e[i]=e[l],e[l]=c,l++);if(c=e[l],e[l]=e[r-1],e[r-1]=c,l===i)return;l<i?n=l+1:r=l}}},ja=class{constructor(){this.emissiveTriangles=[],this.emissiveCount=0,this.totalEmissivePower=0,this.emissiveIndicesArray=null,this.emissivePowerArray=null,this.cdfArray=null,this.lightBVHNodeData=null,this.lightBVHNodeCount=0}extractEmissiveTriangles(e,t,n){console.log(`[EmissiveTriangleBuilder] Extracting emissive triangles...`),this.emissiveTriangles=[],this.totalEmissivePower=0;let r=H.FLOATS_PER_TRIANGLE,i=H.UV_C_MAT_OFFSET+2;for(let a=0;a<n;a++){let n=a*r,o=Math.floor(e[n+i]),s=t[o];if(!s)continue;let c=s.emissive||{r:0,g:0,b:0},l=s.emissiveIntensity||0;if(l>0&&(c.r>0||c.g>0||c.b>0)){let t=e[n+0],r=e[n+1],i=e[n+2],s=e[n+4],u=e[n+5],d=e[n+6],f=e[n+8],p=e[n+9],m=e[n+10],h=this._calculateTriangleArea(t,r,i,s,u,d,f,p,m),g=(c.r+c.g+c.b)/3*l*h,_=(t+s+f)/3,v=(r+u+p)/3,y=(i+d+m)/3,b=Math.min(t,s,f),x=Math.min(r,u,p),S=Math.min(i,d,m),C=Math.max(t,s,f),w=Math.max(r,u,p),T=Math.max(i,d,m);this.emissiveTriangles.push({triangleIndex:a,materialIndex:o,power:g,area:h,emissive:{r:c.r,g:c.g,b:c.b},emissiveIntensity:l,cx:_,cy:v,cz:y,bMinX:b,bMinY:x,bMinZ:S,bMaxX:C,bMaxY:w,bMaxZ:T}),this.totalEmissivePower+=g}}return this.emissiveCount=this.emissiveTriangles.length,console.log(`[EmissiveTriangleBuilder] Found ${this.emissiveCount} emissive triangles (${(this.emissiveCount/n*100).toFixed(2)}%)`),console.log(`[EmissiveTriangleBuilder] Total emissive power: ${this.totalEmissivePower.toFixed(2)}`),this._buildDataArrays(),this.emissiveCount}_calculateTriangleArea(e,t,n,r,i,a,o,s,c){let l=r-e,u=i-t,d=a-n,f=o-e,p=s-t,m=c-n,h=u*m-d*p,g=d*f-l*m,_=l*p-u*f;return Math.sqrt(h*h+g*g+_*_)*.5}_buildDataArrays(){this.emissiveIndicesArray=new Int32Array(this.emissiveCount),this.emissivePowerArray=new Float32Array(this.emissiveCount);for(let e=0;e<this.emissiveCount;e++)this.emissiveIndicesArray[e]=this.emissiveTriangles[e].triangleIndex,this.emissivePowerArray[e]=this.emissiveTriangles[e].power;this._buildCDF()}_buildCDF(){if(this.emissiveCount===0){this.cdfArray=new Float32Array(1),this.cdfArray[0]=0;return}this.cdfArray=new Float32Array(this.emissiveCount);let e=0;for(let t=0;t<this.emissiveCount;t++)e+=this.emissivePowerArray[t],this.cdfArray[t]=e;if(e>0)for(let t=0;t<this.emissiveCount;t++)this.cdfArray[t]/=e}sampleCDF(e){if(this.emissiveCount===0)return-1;if(this.emissiveCount===1)return 0;let t=0,n=this.emissiveCount-1;for(;t<n;){let r=Math.floor((t+n)/2);this.cdfArray[r]<e?t=r+1:n=r}return t}getGPUData(){return{emissiveIndices:this.emissiveIndicesArray,emissivePower:this.emissivePowerArray,emissiveCDF:this.cdfArray,emissiveCount:this.emissiveCount,totalPower:this.totalEmissivePower}}createEmissiveTexture(){if(this.emissiveCount===0)return new r.DataTexture(new Float32Array(4),1,1,r.RGBAFormat,r.FloatType);let e=new Float32Array(this.emissiveCount*4);for(let t=0;t<this.emissiveCount;t++){let n=t*4;e[n+0]=this.emissiveIndicesArray[t],e[n+1]=this.emissivePowerArray[t],e[n+2]=this.cdfArray[t],e[n+3]=0}let t=Math.ceil(Math.sqrt(this.emissiveCount)),n=Math.ceil(this.emissiveCount/t),i=t*n*4,a=new Float32Array(i);a.set(e);let o=new r.DataTexture(a,t,n,r.RGBAFormat,r.FloatType);return o.needsUpdate=!0,o.generateMipmaps=!1,o.minFilter=r.NearestFilter,o.magFilter=r.NearestFilter,console.log(`[EmissiveTriangleBuilder] Created ${t}x${n} emissive texture (${this.emissiveCount} emissives)`),o}createEmissiveRawData(){if(this.emissiveCount===0)return new Float32Array(8);let e=new Float32Array(this.emissiveCount*8);for(let t=0;t<this.emissiveCount;t++){let n=this.emissiveTriangles[t],r=t*8;e[r+0]=n.triangleIndex,e[r+1]=n.power,e[r+2]=this.cdfArray[t],e[r+3]=this.totalEmissivePower>0?n.power/this.totalEmissivePower:0,e[r+4]=n.emissive.r*n.emissiveIntensity,e[r+5]=n.emissive.g*n.emissiveIntensity,e[r+6]=n.emissive.b*n.emissiveIntensity,e[r+7]=n.area}return console.log(`[EmissiveTriangleBuilder] Created emissive raw data: ${this.emissiveCount} entries (${e.byteLength} bytes)`),e}getStats(){if(this.emissiveCount===0)return{count:0,totalPower:0,averagePower:0,minPower:0,maxPower:0};let e=1/0,t=-1/0;for(let n=0;n<this.emissiveCount;n++){let r=this.emissivePowerArray[n];e=Math.min(e,r),t=Math.max(t,r)}return{count:this.emissiveCount,totalPower:this.totalEmissivePower,averagePower:this.totalEmissivePower/this.emissiveCount,minPower:e,maxPower:t}}updateMaterialEmissive(e,t,n,r,i){let a=t.emissive||{r:0,g:0,b:0},o=t.emissiveIntensity||0,s=o>0&&(a.r>0||a.g>0||a.b>0);if(s!==this.emissiveTriangles.some(t=>t.materialIndex===e))return this.extractEmissiveTriangles(n,r,i),!0;if(!s)return!1;let c=(a.r+a.g+a.b)/3;this.totalEmissivePower=0;for(let t=0;t<this.emissiveCount;t++){let n=this.emissiveTriangles[t];n.materialIndex===e&&(n.power=c*o*n.area,n.emissive={r:a.r,g:a.g,b:a.b},n.emissiveIntensity=o,this.emissivePowerArray[t]=n.power),this.totalEmissivePower+=this.emissiveTriangles[t].power}return this._buildCDF(),!0}buildLightBVH(){if(this.emissiveCount===0)return this.lightBVHNodeData=new Float32Array(16),this.lightBVHNodeData[7]=1,this.lightBVHNodeCount=1,1;let{nodeData:e,nodeCount:t,sortedPerm:n}=new Aa().build(this.emissiveTriangles);return this.lightBVHNodeData=e,this.lightBVHNodeCount=t,this._rebuildSortedEmissiveData(n),t}_rebuildSortedEmissiveData(e){let t=e.length;this.emissiveIndicesArray=new Int32Array(t),this.emissivePowerArray=new Float32Array(t);for(let n=0;n<t;n++){let t=e[n];this.emissiveIndicesArray[n]=this.emissiveTriangles[t].triangleIndex,this.emissivePowerArray[n]=this.emissiveTriangles[t].power}this._buildCDF();let n=new Float32Array(t*8);for(let r=0;r<t;r++){let t=e[r],i=this.emissiveTriangles[t],a=r*8;n[a+0]=i.triangleIndex,n[a+1]=i.power,n[a+2]=this.cdfArray[r],n[a+3]=this.totalEmissivePower>0?i.power/this.totalEmissivePower:0,n[a+4]=i.emissive.r*i.emissiveIntensity,n[a+5]=i.emissive.g*i.emissiveIntensity,n[a+6]=i.emissive.b*i.emissiveIntensity,n[a+7]=i.area}this.emissiveTriangleData=n,console.log(`[EmissiveTriangleBuilder] Rebuilt sorted emissive data: ${t} entries`)}clear(){this.emissiveTriangles=[],this.emissiveCount=0,this.totalEmissivePower=0,this.emissiveIndicesArray=null,this.emissivePowerArray=null,this.cdfArray=null,this.lightBVHNodeData=null,this.lightBVHNodeCount=0}},Ma=``+(typeof document>`u`&&typeof location>`u`?require(`url`).pathToFileURL(__dirname+`/assets/BVHRefitWorker-GkmNJYvb.js`).href:new URL(`assets/BVHRefitWorker-GkmNJYvb.js`,typeof document>`u`?location.href:document.currentScript&&document.currentScript.tagName.toUpperCase()===`SCRIPT`&&document.currentScript.src||document.baseURI).href),Na=class{constructor(e={}){this.config={useWorkers:!0,bvhDepth:30,maxLeafSize:4,verbose:!1,useFloat32Array:!0,textureQuality:`adaptive`,enableTextureCache:!0,maxConcurrentTextureTasks:Math.min(navigator.hardwareConcurrency||4,6),treeletSize:7,treeletOptimizationPasses:1,treeletMinImprovement:.01,...e},this.triangleData=null,this.triangleCount=0,this.materials=[],this.maps=[],this.normalMaps=[],this.bumpMaps=[],this.roughnessMaps=[],this.metalnessMaps=[],this.emissiveMaps=[],this.displacementMaps=[],this.directionalLights=[],this.cameras=[],this.spheres=[],this.bvhRoot=null,this.bvhData=null,this.materialData=null,this.instanceTable=null,this.originalToBvhMap=null,this._refitWorker=null,this._refitSharedBuffers=null,this._rebuildGeneration=0,this._pendingRebuilds=new Map,this.albedoTextures=null,this.normalTextures=null,this.bumpTextures=null,this.roughnessTextures=null,this.metalnessTextures=null,this.emissiveTextures=null,this.displacementTextures=null,this.emissiveTriangleData=null,this.emissiveTriangleCount=0,this.lightBVHNodeData=null,this.lightBVHNodeCount=0,this._initProcessors(),this.isProcessing=!1,this.processingStage=null,this.performanceMetrics={textureCreationTime:0,geometryExtractionTime:0,bvhBuildTime:0,totalProcessingTime:0}}_initProcessors(){this.geometryExtractor=new ka,this.bvhBuilder=new ia,this.bvhBuilder.maxLeafSize=this.config.maxLeafSize,this.bvhBuilder.setTreeletConfig({enabled:this.config.enableTreeletOptimization,size:this.config.treeletSize,passes:this.config.treeletOptimizationPasses,minImprovement:this.config.treeletMinImprovement}),this.textureCreator=new Ea,this.emissiveTriangleBuilder=new ja,this.tlasBuilder=new ba}_log(e,t){this.config.verbose&&console.log(`[SceneProcessor] ${e}`,t||``)}async buildBVH(e){if(this.isProcessing)throw Error(`Already processing a scene. Call dispose() first.`);this.isProcessing=!0,this.processingStage=`init`;let t=new Ji(`SceneProcessor (${e.name||`scene`})`);try{this._reset(),this._log(`Starting scene processing`),this.processingStage=`extraction`,t.start(`Geometry extraction`),await this._extractGeometry(e),t.end(`Geometry extraction`),this.performanceMetrics.geometryExtractionTime=t.getDuration(`Geometry extraction`),this.processingStage=`bvh`,t.start(`BVH construction (worker)`),t.start(`Material textures (parallel)`);let n=!1,r=this._buildBVH().then(()=>t.end(`BVH construction (worker)`)),i=this._createMaterialTextures().then(()=>{t.end(`Material textures (parallel)`),n=!0});return await r,B({status:`Building light data...`,progress:77}),t.start(`Emissive extraction + Light BVH`),this._buildEmissiveData(),t.end(`Emissive extraction + Light BVH`),n||B({status:`Processing material textures...`,progress:80}),await i,this.performanceMetrics.bvhBuildTime=t.getDuration(`BVH construction (worker)`),this.performanceMetrics.textureCreationTime=t.getDuration(`Material textures (parallel)`),this.processingStage=`finalize`,t.start(`BVH data packing`),this.bvhRoot&&!this.bvhData&&(this.bvhData=this.textureCreator.createBVHRawData(this.bvhRoot)),t.end(`BVH data packing`),this.spheres=this._createSpheres(),this.performanceMetrics.totalProcessingTime=performance.now()-t.totalStart,t.print(),this.processingStage=`complete`,B({status:`Scene data ready`,progress:85}),this}catch(e){throw this.processingStage=`error`,console.error(`[SceneProcessor] Processing error:`,e),B({status:`Error: ${e.message}`,progress:100}),e}finally{this.isProcessing=!1}}async _extractGeometry(e){B({isLoading:!0,title:`Processing`,status:`Extracting geometry...`,progress:15}),await new Promise(e=>setTimeout(e,0)),this._log(`Extracting geometry`);let t=performance.now();try{let n=this.geometryExtractor.extract(e);this.triangleData=n.triangleData,this.triangleCount=n.triangleCount,this._log(`Using Float32Array format: ${this.triangleCount} triangles, ${(this.triangleData.byteLength/(1024*1024)).toFixed(2)}MB`),this.materials=n.materials,this.materialCount=this.materials.length,this.meshes=n.meshes,this.meshTriangleRanges=n.meshTriangleRanges,this.maps=n.maps,this.normalMaps=n.normalMaps,this.bumpMaps=n.bumpMaps,this.roughnessMaps=n.roughnessMaps,this.metalnessMaps=n.metalnessMaps,this.emissiveMaps=n.emissiveMaps,this.displacementMaps=n.displacementMaps,this.directionalLights=n.directionalLights,this.cameras=n.cameras,this.sceneFeatures=n.sceneFeatures;let r=performance.now()-t;this._log(`Geometry extraction complete (${r.toFixed(2)}ms)`,{triangleCount:this.triangleCount,materials:this.materials.length}),B({status:`Extracted ${this.triangleCount.toLocaleString()} triangles`,progress:25})}catch(e){throw console.error(`[SceneProcessor] Geometry extraction error:`,e),B({status:`Extraction error: ${e.message}`,progress:25}),e}}async _buildBVH(){if(B({status:`Building BVH...`,progress:25}),this.triangleCount===0)throw Error(`No triangles to build BVH from`);this._log(`Building two-level BVH (TLAS/BLAS)`);let e=performance.now();try{let t=H.FLOATS_PER_TRIANGLE,n=this.meshTriangleRanges;if(!n||n.length===0)throw Error(`No mesh triangle ranges available for TLAS/BLAS build`);this.instanceTable=new xa,this.instanceTable.allocate(n.length);let r=n.length,i=this.config.enableTreeletOptimization,a=[],o=[];for(let e=0;e<r;e++){let t=n[e];t.count!==0&&(t.count>=2e5&&_a(t.count)?o.push({m:e,range:t}):a.push({m:e,range:t}))}let s={depth:this.config.bvhDepth,treeletOptimization:{enabled:i!==!1,size:this.config.treeletSize,passes:this.config.treeletOptimizationPasses,minImprovement:this.config.treeletMinImprovement},reinsertionOptimization:{enabled:this.bvhBuilder.enableReinsertionOptimization,batchSizeRatio:this.bvhBuilder.reinsertionBatchSizeRatio,maxIterations:this.bvhBuilder.reinsertionMaxIterations}},c=a.length+o.length,l=this._buildBLASesWithPool(a,s,e=>{B({status:`Building BLAS ${e+o.length}/${c}...`,progress:25+Math.floor(e/c*45)})}),u=o.map(({m:e,range:n})=>ma(this.triangleData.slice(n.start*t,(n.start+n.count)*t),this.config.bvhDepth,null,{maxLeafSize:this.bvhBuilder.maxLeafSize,numBins:this.bvhBuilder.numBins,maxBins:this.bvhBuilder.maxBins,minBins:this.bvhBuilder.minBins,...s}).then(t=>({m:e,range:n,result:t}))),[d,f]=await Promise.all([l,Promise.all(u)]);for(let{m:e,range:n,result:r}of[...d,...f])r.reorderedTriangles&&this.triangleData.set(r.reorderedTriangles,n.start*t),this.instanceTable.setEntry({meshIndex:e,blasNodeCount:r.bvhData.length/16,triOffset:n.start,triCount:n.count,originalToBvhMap:r.originalToBvh||null,bvhData:r.bvhData});B({status:`Built all BLASes`,progress:70}),B({status:`Building TLAS...`,progress:72});let p=this.instanceTable.entries.filter(e=>e!==null);this.instanceTable.computeAABBs(this.triangleData);let{root:m,nodeCount:h}=this.tlasBuilder.build(p);this.instanceTable.assignOffsets(h);let g=this.instanceTable.totalNodeCount,_=this.tlasBuilder.flatten(m,p);this.bvhData=new Float32Array(g*16),this.bvhData.set(_);for(let e of p){let t=e.blasOffset*16;this.bvhData.set(e.bvhData,t),this._offsetBLASInPlace(t,e.bvhData.length/16,e.blasOffset,e.triOffset)}this._buildGlobalOriginalToBvhMap();for(let e of p)e.originalToBvhMap=null,e.bvhData=null;this.bvhRoot=!0,this._disposeRefitWorker();let v=performance.now()-e;this._log(`BVH complete: ${p.length} mesh(es), ${this.bvhData.length/16} nodes (${v.toFixed(2)}ms)`),B({status:`BVH construction complete`,progress:75})}catch(e){throw console.error(`[SceneProcessor] BVH building error:`,e),B({status:`BVH error: ${e.message}`,progress:75}),e}}_offsetBLASInPlace(e,t,n,r){for(let i=0;i<t;i++){let t=e+i*16;this.bvhData[t+3]===-1?this.bvhData[t]+=r:(this.bvhData[t+3]+=n,this.bvhData[t+7]+=n)}}_buildBLASesWithPool(e,t,n){if(e.length===0)return Promise.resolve([]);let r=H.FLOATS_PER_TRIANGLE,i=Math.min(e.length,this.config.maxConcurrentTextureTasks||4),a=[],o=0,s=0;return new Promise((c,l)=>{let u=[],d=n=>{if(o>=e.length){n.terminate(),u.splice(u.indexOf(n),1),u.length===0&&c(a);return}let{m:i,range:s}=e[o++],l=this.triangleData.slice(s.start*r,(s.start+s.count)*r),d=s.count,f=d<=500?{...t.treeletOptimization,enabled:!1}:t.treeletOptimization;n._currentTask={m:i,range:s},n.postMessage({triangleData:l.buffer,triangleByteOffset:l.byteOffset,triangleByteLength:l.byteLength,triangleCount:d,depth:t.depth,reportProgress:!1,sharedReorderBuffer:null,treeletOptimization:f,reinsertionOptimization:t.reinsertionOptimization},[l.buffer])},f=(e,t)=>{let r=t.data;if(r.error){u.forEach(e=>e.terminate()),l(Error(r.error));return}if(r.progress!==void 0)return;let{m:i,range:o}=e._currentTask;a.push({m:i,range:o,result:{bvhData:r.bvhData,reorderedTriangles:r.triangles||null,originalToBvh:r.originalToBvh||null}}),s++,n?.(s),d(e)};(async()=>{for(let e=0;e<i;e++){let e;try{e=new Worker(ea,{type:`module`})}catch(t){if(t.name!==`SecurityError`){l(t);return}e=await q(ea)}e.onmessage=t=>f(e,t),e.onerror=e=>{u.forEach(e=>e.terminate()),l(e)},u.push(e),d(e)}})().catch(l)})}_buildGlobalOriginalToBvhMap(){this.originalToBvhMap=new Uint32Array(this.triangleCount);for(let e of this.instanceTable.entries){if(!e)continue;let t=new Uint32Array(e.triCount);if(e.originalToBvhMap)for(let n=0;n<e.triCount;n++){let r=e.originalToBvhMap[n];this.originalToBvhMap[e.triOffset+n]=e.triOffset+r,t[r]=n}else for(let n=0;n<e.triCount;n++)this.originalToBvhMap[e.triOffset+n]=e.triOffset+n,t[n]=n;e.bvhToOriginal=t}}async _createMaterialTextures(){this._log(`Creating material textures (parallel with BVH)`);try{this.materials?.length&&(this.materialData=this.textureCreator.createMaterialRawData(this.materials));let e=[{data:this.maps,prop:`albedoTextures`},{data:this.normalMaps,prop:`normalTextures`},{data:this.bumpMaps,prop:`bumpTextures`},{data:this.roughnessMaps,prop:`roughnessTextures`},{data:this.metalnessMaps,prop:`metalnessTextures`},{data:this.emissiveMaps,prop:`emissiveTextures`},{data:this.displacementMaps,prop:`displacementTextures`}];await Promise.all(e.filter(({data:e})=>e?.length>0).map(({data:e,prop:t})=>this.textureCreator.createTexturesToDataTexture(e).then(e=>{this[t]=e}))),this._log(`Material textures complete`,{materialData:!!this.materialData})}catch(e){throw console.error(`[SceneProcessor] Texture creation error:`,e),e}}_buildEmissiveData(){this.emissiveTriangleCount=this.emissiveTriangleBuilder.extractEmissiveTriangles(this.triangleData,this.materials,this.triangleCount),this.emissiveTriangleData=this.emissiveTriangleBuilder.createEmissiveRawData(),this.emissiveTotalPower=this.emissiveTriangleBuilder.totalEmissivePower,this._log(`Emissive triangle extraction complete`,this.emissiveTriangleBuilder.getStats()),this.emissiveTriangleBuilder.buildLightBVH(),this.lightBVHNodeData=this.emissiveTriangleBuilder.lightBVHNodeData,this.lightBVHNodeCount=this.emissiveTriangleBuilder.lightBVHNodeCount,this.emissiveTriangleData=this.emissiveTriangleBuilder.emissiveTriangleData||this.emissiveTriangleData}_createSpheres(){return[]}_reset(){this._disposeTextures(),this.triangles=[],this.triangleData=null,this.triangleCount=0,this.materials=[],this.meshTriangleRanges=null,this.maps=[],this.normalMaps=[],this.bumpMaps=[],this.roughnessMaps=[],this.metalnessMaps=[],this.emissiveMaps=[],this.displacementMaps=[],this.directionalLights=[],this.cameras=[],this.spheres=[],this.bvhRoot=null,this.bvhData=null,this.instanceTable=null,this.lightBVHNodeData=null,this.lightBVHNodeCount=0,this.performanceMetrics={textureCreationTime:0,geometryExtractionTime:0,bvhBuildTime:0,totalProcessingTime:0}}_disposeTextures(){[`albedoTextures`,`normalTextures`,`bumpTextures`,`roughnessTextures`,`metalnessTextures`,`emissiveTextures`,`displacementTextures`].forEach(e=>{this[e]&&(typeof this[e].dispose==`function`&&this[e].dispose(),this[e]=null)})}async rebuildMaterials(e){if(this.isProcessing)throw Error(`Already processing. Cannot rebuild materials during processing.`);this._log(`Rebuilding materials and textures`);let t=performance.now();try{this.isProcessing=!0;let n=this.geometryExtractor.extractMaterialsOnly(e);this._disposeMaterialTextures(),this.materials=n.materials,this.materialCount=this.materials.length,this.meshes=n.meshes,this.maps=n.maps,this.normalMaps=n.normalMaps,this.bumpMaps=n.bumpMaps,this.roughnessMaps=n.roughnessMaps,this.metalnessMaps=n.metalnessMaps,this.emissiveMaps=n.emissiveMaps,this.displacementMaps=n.displacementMaps,this.sceneFeatures=n.sceneFeatures;let r={materials:this.materials,triangles:this.triangleData,maps:this.maps,normalMaps:this.normalMaps,bumpMaps:this.bumpMaps,roughnessMaps:this.roughnessMaps,metalnessMaps:this.metalnessMaps,emissiveMaps:this.emissiveMaps,displacementMaps:this.displacementMaps,bvhRoot:this.bvhRoot},i=await this.textureCreator.createMaterialTextures(r);this.materialData=this.textureCreator.createMaterialRawData(this.materials),this.albedoTextures=i.albedoTexture,this.normalTextures=i.normalTexture,this.bumpTextures=i.bumpTexture,this.roughnessTextures=i.roughnessTexture,this.metalnessTextures=i.metalnessTexture,this.emissiveTextures=i.emissiveTexture,this.displacementTextures=i.displacementTexture;let a=performance.now()-t;return this._log(`Material rebuild complete (${a.toFixed(2)}ms)`,{materials:this.materials.length,textures:this.maps.length}),this}catch(e){throw console.error(`[SceneProcessor] Material rebuild error:`,e),e}finally{this.isProcessing=!1}}_disposeMaterialTextures(){[`albedoTextures`,`normalTextures`,`bumpTextures`,`roughnessTextures`,`metalnessTextures`,`emissiveTextures`,`displacementTextures`].forEach(e=>{if(this[e])try{typeof this[e].dispose==`function`&&this[e].dispose()}catch(t){console.warn(`[SceneProcessor] Error disposing ${e}:`,t)}finally{this[e]=null}}),this.textureCreator&&this.textureCreator.textureCache&&(this.textureCreator.textureCache.dispose(),this.textureCreator.textureCache=new this.textureCreator.textureCache.constructor)}getStatistics(){let e={triangleCount:this.triangleCount,materialCount:this.materials.length,textureCount:this.maps.length,lightCount:this.directionalLights.length,cameraCount:this.cameras.length,processingComplete:this.processingStage===`complete`,hasBVH:!!this.bvhRoot,hasTextures:!!this.materialData&&!!this.bvhData,useFloat32Array:this.config.useFloat32Array,triangleDataSize:this.triangleData?(this.triangleData.byteLength/(1024*1024)).toFixed(2)+`MB`:`0MB`};return this.performanceMetrics.totalProcessingTime>0&&(e.performance={totalTime:this.performanceMetrics.totalProcessingTime,textureTime:this.performanceMetrics.textureCreationTime,bvhTime:this.performanceMetrics.bvhBuildTime,extractionTime:this.performanceMetrics.geometryExtractionTime,texturePercentage:(this.performanceMetrics.textureCreationTime/this.performanceMetrics.totalProcessingTime*100).toFixed(1)+`%`}),this.textureCreator&&this.textureCreator.capabilities&&(e.textureCapabilities=this.textureCreator.capabilities),e}updateConfig(e){Object.assign(this.config,e),this.bvhBuilder&&(this.bvhBuilder.maxLeafSize=this.config.maxLeafSize,this.bvhBuilder.setTreeletConfig({enabled:this.config.enableTreeletOptimization,size:this.config.treeletSize,passes:this.config.treeletOptimizationPasses,minImprovement:this.config.treeletMinImprovement})),this._log(`Configuration updated`,this.config)}async refitBVH(e,t){if(!this.bvhData||!this.triangleData||!this.originalToBvhMap)throw Error(`No BVH data available for refit. Run buildBVH() first.`);if(!this._refitWorker)try{this._refitWorker=new Worker(Ma,{type:`module`})}catch(e){if(e.name!==`SecurityError`)throw e;this._refitWorker=await q(Ma)}if(!this._refitSharedBuffers){let t=new SharedArrayBuffer(this.bvhData.byteLength),n=new SharedArrayBuffer(this.triangleData.byteLength),r=new SharedArrayBuffer(e.byteLength),i=new Float32Array(t),a=new Float32Array(n);i.set(this.bvhData),a.set(this.triangleData),this.bvhData=i,this.triangleData=a;let o=this.originalToBvhMap.length,s=new Uint32Array(o);for(let e=0;e<o;e++)s[this.originalToBvhMap[e]]=e;this._refitSharedBuffers={bvhBuf:t,triBuf:n,posBuf:r,posView:new Float32Array(r)},this._refitWorker.postMessage({type:`init`,sharedBvhBuf:t,sharedTriBuf:n,sharedPosBuf:r,bvhToOriginal:s},[s.buffer])}return this._refitSharedBuffers.posView.set(e),new Promise((e,n)=>{this._refitWorker.onmessage=r=>{let i=r.data;i.type===`refitComplete`?(t&&this._patchSmoothNormals(t),e({refitTimeMs:i.refitTimeMs})):i.type===`error`&&n(Error(i.error))},this._refitWorker.postMessage({type:`refit`})})}_patchSmoothNormals(e){this._patchNormalsRange(e,0,this.originalToBvhMap.length)}refitBLASes(e,t,n){if(!this.instanceTable||!this.bvhData||!this.triangleData)throw Error(`No TLAS/BLAS data available. Run buildBVH() first.`);let r=performance.now();this._blasRefitter||=new la;for(let r of e){let e=this.instanceTable.entries[r];e&&(this._updateMeshTrianglePositions(e,t),n&&this._patchMeshSmoothNormals(e,n),this._blasRefitter.refitRange(this.bvhData,this.triangleData,e.blasOffset,e.blasNodeCount),this.instanceTable.recomputeAABB(r,this.bvhData,this.triangleData))}return this._refitTLAS(),{refitTimeMs:performance.now()-r}}computeBLASDirtyRanges(e){let t=H.FLOATS_PER_TRIANGLE,n=[],r=[];for(let i of e){let e=this.instanceTable.entries[i];e&&(n.push({offset:e.triOffset*t,count:e.triCount*t}),r.push({offset:e.blasOffset*16,count:e.blasNodeCount*16}))}return r.push({offset:0,count:this.instanceTable.tlasNodeCount*16}),{triRanges:n,bvhRanges:r}}uploadToPathTracer(e,t,n,r){return this.triangleData?(e.setTriangleData(this.triangleData,this.triangleCount),this.bvhData?(e.setBVHData(this.bvhData),e.setInstanceTable(this.instanceTable),this.materialData?e.materialData.setMaterialData(this.materialData):console.warn(`SceneProcessor: No material data, using defaults`),r&&e.environment.setEnvironmentTexture(r),e.materialData.setMaterialTextures({albedoMaps:this.albedoTextures,normalMaps:this.normalTextures,bumpMaps:this.bumpTextures,roughnessMaps:this.roughnessTextures,metalnessMaps:this.metalnessTextures,emissiveMaps:this.emissiveTextures,displacementMaps:this.displacementTextures}),this.emissiveTriangleData&&e.setEmissiveTriangleData(this.emissiveTriangleData,this.emissiveTriangleCount,this.emissiveTotalPower),this.lightBVHNodeData&&e.setLightBVHData(this.lightBVHNodeData,this.lightBVHNodeCount),t.transferSceneLights(n),!0):(console.error(`SceneProcessor: Failed to get BVH data`),!1)):(console.error(`SceneProcessor: Failed to get triangle data`),!1)}updateMaterialEmissive(e,t,n){if(!this.emissiveTriangleBuilder)return null;let r=this.materials[e];return!r||(t===`emissive`?r.emissive=n:t===`emissiveIntensity`&&(r.emissiveIntensity=n),!this.emissiveTriangleBuilder.updateMaterialEmissive(e,r,this.triangleData,this.materials,this.triangleCount))?null:{rawData:this.emissiveTriangleBuilder.createEmissiveRawData(),emissiveCount:this.emissiveTriangleBuilder.emissiveCount,totalPower:this.emissiveTriangleBuilder.totalEmissivePower}}_updateMeshTrianglePositions(e,t){let n=H.FLOATS_PER_TRIANGLE,r=H.POSITION_A_OFFSET,i=H.POSITION_B_OFFSET,a=H.POSITION_C_OFFSET,o=H.NORMAL_A_OFFSET,s=H.NORMAL_B_OFFSET,c=H.NORMAL_C_OFFSET,l=e.bvhToOriginal;for(let u=0;u<e.triCount;u++){let d=l[u],f=(e.triOffset+u)*n,p=(e.triOffset+d)*9,m=t[p],h=t[p+1],g=t[p+2],_=t[p+3],v=t[p+4],y=t[p+5],b=t[p+6],x=t[p+7],S=t[p+8];this.triangleData[f+r]=m,this.triangleData[f+r+1]=h,this.triangleData[f+r+2]=g,this.triangleData[f+i]=_,this.triangleData[f+i+1]=v,this.triangleData[f+i+2]=y,this.triangleData[f+a]=b,this.triangleData[f+a+1]=x,this.triangleData[f+a+2]=S;let C=_-m,w=v-h,T=y-g,E=b-m,D=x-h,O=S-g,k=w*O-T*D,A=T*E-C*O,j=C*D-w*E;this.triangleData[f+o]=k,this.triangleData[f+o+1]=A,this.triangleData[f+o+2]=j,this.triangleData[f+s]=k,this.triangleData[f+s+1]=A,this.triangleData[f+s+2]=j,this.triangleData[f+c]=k,this.triangleData[f+c+1]=A,this.triangleData[f+c+2]=j}}_patchMeshSmoothNormals(e,t){this._patchNormalsRange(t,e.triOffset,e.triCount)}_patchNormalsRange(e,t,n){let r=H.FLOATS_PER_TRIANGLE,i=H.NORMAL_A_OFFSET,a=H.NORMAL_B_OFFSET,o=H.NORMAL_C_OFFSET;for(let s=0;s<n;s++){let n=t+s,c=this.originalToBvhMap[n]*r,l=n*9;this.triangleData[c+i]=e[l],this.triangleData[c+i+1]=e[l+1],this.triangleData[c+i+2]=e[l+2],this.triangleData[c+a]=e[l+3],this.triangleData[c+a+1]=e[l+4],this.triangleData[c+a+2]=e[l+5],this.triangleData[c+o]=e[l+6],this.triangleData[c+o+1]=e[l+7],this.triangleData[c+o+2]=e[l+8]}}_refitTLAS(){let e=this.instanceTable.tlasNodeCount;(!this._tlasBounds||this._tlasBounds.length<e*6)&&(this._tlasBounds=new Float32Array(e*6)),this._blasOffsetMap||=new Map,this._blasOffsetMap.clear();for(let e of this.instanceTable.entries)e&&this._blasOffsetMap.set(e.blasOffset,e);for(let t=e-1;t>=0;t--){let e=t*16,n=this.bvhData[e+3];if(n===-2){let n=this.bvhData[e],r=this._blasOffsetMap.get(n);if(r&&r.worldAABB){let e=t*6;this._tlasBounds[e]=r.worldAABB.minX,this._tlasBounds[e+1]=r.worldAABB.minY,this._tlasBounds[e+2]=r.worldAABB.minZ,this._tlasBounds[e+3]=r.worldAABB.maxX,this._tlasBounds[e+4]=r.worldAABB.maxY,this._tlasBounds[e+5]=r.worldAABB.maxZ}}else if(n>=0){let n=this.bvhData[e+3],r=this.bvhData[e+7],i=n*6,a=r*6,o=this._tlasBounds;this.bvhData[e]=o[i],this.bvhData[e+1]=o[i+1],this.bvhData[e+2]=o[i+2],this.bvhData[e+4]=o[i+3],this.bvhData[e+5]=o[i+4],this.bvhData[e+6]=o[i+5],this.bvhData[e+8]=o[a],this.bvhData[e+9]=o[a+1],this.bvhData[e+10]=o[a+2],this.bvhData[e+12]=o[a+3],this.bvhData[e+13]=o[a+4],this.bvhData[e+14]=o[a+5];let s=t*6;o[s]=Math.min(o[i],o[a]),o[s+1]=Math.min(o[i+1],o[a+1]),o[s+2]=Math.min(o[i+2],o[a+2]),o[s+3]=Math.max(o[i+3],o[a+3]),o[s+4]=Math.max(o[i+4],o[a+4]),o[s+5]=Math.max(o[i+5],o[a+5])}}}scheduleBackgroundRebuild(e,t){if(!this.instanceTable||!this.triangleData)return;let n=H.FLOATS_PER_TRIANGLE;this._rebuildGeneration++;let r=this._rebuildGeneration,i=(e,i,a)=>{let o=this.triangleData.slice(i.triOffset*n,(i.triOffset+i.triCount)*n);this._pendingRebuilds.set(e,a),a.onmessage=n=>{let o=n.data;if(a.terminate(),this._pendingRebuilds.delete(e),o.error){console.error(`Background BLAS rebuild error (mesh ${e}):`,o.error);return}r===this._rebuildGeneration&&this._swapBLAS(e,i,o,t)},a.onerror=t=>{console.error(`Background BLAS rebuild worker error (mesh ${e}):`,t),a.terminate(),this._pendingRebuilds.delete(e)};let s=i.triCount>500;a.postMessage({triangleData:o.buffer,triangleByteOffset:o.byteOffset,triangleByteLength:o.byteLength,triangleCount:i.triCount,depth:this.config.bvhDepth,reportProgress:!1,sharedReorderBuffer:null,treeletOptimization:{enabled:s,size:this.config.treeletSize,passes:this.config.treeletOptimizationPasses,minImprovement:this.config.treeletMinImprovement},reinsertionOptimization:{enabled:this.bvhBuilder.enableReinsertionOptimization,batchSizeRatio:this.bvhBuilder.reinsertionBatchSizeRatio,maxIterations:this.bvhBuilder.reinsertionMaxIterations}},[o.buffer])};for(let t of e){let e=this.instanceTable.entries[t];if(!e)continue;let n=this._pendingRebuilds.get(t);n&&n.terminate();let r;try{r=new Worker(ea,{type:`module`}),i(t,e,r)}catch(n){if(n.name!==`SecurityError`)throw n;q(ea).then(n=>i(t,e,n))}}}_swapBLAS(e,t,n,r){let i=n.bvhData,a=i.length/16;if(a!==t.blasNodeCount){console.warn(`Background rebuild: node count mismatch for mesh ${e} (${a} vs ${t.blasNodeCount}), skipping swap`);return}let o=t.blasOffset*16;this.bvhData.set(i,o),this._offsetBLASInPlace(o,a,t.blasOffset,t.triOffset);let s=H.FLOATS_PER_TRIANGLE,c=n.triangles;c&&this.triangleData.set(c,t.triOffset*s);let l=n.originalToBvh;if(l){for(let e=0;e<t.triCount;e++)this.originalToBvhMap[t.triOffset+e]=t.triOffset+l[e];let e=new Uint32Array(t.triCount);for(let n=0;n<t.triCount;n++)e[l[n]]=n;t.bvhToOriginal=e}this.instanceTable.recomputeAABB(e,this.bvhData,this.triangleData),this._refitTLAS(),this._log(`Background BLAS rebuild complete for mesh ${e}`),r?.()}cancelBackgroundRebuilds(){for(let e of this._pendingRebuilds.values())e.terminate();this._pendingRebuilds.clear()}_disposeRefitWorker(){this._refitWorker&&=(this._refitWorker.terminate(),null),this._refitSharedBuffers=null,this.cancelBackgroundRebuilds()}dispose(){this._log(`Disposing resources`),this._disposeRefitWorker(),this._disposeTextures(),this._reset(),this.textureCreator&&=(this.textureCreator.dispose(),null),this.geometryExtractor=null,this.bvhBuilder=null,this.tlasBuilder=null,this._blasRefitter=null}},Pa=class{constructor(){this.lightData={directional:[],rectArea:[],point:[],spot:[]},this.directionalLightCache=[],this.areaLightCache=[],this.pointLightCache=[],this.spotLightCache=[]}clear(){this.lightData.directional=[],this.lightData.rectArea=[],this.lightData.point=[],this.lightData.spot=[],this.directionalLightCache=[],this.areaLightCache=[],this.pointLightCache=[],this.spotLightCache=[]}calculateLightImportance(e,t=`directional`){let n=.2126*e.color.r+.7152*e.color.g+.0722*e.color.b,r=e.intensity*n;if(t===`area`){let t=e.width*e.height;r*=Math.sqrt(t)}else if(t===`point`)r*=Math.sqrt(e.distance||100);else if(t===`spot`){let t=Math.sin(e.angle||Math.PI/4);r*=Math.sqrt(e.distance||100)*t}return r}addDirectionalLight(e){if(e.intensity<=0)return;e.updateMatrixWorld();let t=e.getWorldPosition(new r.Vector3),n;if(e.target){e.target.updateMatrixWorld();let i=e.target.getWorldPosition(new r.Vector3);n=t.sub(i).normalize()}else n=t.normalize();let i=this.calculateLightImportance(e,`directional`),a=e.userData.angle||e.angle||0;this.directionalLightCache.push({data:[n.x,n.y,n.z,e.color.r,e.color.g,e.color.b,e.intensity,a],importance:i,light:e})}addRectAreaLight(e){if(e.intensity<=0)return;e.updateMatrixWorld();let t=e.getWorldPosition(new r.Vector3),n=e.getWorldQuaternion(new r.Quaternion),i=e.getWorldScale(new r.Vector3),a=e.width*i.x*.5,o=e.height*i.y*.5,s=new r.Vector3(a,0,0).applyQuaternion(n),c=new r.Vector3(0,-o,0).applyQuaternion(n),l=this.calculateLightImportance(e,`area`);this.areaLightCache.push({data:[t.x,t.y,t.z,s.x,s.y,s.z,c.x,c.y,c.z,e.color.r,e.color.g,e.color.b,e.intensity],importance:l,light:e})}addPointLight(e){if(e.intensity<=0)return;e.updateMatrixWorld();let t=e.getWorldPosition(new r.Vector3),n=this.calculateLightImportance(e,`point`);this.pointLightCache.push({data:[t.x,t.y,t.z,e.color.r,e.color.g,e.color.b,e.intensity,e.distance||0,e.decay===void 0?2:e.decay],importance:n,light:e})}addSpotLight(e){if(e.intensity<=0)return;e.updateMatrixWorld();let t=e.getWorldPosition(new r.Vector3),n=(e.target?e.target.getWorldPosition(new r.Vector3):new r.Vector3(0,0,-1)).sub(t).normalize(),i=this.calculateLightImportance(e,`spot`);this.spotLightCache.push({data:[t.x,t.y,t.z,n.x,n.y,n.z,e.color.r,e.color.g,e.color.b,e.intensity,e.angle||Math.PI/4,e.penumbra||0,e.distance||0,e.decay===void 0?2:e.decay],importance:i,light:e})}preprocessLights(){this.directionalLightCache.sort((e,t)=>t.importance-e.importance),this.areaLightCache.sort((e,t)=>t.importance-e.importance),this.pointLightCache.sort((e,t)=>t.importance-e.importance),this.spotLightCache.sort((e,t)=>t.importance-e.importance),this.lightData.directional=[],this.lightData.rectArea=[],this.lightData.point=[],this.lightData.spot=[],this.directionalLightCache.forEach(e=>{this.lightData.directional.push(...e.data)}),this.areaLightCache.forEach(e=>{this.lightData.rectArea.push(...e.data)}),this.pointLightCache.forEach(e=>{this.lightData.point.push(...e.data)}),this.spotLightCache.forEach(e=>{this.lightData.spot.push(...e.data)}),this.areaLightCache.length>0&&console.log(`Preprocessed ${this.areaLightCache.length} area lights by importance`),this.pointLightCache.length>0&&console.log(`Preprocessed ${this.pointLightCache.length} point lights by importance`),this.spotLightCache.length>0&&console.log(`Preprocessed ${this.spotLightCache.length} spot lights by importance`)}updateShaderUniforms(e){let t=Math.floor(this.lightData.directional.length/8),n=Math.floor(this.lightData.rectArea.length/13),r=Math.floor(this.lightData.point.length/9),i=Math.floor(this.lightData.spot.length/14);e.defines.MAX_DIRECTIONAL_LIGHTS=t,e.defines.MAX_AREA_LIGHTS=n,e.defines.MAX_POINT_LIGHTS=r,e.defines.MAX_SPOT_LIGHTS=i,e.uniforms.directionalLights.value=new Float32Array(this.lightData.directional),e.uniforms.areaLights.value=new Float32Array(this.lightData.rectArea),e.uniforms.pointLights.value=new Float32Array(this.lightData.point),e.uniforms.spotLights.value=new Float32Array(this.lightData.spot),e.needsUpdate=!0}processSceneLights(e,t){this.clear(),e.traverse(e=>{e.isDirectionalLight?this.addDirectionalLight(e):e.isRectAreaLight?this.addRectAreaLight(e):e.isPointLight?this.addPointLight(e):e.isSpotLight&&this.addSpotLight(e)}),this.preprocessLights(),this.updateShaderUniforms(t)}getLightStatistics(){return{directionalLights:this.directionalLightCache.map(e=>({intensity:e.light.intensity,importance:e.importance,color:e.light.color})),areaLights:this.areaLightCache.map(e=>({intensity:e.light.intensity,importance:e.importance,color:e.light.color,size:e.light.width*e.light.height}))}}},Fa={stbnScalarAtlas:`https://assets.rayzee.atulmourya.com/noise/stbn_scalar_atlas.png`,stbnVec2Atlas:`https://assets.rayzee.atulmourya.com/noise/stbn_vec2_atlas.png`,ortRuntimeUrl:`https://cdn.jsdelivr.net/npm/onnxruntime-web@1.24.3/dist/ort.webgpu.bundle.min.mjs`,ortWasmPaths:`https://cdn.jsdelivr.net/npm/onnxruntime-web@1.24.3/dist/`,dracoDecoderPath:`https://www.gstatic.com/draco/v1/decoders/`,ktx2TranscoderPath:`https://cdn.jsdelivr.net/npm/three@0.183.2/examples/jsm/libs/basis/`,oidnWeightsBaseUrl:`https://cdn.jsdelivr.net/npm/denoiser/tzas/`,upscalerModelBaseUrl:`https://huggingface.co/notaneimu/onnx-image-models/resolve/main/`,cacheNamespace:`rayzee`};function Ia(e){e&&Object.assign(Fa,e)}function La(){return{...Fa}}var Ra=4,za=class extends R{constructor(e,t,n,i={}){super(`PathTracer`,{...i,executionMode:L.ALWAYS});let a=i.width||1920,o=i.height||1080;this.camera=n,this.width=a,this.height=o,this.renderer=e,this.scene=t,this.tileManager=new se(a,o,V.tiles),this.sdfs=new Na,this.lightSerializer=new Pa,this.accumulationEnabled=!0,this.isComplete=!1,this.cameras=[],this.performanceMonitor=be(),this.completionThreshold=0,this.renderLimitMode=`frames`,this._initDataTextures(),this.storageTextures=new Se(0,0),this.uniforms=new Fe(a,o),this._defineUniformGetters(),this.materialData=new ze(this.sdfs),this.materialData.callbacks.onReset=()=>this.reset(),this.materialData.callbacks.getTriangleData=()=>({array:this.triangleStorageAttr?.array,count:this.triangleCount}),this.materialData.callbacks.onTriangleDataChanged=()=>{this.triangleStorageAttr&&(this.triangleStorageAttr.needsUpdate=!0)},this.environment=new ht(this.scene,this.uniforms),this.environment.callbacks.onReset=()=>this.reset(),this.environment.callbacks.getSceneTextureNodes=()=>this.shaderBuilder.getSceneTextureNodes(),this.shaderBuilder=new Xi,this._initRenderingState(),this.setupBlueNoise(),this.tempVector2=new r.Vector2,this.lastCameraMatrix=new r.Matrix4,this.lastProjectionMatrix=new r.Matrix4,this.lastRenderMode=-1,this.tileCompletionFrame=0,this.renderModeChangeTimeout=null,this.renderModeChangeDelay=50,this.pendingRenderMode=null,this.adaptiveSamplingFrameToggle=!1,this.lastInteractionModeState=!1,this.cameraChanged=!1,this.tileChanged=!1,this.updateCompletionThreshold()}_initDataTextures(){this.triangleStorageAttr=null,this.triangleStorageNode=null,this.triangleCount=0,this.bvhStorageAttr=null,this.bvhStorageNode=null,this.bvhNodeCount=0,this.directionalLightsData=null,this.pointLightsData=null,this.spotLightsData=null,this.areaLightsData=null,this.stbnScalarTexture=null,this.stbnVec2Texture=null,this.lightStorageAttr=new t.StorageInstancedBufferAttribute(new Float32Array(16),4),this.lightStorageNode=(0,n.storage)(this.lightStorageAttr,`vec4`,1).toReadOnly(),this._lbvhDataCache=null,this._emissiveDataCache=null,this._instanceTable=null,this.adaptiveSamplingTexture=null,this.spheres=[]}_defineUniformGetters(){let e=this.uniforms;for(let t of e.keys())Object.defineProperty(this,t,{get:()=>e.get(t),configurable:!0});let t=e.getLightBufferNodes();for(let[e,n]of Object.entries(t))Object.defineProperty(this,`${e}LightsBufferNode`,{get:()=>n,configurable:!0})}_initRenderingState(){this.isReady=!1,this.frameCount=0}_initCameraOptimizer(){let e=this;this.cameraOptimizer=new ce(this.renderer,{uniforms:{maxBounceCount:{get value(){return e.maxBounces.value},set value(t){e.maxBounces.value=t}},numRaysPerPixel:{get value(){return e.samplesPerPixel.value},set value(t){e.samplesPerPixel.value=t}},useAdaptiveSampling:{get value(){return e.useAdaptiveSampling.value},set value(t){e.useAdaptiveSampling.value=t}},useEnvMapIS:{get value(){return e.useEnvMapIS.value},set value(t){e.useEnvMapIS.value=t}},enableAccumulation:{get value(){return e.enableAccumulation.value},set value(t){e.enableAccumulation.value=t}},enableEmissiveTriangleSampling:{get value(){return e.enableEmissiveTriangleSampling.value},set value(t){e.enableEmissiveTriangleSampling.value=t}},cameraIsMoving:{get value(){return e.cameraIsMoving.value},set value(t){e.cameraIsMoving.value=t}}}},{enabled:V.interactionModeEnabled,qualitySettings:{maxBounceCount:1,numRaysPerPixel:1,useAdaptiveSampling:!1,useEnvMapIS:!1,enableAccumulation:!1,enableEmissiveTriangleSampling:!1},onReset:()=>{this.reset(),this.emit(`pathtracer:viewpointChanged`)}})}setupBlueNoise(){let e=new r.TextureLoader;e.setCrossOrigin(`anonymous`);let t=e=>(e.minFilter=r.NearestFilter,e.magFilter=r.NearestFilter,e.wrapS=r.RepeatWrapping,e.wrapT=r.RepeatWrapping,e.generateMipmaps=!1,e),{stbnScalarAtlas:n,stbnVec2Atlas:i}=La();e.load(n,e=>{this.stbnScalarTexture=t(e),T.value=e,console.log(`PathTracer: STBN scalar atlas loaded ${e.image.width}x${e.image.height}`)}),e.load(i,e=>{this.stbnVec2Texture=t(e),E.value=e,console.log(`PathTracer: STBN vec2 atlas loaded ${e.image.width}x${e.image.height}`)})}setupEventListeners(){this.on(`pipeline:reset`,()=>{this.reset()}),this.on(`pipeline:resize`,e=>{e&&e.width&&e.height&&this.setSize(e.width,e.height)}),this.on(`pathtracer:setCompletionThreshold`,e=>{e&&e.threshold!==void 0&&(this.completionThreshold=e.threshold)})}async build(e){this.dispose(),this.scene=e,await this.sdfs.buildBVH(e),this.cameras=this.sdfs.cameras,this.materialData.injectMaterialFeatureDefines(),this.updateSceneUniforms(),this.updateLights(),this._initCameraOptimizer(),this.setupMaterial()}updateSceneUniforms(){this.setTriangleData(this.sdfs.triangleData,this.sdfs.triangleCount),this.setBVHData(this.sdfs.bvhData),this.setInstanceTable(this.sdfs.instanceTable),this.materialData.setMaterialData(this.sdfs.materialData),this.totalTriangleCount.value=this.sdfs.triangleCount||0,this.materialData.loadTexturesFromSdfs(),this.sdfs.emissiveTriangleData?this.setEmissiveTriangleData(this.sdfs.emissiveTriangleData,this.sdfs.emissiveTriangleCount||0):this.emissiveTriangleCount.value=0,this.sdfs.lightBVHNodeData?this.setLightBVHData(this.sdfs.lightBVHNodeData,this.sdfs.lightBVHNodeCount||0):this.lightBVHNodeCount.value=0,this._meshRefs=this._collectMeshRefs(this.scene),this.setMeshVisibilityData(this._meshRefs),this.spheres=this.sdfs.spheres||[]}updateLights(){let e={uniforms:{directionalLights:{value:null},pointLights:{value:null},spotLights:{value:null},areaLights:{value:null}},defines:{}};if(this.lightSerializer.processSceneLights(this.scene,e),this.directionalLightsData=e.uniforms.directionalLights.value,this.pointLightsData=e.uniforms.pointLights.value,this.spotLightsData=e.uniforms.spotLights.value,this.areaLightsData=e.uniforms.areaLights.value,this.hasSun.value){let t=this.environment.envParams.skySunIntensity*950,n={intensity:t,color:{r:1,g:1,b:1},userData:{angle:this.sunAngularSize.value},updateMatrixWorld:()=>{},getWorldPosition:e=>{let t=this.sunDirection.value;return e.set(t.x,t.y,t.z).multiplyScalar(1e10)}};this.lightSerializer.addDirectionalLight(n),this.lightSerializer.preprocessLights(),this.lightSerializer.updateShaderUniforms(e),this.directionalLightsData=e.uniforms.directionalLights.value,console.log(`Sun added as directional light (intensity: ${t.toFixed(2)})`)}this._updateLightBufferNodes()}_updateLightBufferNodes(){this.directionalLightsData&&this.directionalLightsData.length>0?(this.directionalLightsBufferNode.array=Array.from(this.directionalLightsData),this.numDirectionalLights.value=Math.floor(this.directionalLightsData.length/8)):this.numDirectionalLights.value=0,this.areaLightsData&&this.areaLightsData.length>0?(this.areaLightsBufferNode.array=Array.from(this.areaLightsData),this.numAreaLights.value=Math.floor(this.areaLightsData.length/13)):this.numAreaLights.value=0,this.pointLightsData&&this.pointLightsData.length>0?(this.pointLightsBufferNode.array=Array.from(this.pointLightsData),this.numPointLights.value=Math.floor(this.pointLightsData.length/9)):this.numPointLights.value=0,this.spotLightsData&&this.spotLightsData.length>0?(this.spotLightsBufferNode.array=Array.from(this.spotLightsData),this.numSpotLights.value=Math.floor(this.spotLightsData.length/14)):this.numSpotLights.value=0}reset(){this.frameCount=0,this.frame.value=0,this.hasPreviousAccumulated.value=0,this.storageTextures.currentTarget=0,this.tileManager.spiralOrder=this.tileManager.generateSpiralOrder(this.tileManager.tiles),this.updateCompletionThreshold(),this.isComplete=!1,this.performanceMonitor?.reset(),this.lastRenderMode=-1,this.tileCompletionFrame=0,this.lastInteractionModeState=!1}setTileCount(e){this.tileManager.setTileCount(e),this.updateCompletionThreshold(),this.reset()}setSize(e,t){this.width=e,this.height=t,this.resolution.value.set(e,t),this.tileManager.setSize(e,t),this.createStorageTextures(e,t),this.shaderBuilder.setSize(e,t)}setAccumulationEnabled(e){this.accumulationEnabled=e,this.enableAccumulation.value=+!!e}enterInteractionMode(){this.cameraOptimizer?.enterInteractionMode()}setInteractionModeEnabled(e){this.cameraOptimizer?.setInteractionModeEnabled(e)}get tiles(){return this.tileManager.tiles}get interactionMode(){return this.cameraOptimizer?.isInInteractionMode()??!1}setTriangleData(e,r){if(!e)return;let i=e.length/4;this.triangleStorageNode?(this.triangleStorageAttr=new t.StorageInstancedBufferAttribute(e,4),this.triangleStorageNode.value=this.triangleStorageAttr,this.triangleStorageNode.bufferCount=i):(this.triangleStorageAttr=new t.StorageInstancedBufferAttribute(e,4),this.triangleStorageNode=(0,n.storage)(this.triangleStorageAttr,`vec4`,i).toReadOnly()),this.triangleCount=r,console.log(`PathTracer: ${this.triangleCount} triangles (storage buffer)`)}setBVHData(e){if(!e)return;let r=e.length/4;this.bvhStorageNode?(this.bvhStorageAttr=new t.StorageInstancedBufferAttribute(e,4),this.bvhStorageNode.value=this.bvhStorageAttr,this.bvhStorageNode.bufferCount=r):(this.bvhStorageAttr=new t.StorageInstancedBufferAttribute(e,4),this.bvhStorageNode=(0,n.storage)(this.bvhStorageAttr,`vec4`,r).toReadOnly()),this.bvhNodeCount=Math.floor(r/Ra),console.log(`PathTracer: ${this.bvhNodeCount} BVH nodes (storage buffer)`)}setInstanceTable(e){this._instanceTable=e}setMeshVisibilityData(e){if(!(!e||e.length===0||!this._instanceTable)){for(let t=0;t<e.length;t++)this._patchTLASLeafVisibility(t,this._isWorldVisible(e[t]));this.bvhStorageAttr&&(this.bvhStorageAttr.needsUpdate=!0)}}updateMeshVisibility(e,t){this._patchTLASLeafVisibility(e,t)&&this.bvhStorageAttr&&(this.bvhStorageAttr.needsUpdate=!0)}updateAllMeshVisibility(){if(!(!this._meshRefs||!this._instanceTable)){for(let e=0;e<this._meshRefs.length;e++)this._patchTLASLeafVisibility(e,this._isWorldVisible(this._meshRefs[e]));this.bvhStorageAttr&&(this.bvhStorageAttr.needsUpdate=!0)}}_patchTLASLeafVisibility(e,t){let n=this._instanceTable?.entries?.[e];return!n||n.tlasLeafIndex<0||!this.bvhStorageAttr?!1:(n.visible=t,this.bvhStorageAttr.array[n.tlasLeafIndex*16+2]=+!!t,!0)}_collectMeshRefs(e){if(!e)return[];let t=[];return e.traverse(e=>{e.isMesh&&e.userData.meshIndex!==void 0&&(t[e.userData.meshIndex]=e)}),t}_isWorldVisible(e){for(;e;){if(!e.visible)return!1;e=e.parent}return!0}_updateStorageBuffer(e,t){e&&(e.array.set(t),e.needsUpdate=!0)}updateTriangleData(e){this._updateStorageBuffer(this.triangleStorageAttr,e)}updateBVHData(e){this._updateStorageBuffer(this.bvhStorageAttr,e)}updateBufferRanges(e,t){if(this.triangleStorageAttr&&e.length>0){this.triangleStorageAttr.clearUpdateRanges();for(let t of e)this.triangleStorageAttr.addUpdateRange(t.offset,t.count);this.triangleStorageAttr.version++}if(this.bvhStorageAttr&&t.length>0){this.bvhStorageAttr.clearUpdateRanges();for(let e of t)this.bvhStorageAttr.addUpdateRange(e.offset,e.count);this.bvhStorageAttr.version++}}createStorageTextures(e,t){this.storageTextures.writeColor?this.storageTextures.setSize(e,t):this.storageTextures.create(e,t),this.resolution.value.set(e,t)}setupMaterial(){if(this.cameraOptimizer||this._initCameraOptimizer(),!this.triangleStorageNode){console.error(`PathTracer: Triangle data required`);return}if(!this.bvhStorageNode){console.error(`PathTracer: BVH data required`);return}if(this.isReady&&this.shaderBuilder.getSceneTextureNodes()){this.shaderBuilder.updateSceneTextures(this);return}this._ensureStorageTextures(),this.shaderBuilder.setupCompute({stage:this,storageTextures:this.storageTextures}),this.isReady=!0}_ensureStorageTextures(){let e=this.renderer.domElement,t=Math.max(1,e.width||this.width),n=Math.max(1,e.height||this.height);this.storageTextures.ensureSize(t,n)&&this.resolution.value.set(t,n)}render(e,t){if(!this.isReady)return;if(this.isComplete||this.frameCount>=this.completionThreshold){this.isComplete||=!0;return}if(this.performanceMonitor?.start(),e&&this.shaderBuilder.adaptiveSamplingTexNode){let t=e.getTexture(`adaptiveSampling:output`);t&&(this.shaderBuilder.adaptiveSamplingTexNode.value=t)}let n=this.frameCount,r=this.renderMode.value,i=null,a=null;r===1&&n===0&&(i=this.maxBounces.value,a=this.samplesPerPixel.value,this.maxBounces.value=1,this.samplesPerPixel.value=1),this._handleResize(),this.manageASVGFForRenderMode(r,n);let o=this.tileManager.handleTileRendering(this.renderer,r,n,null);if(e&&e.setState(`tileRenderingComplete`,o.isCompleteCycle),o.tileIndex>=0){let e=this.tileManager.calculateTileBounds(o.tileIndex,this.tileManager.tiles,this.width,this.height);this.emit(`tile:changed`,{tileIndex:o.tileIndex,tileBounds:e,renderMode:r}),this.tileChanged=!0}this.cameraChanged=this._updateCameraUniforms(),this.cameraOptimizer?.updateInteractionMode(this.cameraChanged),this._updateAccumulationUniforms(n,r),this.frame.value=n,o.tileIndex>=0&&o.tileBounds?this.shaderBuilder.setTileDispatch(o.tileBounds.x,o.tileBounds.y,o.tileBounds.width,o.tileBounds.height):this.shaderBuilder.setFullScreenDispatch();let s=this.storageTextures.getReadTextures();this.shaderBuilder.prevColorTexNode&&(this.shaderBuilder.prevColorTexNode.value=s.color,this.shaderBuilder.prevNormalDepthTexNode.value=s.normalDepth,this.shaderBuilder.prevAlbedoTexNode.value=s.albedo),this.renderer.compute(this.shaderBuilder.computeNode),this.storageTextures.copyToReadTargets(this.renderer);let c=this.storageTextures.getReadTextures();e&&this._publishTexturesToContext(e,c),this._emitStateEvents(),this.cameraOptimizer?.isInInteractionMode()||this.frameCount++,i!==null&&(this.maxBounces.value=i),a!==null&&(this.samplesPerPixel.value=a),this.performanceMonitor?.end()}_handleResize(){let{width:e,height:t}=this.renderer.domElement;(e!==this.storageTextures.renderWidth||t!==this.storageTextures.renderHeight)&&(this.createStorageTextures(e,t),this.shaderBuilder.setSize(e,t),this.frameCount=0),this.resolution.value.set(e,t)}_matricesApproxEqual(e,t,n=1e-10){let r=e.elements,i=t.elements;for(let e=0;e<16;e++)if(Math.abs(r[e]-i[e])>n)return!1;return!0}_updateCameraUniforms(){return!this._matricesApproxEqual(this.lastCameraMatrix,this.camera.matrixWorld)||!this._matricesApproxEqual(this.lastProjectionMatrix,this.camera.projectionMatrixInverse)?(this.cameraWorldMatrix.value.copy(this.camera.matrixWorld),this.cameraViewMatrix.value.copy(this.camera.matrixWorldInverse),this.cameraProjectionMatrix.value.copy(this.camera.projectionMatrix),this.cameraProjectionMatrixInverse.value.copy(this.camera.projectionMatrixInverse),this.lastCameraMatrix.copy(this.camera.matrixWorld),this.lastProjectionMatrix.copy(this.camera.projectionMatrixInverse),!0):!1}_updateAccumulationUniforms(e,t){let n=this.cameraOptimizer?.isInInteractionMode()??!1;this.lastInteractionModeState=n,this.accumulationEnabled?n?(this.accumulationAlpha.value=1,this.hasPreviousAccumulated.value=0):(this.accumulationAlpha.value=ye(e,t,this.tileManager.totalTilesCache,!1),this.hasPreviousAccumulated.value=+(e>0)):(this.accumulationAlpha.value=1,this.hasPreviousAccumulated.value=0)}_publishTexturesToContext(e,t){e.setTexture(`pathtracer:color`,t.color),e.setTexture(`pathtracer:normalDepth`,t.normalDepth),e.setTexture(`pathtracer:albedo`,t.albedo),e.setState(`interactionMode`,this.cameraOptimizer?.isInInteractionMode()??!1),e.setState(`renderMode`,this.renderMode.value),e.setState(`tiles`,this.tileManager.tiles)}_emitStateEvents(){this.emit(`pathtracer:frameComplete`,{frame:this.frameCount,isComplete:this.isComplete}),this.cameraChanged&&=(this.emit(`camera:moved`),!1)}updateCompletionThreshold(){let e=this.renderMode.value,t=this.maxSamples.value;this.renderLimitMode===`time`?this.completionThreshold=1/0:this.completionThreshold=ve(e,t,this.tileManager.totalTilesCache)}setRenderLimitMode(e){this.renderLimitMode=e,this.updateCompletionThreshold()}manageASVGFForRenderMode(e,t){e!==this.lastRenderMode&&(this.renderModeChangeTimeout&&clearTimeout(this.renderModeChangeTimeout),this.pendingRenderMode=e,this.renderModeChangeTimeout=setTimeout(()=>{this.pendingRenderMode!==null&&this.pendingRenderMode!==this.lastRenderMode&&(this.lastRenderMode=this.pendingRenderMode,this._onRenderModeChanged(this.pendingRenderMode)),this.renderModeChangeTimeout=null,this.pendingRenderMode=null},this.renderModeChangeDelay)),e===1?this._handleTiledASVGF(t):this._handleFullQuadASVGF()}_onRenderModeChanged(e){e===1?this.emit(`asvgf:updateParameters`,{enableDebug:!1,temporalAlpha:.15}):this.emit(`asvgf:updateParameters`,{temporalAlpha:.1}),this.emit(`asvgf:reset`)}_handleTiledASVGF(e){let t=e===0,n=(t?-1:(e-1)%this.tileManager.totalTilesCache)==this.tileManager.totalTilesCache-1;t?this.emit(`asvgf:setTemporal`,{enabled:!0}):n?(this.emit(`asvgf:setTemporal`,{enabled:!0}),this.tileCompletionFrame=e):this.emit(`asvgf:setTemporal`,{enabled:!1})}_handleFullQuadASVGF(){this.emit(`asvgf:setTemporal`,{enabled:!0})}setUniform(e,t){this.uniforms.set(e,t)}setBlueNoiseTexture(e){this.stbnScalarTexture=e,e&&(T.value=e)}_rebuildLightBuffer(){let e=this._lbvhDataCache,n=this._emissiveDataCache,r=e?e.length:0,i=n?n.length:0,a=Math.max(r+i,4),o=new Float32Array(a);e&&o.set(e,0),n&&o.set(n,r),this.lightStorageAttr=new t.StorageInstancedBufferAttribute(o,4),this.lightStorageNode.value=this.lightStorageAttr,this.lightStorageNode.bufferCount=o.length/4,this.emissiveVec4Offset.value=(this.lightBVHNodeCount.value||0)*4}setEmissiveTriangleData(e,t,n=0){e&&(this._emissiveDataCache=e,this.emissiveTriangleCount.value=t,this.emissiveTotalPower.value=n,this._rebuildLightBuffer(),console.log(`PathTracer: ${t} emissive triangles, totalPower=${n.toFixed(4)} (storage buffer)`))}setLightBVHData(e,t){e&&(this._lbvhDataCache=e,this.lightBVHNodeCount.value=t,this._rebuildLightBuffer(),console.log(`PathTracer: Light BVH ${t} nodes`))}updateUniforms(e){let t=!1;for(let[n,r]of Object.entries(e))this[n]&&this[n].value!==void 0&&this[n].value!==r&&(this[n].value=r,t=!0);t&&this.reset()}async rebuildMaterials(e){if(!this.sdfs)throw Error(`Scene not built yet. Call build() first.`);try{console.log(`PathTracer: Starting material rebuild...`),await this.sdfs.rebuildMaterials(e),this.updateSceneUniforms(),this.shaderBuilder.updateSceneTextures(this),this.updateLights(),this.reset(),console.log(`PathTracer materials rebuilt successfully`)}catch(e){console.error(`Error rebuilding PathTracer materials:`,e);try{console.warn(`Attempting recovery by resetting path tracer...`),this.reset()}catch(e){console.error(`Recovery failed:`,e)}throw e}}dispose(){this.renderModeChangeTimeout&&=(clearTimeout(this.renderModeChangeTimeout),null),this.tileManager?.dispose(),this.cameraOptimizer?.dispose(),this.materialData?.dispose(),this.environment?.dispose(),this.shaderBuilder?.dispose(),this.uniforms?.dispose(),this.storageTextures?.dispose(),this.stbnScalarTexture?.dispose(),this.stbnVec2Texture?.dispose(),this.placeholderTexture?.dispose(),this.triangleStorageAttr=null,this.triangleStorageNode=null,this.bvhStorageAttr=null,this.bvhStorageNode=null,this.placeholderTexture=null,this.isReady=!1}},Ba=class extends R{constructor(e,i={}){super(`NormalDepth`,{...i,executionMode:L.ALWAYS}),this.renderer=e,this.pathTracer=i.pathTracer,this._dirty=!0,this.cameraWorldMatrix=(0,n.uniform)(new r.Matrix4,`mat4`),this.cameraProjectionMatrixInverse=(0,n.uniform)(new r.Matrix4,`mat4`),this.resolutionWidth=(0,n.uniform)(i.width||1),this.resolutionHeight=(0,n.uniform)(i.height||1);let a=i.width||1,o=i.height||1;this._outputStorageTex=new t.StorageTexture(a,o),this._outputStorageTex.type=r.HalfFloatType,this._outputStorageTex.format=r.RGBAFormat,this._outputStorageTex.minFilter=r.NearestFilter,this._outputStorageTex.magFilter=r.NearestFilter,this.renderTarget=new t.RenderTarget(a,o,{type:r.HalfFloatType,format:r.RGBAFormat,minFilter:r.NearestFilter,magFilter:r.NearestFilter,depthBuffer:!1,stencilBuffer:!1}),this._dispatchX=Math.ceil(a/8),this._dispatchY=Math.ceil(o/8),this._triStorageNode=null,this._bvhStorageNode=null,this._matStorageNode=null,this._lastTriAttr=null,this._lastBvhAttr=null,this._lastMatAttr=null,this._computeNode=null,this._computeBuilt=!1}setupEventListeners(){this.on(`camera:moved`,()=>{this._dirty=!0}),this.on(`pipeline:reset`,()=>{this._dirty=!0})}_syncStorageBuffers(){let e=this.pathTracer;if(!e)return!1;let t=e.materialData.materialStorageAttr,r=e.triangleStorageAttr&&e.triangleStorageAttr!==this._lastTriAttr,i=e.bvhStorageAttr&&e.bvhStorageAttr!==this._lastBvhAttr,a=t&&t!==this._lastMatAttr;return(r||i||a)&&(this._computeNode?.dispose?.(),this._computeNode=null,this._computeBuilt=!1,this._triStorageNode=null,this._bvhStorageNode=null,this._matStorageNode=null,this._dirty=!0),e.triangleStorageAttr&&!this._triStorageNode&&(this._triStorageNode=(0,n.storage)(e.triangleStorageAttr,`vec4`,e.triangleStorageAttr.count).toReadOnly()),e.bvhStorageAttr&&!this._bvhStorageNode&&(this._bvhStorageNode=(0,n.storage)(e.bvhStorageAttr,`vec4`,e.bvhStorageAttr.count).toReadOnly()),t&&!this._matStorageNode&&(this._matStorageNode=(0,n.storage)(t,`vec4`,t.count).toReadOnly()),this._lastTriAttr=e.triangleStorageAttr||this._lastTriAttr,this._lastBvhAttr=e.bvhStorageAttr||this._lastBvhAttr,this._lastMatAttr=t||this._lastMatAttr,!!(this._triStorageNode&&this._bvhStorageNode&&this._matStorageNode)}_buildCompute(){let e=this._triStorageNode,t=this._bvhStorageNode,r=this._matStorageNode,i=this.cameraWorldMatrix,a=this.cameraProjectionMatrixInverse,o=this.resolutionWidth,s=this.resolutionHeight,c=this._outputStorageTex;this._computeNode=(0,n.Fn)(([i,a])=>{let l=(0,n.int)(n.workgroupId.x).mul(8).add((0,n.int)(n.localId.x)),u=(0,n.int)(n.workgroupId.y).mul(8).add((0,n.int)(n.localId.y));(0,n.If)(l.lessThan((0,n.int)(o)).and(u.lessThan((0,n.int)(s))),()=>{let d=(0,n.vec3)((0,n.float)(l).add(.5).div(o).mul(2).sub(1),(0,n.float)(u).add(.5).div(s).mul(2).sub(1).negate(),1),f=a.mul((0,n.vec4)(d,1)),p=(0,n.normalize)((0,n.mat3)(i[0].xyz,i[1].xyz,i[2].xyz).mul(f.xyz.div(f.w))),m=gt({origin:(0,n.vec3)(i[3]),direction:p}),h=yt.wrap(dn(m,t,e,r)),g=h.normal.mul(.5).add(.5),_=h.dst,v=h.didHit.select((0,n.vec4)(g,_),(0,n.vec4)(0,0,0,(0,n.float)(1e6)));(0,n.textureStore)(c,(0,n.uvec2)((0,n.uint)(l),(0,n.uint)(u)),v).toWriteOnly()})})(i,a).compute([this._dispatchX,this._dispatchY,1],[8,8,1]),this._computeBuilt=!0}render(e){if(!this.enabled||!this._syncStorageBuffers())return;this._computeBuilt||this._buildCompute();let t=this.pathTracer;if(t&&(this.cameraWorldMatrix.value.copy(t.uniforms.get(`cameraWorldMatrix`).value),this.cameraProjectionMatrixInverse.value.copy(t.uniforms.get(`cameraProjectionMatrixInverse`).value)),!this._dirty&&this.renderTarget.texture){e.setTexture(`pathtracer:normalDepth`,this.renderTarget.texture);return}let n=e.getTexture(`pathtracer:color`);if(n&&n.image){let e=n.image;e.width>0&&e.height>0&&(e.width!==this.renderTarget.width||e.height!==this.renderTarget.height)&&this.setSize(e.width,e.height)}this.renderer.compute(this._computeNode),this.renderer.copyTextureToTexture(this._outputStorageTex,this.renderTarget.texture),e.setTexture(`pathtracer:normalDepth`,this.renderTarget.texture),this._dirty=!1}reset(){this._dirty=!0}setSize(e,t){this._outputStorageTex.setSize(e,t),this.renderTarget.setSize(e,t),this.renderTarget.texture.needsUpdate=!0,this.resolutionWidth.value=e,this.resolutionHeight.value=t,this._dispatchX=Math.ceil(e/8),this._dispatchY=Math.ceil(t/8),this._computeNode&&(this._computeNode.dispatchSize=[this._dispatchX,this._dispatchY,1]),this._dirty=!0}dispose(){this._computeNode?.dispose(),this._outputStorageTex?.dispose(),this.renderTarget?.dispose()}},Va=class extends R{constructor(e,i,a={}){super(`MotionVector`,{...a,executionMode:L.ALWAYS}),this.renderer=e,this.camera=i,this.pathTracer=a.pathTracer||null;let o=a.width||1,s=a.height||1;this.prevViewProjectionMatrix=new r.Matrix4,this.currentViewProjectionMatrix=new r.Matrix4,this.matricesInitialized=!1,this.isFirstFrame=!0,this.frameCount=0,this.cameraWorldMatrix=(0,n.uniform)(new r.Matrix4,`mat4`),this.cameraProjectionMatrixInverse=(0,n.uniform)(new r.Matrix4,`mat4`),this.prevVP=(0,n.uniform)(new r.Matrix4,`mat4`),this.isFirstFrameU=(0,n.uniform)(1),this.deltaTime=(0,n.uniform)(1/60),this.velocityScale=(0,n.uniform)(1),this.resolutionWidth=(0,n.uniform)(o),this.resolutionHeight=(0,n.uniform)(s),this._normalDepthTexNode=new t.TextureNode,this._screenSpaceStorageTex=new t.StorageTexture(o,s),this._screenSpaceStorageTex.type=r.HalfFloatType,this._screenSpaceStorageTex.format=r.RGBAFormat,this._screenSpaceStorageTex.minFilter=r.NearestFilter,this._screenSpaceStorageTex.magFilter=r.NearestFilter,this._worldSpaceStorageTex=new t.StorageTexture(o,s),this._worldSpaceStorageTex.type=r.HalfFloatType,this._worldSpaceStorageTex.format=r.RGBAFormat,this._worldSpaceStorageTex.minFilter=r.NearestFilter,this._worldSpaceStorageTex.magFilter=r.NearestFilter;let c={type:r.HalfFloatType,format:r.RGBAFormat,minFilter:r.NearestFilter,magFilter:r.NearestFilter,depthBuffer:!1,stencilBuffer:!1};this.screenSpaceTarget=new t.RenderTarget(o,s,c),this.worldSpaceTarget=new t.RenderTarget(o,s,c),this._dispatchX=Math.ceil(o/16),this._dispatchY=Math.ceil(s/16),this._buildScreenSpaceCompute(),this._buildWorldSpaceCompute()}_buildScreenSpaceCompute(){let e=this._normalDepthTexNode,t=this.cameraWorldMatrix,r=this.cameraProjectionMatrixInverse,i=this.prevVP,a=this.resolutionWidth,o=this.resolutionHeight,s=this._screenSpaceStorageTex;this._screenSpaceComputeNode=(0,n.Fn)(([t,r])=>{let c=(0,n.int)(n.workgroupId.x).mul(16).add((0,n.int)(n.localId.x)),l=(0,n.int)(n.workgroupId.y).mul(16).add((0,n.int)(n.localId.y));(0,n.If)(c.lessThan((0,n.int)(a)).and(l.lessThan((0,n.int)(o))),()=>{let u=(0,n.textureLoad)(e,(0,n.ivec2)(c,l)).w,d=(0,n.vec2)((0,n.float)(c).add(.5).div(a),(0,n.float)(l).add(.5).div(o)),f=(0,n.vec4)(0,0,u,1).toVar();(0,n.If)(u.lessThan((0,n.float)(1e5)),()=>{let e=(0,n.vec3)((0,n.float)(c).add(.5).div(a).mul(2).sub(1),(0,n.float)(l).add(.5).div(o).mul(2).sub(1).negate(),1),s=r.mul((0,n.vec4)(e,1)),p=(0,n.normalize)((0,n.mat3)(t[0].xyz,t[1].xyz,t[2].xyz).mul(s.xyz.div(s.w))),m=(0,n.vec3)(t[3]).add(p.mul(u)),h=i.mul((0,n.vec4)(m,1)),g=h.xy.div(h.w),_=(0,n.vec2)(g.x.mul(.5).add(.5),g.y.mul(-.5).add(.5)),v=d.sub(_),y=_.x.greaterThanEqual(0).and(_.x.lessThanEqual(1)).and(_.y.greaterThanEqual(0)).and(_.y.lessThanEqual(1));f.assign(y.select((0,n.vec4)(v,u,1),(0,n.vec4)((0,n.float)(1e3),(0,n.float)(1e3),u,0)))}),(0,n.textureStore)(s,(0,n.uvec2)((0,n.uint)(c),(0,n.uint)(l)),f).toWriteOnly()})})(t,r).compute([this._dispatchX,this._dispatchY,1],[16,16,1])}_buildWorldSpaceCompute(){let e=this._normalDepthTexNode,t=this.cameraWorldMatrix,r=this.cameraProjectionMatrixInverse,i=this.prevVP,a=this.isFirstFrameU,o=this.deltaTime,s=this.velocityScale,c=this.resolutionWidth,l=this.resolutionHeight,u=this._worldSpaceStorageTex;this._worldSpaceComputeNode=(0,n.Fn)(([t,r])=>{let d=(0,n.int)(n.workgroupId.x).mul(16).add((0,n.int)(n.localId.x)),f=(0,n.int)(n.workgroupId.y).mul(16).add((0,n.int)(n.localId.y));(0,n.If)(d.lessThan((0,n.int)(c)).and(f.lessThan((0,n.int)(l))),()=>{let p=(0,n.textureLoad)(e,(0,n.ivec2)(d,f)).w,m=(0,n.vec4)(0,0,0,0).toVar();(0,n.If)(a.lessThan(.5).and(p.lessThan((0,n.float)(1e5))),()=>{let e=(0,n.vec3)((0,n.float)(d).add(.5).div(c).mul(2).sub(1),(0,n.float)(f).add(.5).div(l).mul(2).sub(1).negate(),1),a=r.mul((0,n.vec4)(e,1)),u=(0,n.normalize)((0,n.mat3)(t[0].xyz,t[1].xyz,t[2].xyz).mul(a.xyz.div(a.w))),h=(0,n.vec3)(t[3]).add(u.mul(p)),g=(0,n.vec2)((0,n.float)(d).add(.5).div(c),(0,n.float)(f).add(.5).div(l)),_=i.mul((0,n.vec4)(h,1)),v=_.xy.div(_.w),y=(0,n.vec2)(v.x.mul(.5).add(.5),v.y.mul(-.5).add(.5)),b=y.x.greaterThanEqual(0).and(y.x.lessThanEqual(1)).and(y.y.greaterThanEqual(0)).and(y.y.lessThanEqual(1)),x=g.sub(y),S=(0,n.vec3)(x.x.div(o).mul(s),x.y.div(o).mul(s),0);m.assign(b.select((0,n.vec4)(S,1),(0,n.vec4)(0,0,0,.5)))}),(0,n.textureStore)(u,(0,n.uvec2)((0,n.uint)(d),(0,n.uint)(f)),m).toWriteOnly()})})(t,r).compute([this._dispatchX,this._dispatchY,1],[16,16,1])}_updateCameraMatrices(){let e=this.pathTracer,t,n,r,i;if(e&&e.uniforms)t=e.uniforms.get(`cameraWorldMatrix`).value,n=e.uniforms.get(`cameraViewMatrix`).value,r=e.uniforms.get(`cameraProjectionMatrix`).value,i=e.uniforms.get(`cameraProjectionMatrixInverse`).value;else{let e=this.camera;if(!e)return;t=e.matrixWorld,n=e.matrixWorldInverse,r=e.projectionMatrix,i=e.projectionMatrixInverse}this.matricesInitialized?this.prevViewProjectionMatrix.copy(this.currentViewProjectionMatrix):(this.currentViewProjectionMatrix.multiplyMatrices(r,n),this.prevViewProjectionMatrix.copy(this.currentViewProjectionMatrix),this.matricesInitialized=!0),this.currentViewProjectionMatrix.multiplyMatrices(r,n),this.cameraWorldMatrix.value.copy(t),this.cameraProjectionMatrixInverse.value.copy(i),this.prevVP.value.copy(this.prevViewProjectionMatrix)}setupEventListeners(){this.on(`pipeline:reset`,()=>{this.reset()})}render(e){if(!this.enabled)return;let t=e.getTexture(`pathtracer:normalDepth`);if(!t)return;this._updateCameraMatrices(),this.isFirstFrameU.value=+!!this.isFirstFrame,this.frameCount++;let n=t.image;n&&n.width>0&&n.height>0&&(n.width!==this.screenSpaceTarget.width||n.height!==this.screenSpaceTarget.height)&&this.setSize(n.width,n.height),this._normalDepthTexNode.value=t,this.renderer.compute(this._screenSpaceComputeNode),this.renderer.compute(this._worldSpaceComputeNode),this.renderer.copyTextureToTexture(this._screenSpaceStorageTex,this.screenSpaceTarget.texture),this.renderer.copyTextureToTexture(this._worldSpaceStorageTex,this.worldSpaceTarget.texture),e.setTexture(`motionVector:screenSpace`,this.screenSpaceTarget.texture),e.setTexture(`motionVector:worldSpace`,this.worldSpaceTarget.texture),e.setTexture(`motionVector:motion`,this.screenSpaceTarget.texture),this.emit(`motionvector:computed`,{frame:this.frameCount,isFirstFrame:this.isFirstFrame}),this.isFirstFrame=!1}reset(){this.matricesInitialized||(this.isFirstFrame=!0),this.frameCount=0}setSize(e,t){this._screenSpaceStorageTex.setSize(e,t),this._worldSpaceStorageTex.setSize(e,t),this.screenSpaceTarget.setSize(e,t),this.screenSpaceTarget.texture.needsUpdate=!0,this.worldSpaceTarget.setSize(e,t),this.worldSpaceTarget.texture.needsUpdate=!0,this.resolutionWidth.value=e,this.resolutionHeight.value=t,this._dispatchX=Math.ceil(e/16),this._dispatchY=Math.ceil(t/16),this._screenSpaceComputeNode&&(this._screenSpaceComputeNode.dispatchSize=[this._dispatchX,this._dispatchY,1]),this._worldSpaceComputeNode&&(this._worldSpaceComputeNode.dispatchSize=[this._dispatchX,this._dispatchY,1])}setVelocityScale(e){this.velocityScale.value=e}setDeltaTime(e){this.deltaTime.value=e}dispose(){this._screenSpaceComputeNode?.dispose(),this._worldSpaceComputeNode?.dispose(),this._screenSpaceStorageTex?.dispose(),this._worldSpaceStorageTex?.dispose(),this.screenSpaceTarget?.dispose(),this.worldSpaceTarget?.dispose(),this._normalDepthTexNode?.dispose()}},Ha=class extends R{constructor(e,i={}){super(`ASVGF`,{...i,executionMode:L.PER_CYCLE}),this.renderer=e,this.temporalAlpha=(0,n.uniform)(i.temporalAlpha??.1),this.phiColor=(0,n.uniform)(i.phiColor??10),this.maxAccumFrames=(0,n.uniform)(i.maxAccumFrames??32),this.varianceClip=(0,n.uniform)(i.varianceClip??1),this.resW=(0,n.uniform)(i.width||1),this.resH=(0,n.uniform)(i.height||1),this.temporalEnabled=!0,this.temporalEnabledU=(0,n.uniform)(1),this._colorTexNode=new t.TextureNode,this._motionTexNode=new t.TextureNode,this._readTemporalTexNode=new t.TextureNode;let a=i.width||1,o=i.height||1;this._temporalTexA=new t.StorageTexture(a,o),this._temporalTexA.type=r.HalfFloatType,this._temporalTexA.format=r.RGBAFormat,this._temporalTexA.minFilter=r.LinearFilter,this._temporalTexA.magFilter=r.LinearFilter,this._temporalTexB=new t.StorageTexture(a,o),this._temporalTexB.type=r.HalfFloatType,this._temporalTexB.format=r.RGBAFormat,this._temporalTexB.minFilter=r.LinearFilter,this._temporalTexB.magFilter=r.LinearFilter,this._gradientStorageTex=new t.StorageTexture(a,o),this._gradientStorageTex.type=r.HalfFloatType,this._gradientStorageTex.format=r.RGBAFormat,this._gradientStorageTex.minFilter=r.LinearFilter,this._gradientStorageTex.magFilter=r.LinearFilter,this.currentMoments=0,this._compiled=!1,this._dispatchX=Math.ceil(a/8),this._dispatchY=Math.ceil(o/8),this._buildGradientCompute(),this._buildTemporalCompute(),this.showHeatmap=!1,this.debugMode=(0,n.uniform)(0,`int`),this._heatmapStorageTex=new t.StorageTexture(a,o),this._heatmapStorageTex.type=r.FloatType,this._heatmapStorageTex.format=r.RGBAFormat,this._heatmapStorageTex.minFilter=r.NearestFilter,this._heatmapStorageTex.magFilter=r.NearestFilter,this.heatmapTarget=new t.RenderTarget(a,o,{type:r.FloatType,format:r.RGBAFormat,minFilter:r.NearestFilter,magFilter:r.NearestFilter,depthBuffer:!1,stencilBuffer:!1}),this._heatmapRawColorTexNode=new t.TextureNode,this._heatmapColorTexNode=new t.TextureNode,this._heatmapTemporalTexNode=new t.TextureNode,this._heatmapNDTexNode=new t.TextureNode,this._heatmapMotionTexNode=new t.TextureNode,this._heatmapGradientTexNode=new t.TextureNode,this._buildHeatmapCompute(),this.frameCount=0}_buildGradientCompute(){let e=this._colorTexNode,t=this._motionTexNode,r=this._readTemporalTexNode,i=this._gradientStorageTex,a=this.resW,o=this.resH,s=(0,n.workgroupArray)(`float`,100);this._gradientNode=(0,n.Fn)(()=>{let c=n.localId.x,l=n.localId.y,u=l.mul(8).add(c),d=(0,n.int)(n.workgroupId.x).mul(8).sub(1),f=(0,n.int)(n.workgroupId.y).mul(8).sub(1),p=u.mod(10),m=u.div(10),h=(0,n.textureLoad)(e,(0,n.ivec2)(d.add((0,n.int)(p)).clamp((0,n.int)(0),(0,n.int)(a).sub(1)),f.add((0,n.int)(m)).clamp((0,n.int)(0),(0,n.int)(o).sub(1)))).xyz;s.element(u).assign(Ht(h)),(0,n.If)(u.lessThan((0,n.uint)(36)),()=>{let t=u.add((0,n.uint)(64)),r=t.mod(10),i=t.div(10),c=(0,n.textureLoad)(e,(0,n.ivec2)(d.add((0,n.int)(r)).clamp((0,n.int)(0),(0,n.int)(a).sub(1)),f.add((0,n.int)(i)).clamp((0,n.int)(0),(0,n.int)(o).sub(1)))).xyz;s.element(t).assign(Ht(c))}),(0,n.workgroupBarrier)();let g=(0,n.int)(n.workgroupId.x).mul(8).add((0,n.int)(c)),_=(0,n.int)(n.workgroupId.y).mul(8).add((0,n.int)(l));(0,n.If)(g.lessThan((0,n.int)(a)).and(_.lessThan((0,n.int)(o))),()=>{let e=(0,n.float)(-1).toVar(),u=(0,n.int)(0).toVar(),d=(0,n.int)(0).toVar();for(let t=-1;t<=1;t++)for(let r=-1;r<=1;r++){let i=s.element(l.add(1+t).mul(10).add(c.add(1+r)));(0,n.If)(i.greaterThan(e),()=>{e.assign(i),u.assign((0,n.int)(r)),d.assign((0,n.int)(t))})}let f=g.add(u).clamp((0,n.int)(0),(0,n.int)(a).sub(1)),p=_.add(d).clamp((0,n.int)(0),(0,n.int)(o).sub(1)),m=(0,n.textureLoad)(t,(0,n.ivec2)(f,p)),h=(0,n.float)(f).sub(m.x.mul(a)),v=(0,n.float)(p).sub(m.y.mul(o)),y=(0,n.textureLoad)(r,(0,n.ivec2)((0,n.int)(h).clamp((0,n.int)(0),(0,n.int)(a).sub(1)),(0,n.int)(v).clamp((0,n.int)(0),(0,n.int)(o).sub(1)))).xyz,b=Ht(y),x=(0,n.abs)(e.sub(b)).div((0,n.max)(e,(0,n.float)(.001))).clamp(0,1);(0,n.textureStore)(i,(0,n.uvec2)((0,n.uint)(g),(0,n.uint)(_)),(0,n.vec4)(x,e,b,1)).toWriteOnly()})})().compute([this._dispatchX,this._dispatchY,1],[8,8,1])}_buildTemporalCompute(){this._temporalNodeA=this._buildTemporalForDirection(this._temporalTexA),this._temporalNodeB=this._buildTemporalForDirection(this._temporalTexB)}_buildTemporalForDirection(e){let t=this._colorTexNode,r=this._motionTexNode,i=this._readTemporalTexNode,a=this.temporalAlpha,o=this.maxAccumFrames,s=this.varianceClip,c=this.temporalEnabledU,l=this.resW,u=this.resH;return(0,n.Fn)(()=>{let d=(0,n.int)(n.workgroupId.x).mul(8).add((0,n.int)(n.localId.x)),f=(0,n.int)(n.workgroupId.y).mul(8).add((0,n.int)(n.localId.y));(0,n.If)(d.lessThan((0,n.int)(l)).and(f.lessThan((0,n.int)(u))),()=>{let p=(0,n.ivec2)(d,f),m=(0,n.textureLoad)(t,p).xyz,h=(0,n.vec4)(m,1).toVar();(0,n.If)(c.greaterThan(.5),()=>{let e=(0,n.textureLoad)(r,p),c=e.w.greaterThan(.5),g=(0,n.float)(d).sub(e.x.mul(l)),_=(0,n.float)(f).sub(e.y.mul(u)),v=g.greaterThanEqual(0).and(g.lessThan((0,n.float)(l))).and(_.greaterThanEqual(0)).and(_.lessThan((0,n.float)(u)));(0,n.If)(c.and(v),()=>{let e=(0,n.textureLoad)(i,(0,n.ivec2)((0,n.int)(g).clamp((0,n.int)(0),(0,n.int)(l).sub(1)),(0,n.int)(_).clamp((0,n.int)(0),(0,n.int)(u).sub(1)))),r=e.xyz,c=e.w,p=(0,n.vec3)(0).toVar(),v=(0,n.vec3)(0).toVar();for(let e=-1;e<=1;e++)for(let r=-1;r<=1;r++){let i=(0,n.textureLoad)(t,(0,n.ivec2)(d.add(r).clamp((0,n.int)(0),(0,n.int)(l).sub(1)),f.add(e).clamp((0,n.int)(0),(0,n.int)(u).sub(1)))).xyz;p.addAssign(i),v.addAssign(i.mul(i))}p.divAssign(9),v.divAssign(9);let y=(0,n.dot)((0,n.max)(v.sub(p.mul(p)),(0,n.vec3)(0)),(0,n.vec3)(1)),b=r.sub(p),x=(0,n.dot)(b,b),S=y.mul(s.mul(s)),C=x.div((0,n.max)(S,(0,n.float)(1e-6))).clamp(0,1),w=(0,n.mix)(r,m,(0,n.mix)((0,n.max)((0,n.float)(1).div(c.add(1)),a),(0,n.float)(1),C)),T=(0,n.mix)((0,n.min)(c.add(1),o),(0,n.float)(1),C);h.assign((0,n.vec4)(w,T))}).Else(()=>{h.assign((0,n.vec4)(m,1))})}),(0,n.textureStore)(e,(0,n.uvec2)((0,n.uint)(d),(0,n.uint)(f)),h).toWriteOnly()})})().compute([this._dispatchX,this._dispatchY,1],[8,8,1])}_buildHeatmapCompute(){let e=this._heatmapRawColorTexNode,t=this._heatmapColorTexNode,r=this._heatmapTemporalTexNode,i=this._heatmapNDTexNode,a=this._heatmapMotionTexNode,o=this._heatmapGradientTexNode,s=this._heatmapStorageTex,c=this.debugMode,l=this.resW,u=this.resH;this._heatmapComputeNode=(0,n.Fn)(()=>{let d=(0,n.int)(n.workgroupId.x).mul(8).add((0,n.int)(n.localId.x)),f=(0,n.int)(n.workgroupId.y).mul(8).add((0,n.int)(n.localId.y));(0,n.If)(d.lessThan((0,n.int)(l)).and(f.lessThan((0,n.int)(u))),()=>{let p=(0,n.ivec2)(d,f),m=(0,n.vec4)(0,0,0,1).toVar();(0,n.If)(c.equal((0,n.int)(0)),()=>{let e=(0,n.textureLoad)(t,p).xyz;m.assign((0,n.vec4)(e,1))}).ElseIf(c.equal((0,n.int)(1)),()=>{let t=(0,n.float)(0).toVar(),r=(0,n.float)(0).toVar();for(let i=-1;i<=1;i++)for(let a=-1;a<=1;a++){let o=(0,n.textureLoad)(e,(0,n.ivec2)(d.add(a).clamp((0,n.int)(0),(0,n.int)(l).sub(1)),f.add(i).clamp((0,n.int)(0),(0,n.int)(u).sub(1)))).xyz,s=(0,n.dot)(o,(0,n.vec3)(.2126,.7152,.0722));t.addAssign(s),r.addAssign(s.mul(s))}t.divAssign(9),r.divAssign(9);let i=(0,n.max)(r.sub(t.mul(t)),(0,n.float)(0)).div((0,n.max)(t.mul(t),(0,n.float)(1e-4))).mul(10).clamp(0,1),a=i.sub(.5).mul(4).clamp(0,1),o=i.mul(4).clamp(0,1).sub(i.sub(.75).mul(4).clamp(0,1)),s=(0,n.float)(1).sub(i.sub(.25).mul(4).clamp(0,1));m.assign((0,n.vec4)(a,o,s,1))}).ElseIf(c.equal((0,n.int)(2)),()=>{let e=(0,n.textureLoad)(r,p).w.div(32).clamp(0,1);m.assign((0,n.vec4)((0,n.float)(1).sub(e),e,(0,n.float)(.2),1))}).ElseIf(c.equal((0,n.int)(3)),()=>{let e=(0,n.textureLoad)(a,p),t=(0,n.abs)(e.x).mul(100).clamp(0,1),r=(0,n.abs)(e.y).mul(100).clamp(0,1),i=t.add(r).clamp(0,1);m.assign((0,n.vec4)(t,r,i.mul(.3),1))}).ElseIf(c.equal((0,n.int)(4)),()=>{let e=(0,n.textureLoad)(i,p);m.assign((0,n.vec4)(e.xyz,1))}).Else(()=>{let e=(0,n.textureLoad)(o,p).x.mul(5).clamp(0,1);m.assign((0,n.vec4)(e,e.mul(.5),(0,n.float)(1).sub(e),1))}),(0,n.textureStore)(s,(0,n.uvec2)((0,n.uint)(d),(0,n.uint)(f)),m).toWriteOnly()})})().compute([this._dispatchX,this._dispatchY,1],[8,8,1])}setupEventListeners(){this.on(`asvgf:reset`,()=>this.resetTemporalData()),this.on(`asvgf:setTemporal`,e=>{e&&e.enabled!==void 0&&(this.temporalEnabled=e.enabled,this.temporalEnabledU.value=+!!e.enabled)}),this.on(`asvgf:updateParameters`,e=>{e&&(e.temporalAlpha!==void 0&&(this.temporalAlpha.value=e.temporalAlpha),e.phiColor!==void 0&&(this.phiColor.value=e.phiColor))})}render(e){if(!this.enabled)return;let t=e.getTexture(`pathtracer:color`),n=e.getTexture(`pathtracer:normalDepth`),r=e.getTexture(`motionVector:screenSpace`);if(!t)return;let i=t.image;i&&i.width>0&&i.height>0&&(i.width!==this._temporalTexA.image.width||i.height!==this._temporalTexA.image.height)&&this.setSize(i.width,i.height),this._colorTexNode.value=t,r&&(this._motionTexNode.value=r),this._compiled||=(this.renderer.compute(this._gradientNode),this.renderer.compute(this._temporalNodeA),this.renderer.compute(this._temporalNodeB),!0);let a=this.currentMoments===0?this._temporalTexB:this._temporalTexA,o=this.currentMoments===0?this._temporalNodeA:this._temporalNodeB,s=this.currentMoments===0?this._temporalTexA:this._temporalTexB;this._readTemporalTexNode.value=a,this.renderer.compute(o),e.setTexture(`asvgf:output`,s),e.setTexture(`asvgf:temporalColor`,s),this.currentMoments=1-this.currentMoments,this.showHeatmap&&(this.renderer.compute(this._gradientNode),this._heatmapRawColorTexNode.value=t,this._heatmapColorTexNode.value=s,this._heatmapTemporalTexNode.value=s,n&&(this._heatmapNDTexNode.value=n),r&&(this._heatmapMotionTexNode.value=r),this._heatmapGradientTexNode.value=this._gradientStorageTex,this.renderer.compute(this._heatmapComputeNode),this.renderer.copyTextureToTexture(this._heatmapStorageTex,this.heatmapTarget.texture)),this.frameCount++}setHeatmapEnabled(e){this.showHeatmap=e}setTemporalEnabled(e){this.temporalEnabled=e}updateParameters(e){e&&(e.temporalAlpha!==void 0&&(this.temporalAlpha.value=e.temporalAlpha),e.phiColor!==void 0&&(this.phiColor.value=e.phiColor),e.debugMode!==void 0&&(this.debugMode.value=e.debugMode))}resetTemporalData(){this.frameCount=0,this.currentMoments=0}setSize(e,t){this._temporalTexA.setSize(e,t),this._temporalTexB.setSize(e,t),this._gradientStorageTex.setSize(e,t),this._heatmapStorageTex.setSize(e,t),this.heatmapTarget.setSize(e,t),this.heatmapTarget.texture.needsUpdate=!0,this.resW.value=e,this.resH.value=t,this._dispatchX=Math.ceil(e/8),this._dispatchY=Math.ceil(t/8),this._gradientNode.dispatchSize=[this._dispatchX,this._dispatchY,1],this._temporalNodeA.dispatchSize=[this._dispatchX,this._dispatchY,1],this._temporalNodeB.dispatchSize=[this._dispatchX,this._dispatchY,1],this._heatmapComputeNode.dispatchSize=[this._dispatchX,this._dispatchY,1]}reset(){}dispose(){this._gradientNode?.dispose(),this._temporalNodeA?.dispose(),this._temporalNodeB?.dispose(),this._temporalTexA?.dispose(),this._temporalTexB?.dispose(),this._gradientStorageTex?.dispose(),this._heatmapComputeNode?.dispose(),this._heatmapStorageTex?.dispose(),this.heatmapTarget?.dispose(),this._colorTexNode?.dispose(),this._motionTexNode?.dispose(),this._readTemporalTexNode?.dispose(),this._heatmapRawColorTexNode?.dispose(),this._heatmapColorTexNode?.dispose(),this._heatmapTemporalTexNode?.dispose(),this._heatmapNDTexNode?.dispose(),this._heatmapMotionTexNode?.dispose(),this._heatmapGradientTexNode?.dispose()}},Ua=(0,n.wgslFn)(`
532
508
  fn temporalAccumulate(
533
509
  lum: f32,
534
510
  prevMean: f32,
@@ -550,7 +526,7 @@
550
526
  );
551
527
 
552
528
  }
553
- `),oo=class extends I{constructor(e,i={}){super(`VarianceEstimation`,{...i,executionMode:F.ALWAYS}),this.renderer=e,this.inputTextureName=i.inputTextureName||`pathtracer:color`,this.varianceBoost=(0,n.uniform)(i.varianceBoost??1),this.temporalAlpha=(0,n.uniform)(i.temporalAlpha??.1),this.resW=(0,n.uniform)(i.width||1),this.resH=(0,n.uniform)(i.height||1),this._colorTexNode=new t.TextureNode;let a=i.width||1,o=i.height||1;this._storageTexA=new t.StorageTexture(a,o),this._storageTexA.type=r.FloatType,this._storageTexA.format=r.RGBAFormat,this._storageTexA.minFilter=r.LinearFilter,this._storageTexA.magFilter=r.LinearFilter,this._storageTexB=new t.StorageTexture(a,o),this._storageTexB.type=r.FloatType,this._storageTexB.format=r.RGBAFormat,this._storageTexB.minFilter=r.LinearFilter,this._storageTexB.magFilter=r.LinearFilter,this.currentMoments=0,this._compiled=!1,this._needsWarmReset=!1,this._dispatchX=Math.ceil(a/8),this._dispatchY=Math.ceil(o/8),this._buildCompute()}setupEventListeners(){this.on(`pathtracer:viewpointChanged`,()=>this.reset())}_buildCompute(){this._readTexNodeA=new t.TextureNode,this._readTexNodeB=new t.TextureNode,this._computeNodeA=this._buildComputeForDirection(this._storageTexA,this._readTexNodeB),this._computeNodeB=this._buildComputeForDirection(this._storageTexB,this._readTexNodeA)}_buildComputeForDirection(e,t){let r=this._colorTexNode,i=this.temporalAlpha,a=this.varianceBoost,o=this.resW,s=this.resH,c=(0,n.workgroupArray)(`float`,100);return(0,n.Fn)(()=>{let l=n.localId.x,u=n.localId.y,d=u.mul(8).add(l),f=(0,n.int)(n.workgroupId.x).mul(8).sub(1),p=(0,n.int)(n.workgroupId.y).mul(8).sub(1),m=d.mod(10),h=d.div(10),g=(0,n.textureLoad)(r,(0,n.ivec2)(f.add((0,n.int)(m)).clamp((0,n.int)(0),(0,n.int)(o).sub(1)),p.add((0,n.int)(h)).clamp((0,n.int)(0),(0,n.int)(s).sub(1)))).xyz;c.element(d).assign(Qt(g)),(0,n.If)(d.lessThan((0,n.uint)(36)),()=>{let e=d.add((0,n.uint)(64)),t=e.mod(10),i=e.div(10),a=(0,n.textureLoad)(r,(0,n.ivec2)(f.add((0,n.int)(t)).clamp((0,n.int)(0),(0,n.int)(o).sub(1)),p.add((0,n.int)(i)).clamp((0,n.int)(0),(0,n.int)(s).sub(1)))).xyz;c.element(e).assign(Qt(a))}),(0,n.workgroupBarrier)();let _=(0,n.int)(n.workgroupId.x).mul(8).add((0,n.int)(l)),v=(0,n.int)(n.workgroupId.y).mul(8).add((0,n.int)(u));(0,n.If)(_.lessThan((0,n.int)(o)).and(v.lessThan((0,n.int)(s))),()=>{let r=(0,n.float)(0).toVar(),o=(0,n.float)(0).toVar();for(let e=-1;e<=1;e++)for(let t=-1;t<=1;t++){let n=c.element(u.add(1+e).mul(10).add(l.add(1+t)));r.addAssign(n),o.addAssign(n.mul(n))}r.divAssign(9),o.divAssign(9);let s=(0,n.max)(o.sub(r.mul(r)),(0,n.float)(0)),d=c.element(u.add(1).mul(10).add(l.add(1))),f=(0,n.textureLoad)(t,(0,n.ivec2)(_,v));(0,n.textureStore)(e,(0,n.uvec2)((0,n.uint)(_),(0,n.uint)(v)),ao(d,f.x,f.y,i,s,a)).toWriteOnly()})})().compute([this._dispatchX,this._dispatchY,1],[8,8,1])}render(e){if(!this.enabled)return;let t=e.getTexture(this.inputTextureName);if(!t)return;let n=t.image;if(n&&n.width>0&&n.height>0&&(n.width!==this._storageTexA.image.width||n.height!==this._storageTexA.image.height)&&this.setSize(n.width,n.height),this._colorTexNode.value=t,this._compiled||=(this.renderer.compute(this._computeNodeA),this.renderer.compute(this._computeNodeB),!0),this._readTexNodeA.value=this._storageTexA,this._readTexNodeB.value=this._storageTexB,this._needsWarmReset){let e=this.temporalAlpha.value;this.temporalAlpha.value=1,this.renderer.compute(this._computeNodeA),this.renderer.compute(this._computeNodeB),this.temporalAlpha.value=e,this._needsWarmReset=!1}let r=this.currentMoments===0?this._computeNodeA:this._computeNodeB;this.renderer.compute(r);let i=this.currentMoments===0?this._storageTexA:this._storageTexB;this.currentMoments=1-this.currentMoments,e.setTexture(`variance:output`,i)}reset(){this.currentMoments=0,this._needsWarmReset=!0,this.context&&this.context.removeTexture(`variance:output`)}setSize(e,t){this._storageTexA.setSize(e,t),this._storageTexB.setSize(e,t),this.resW.value=e,this.resH.value=t,this._dispatchX=Math.ceil(e/8),this._dispatchY=Math.ceil(t/8),this._computeNodeA.dispatchSize=[this._dispatchX,this._dispatchY,1],this._computeNodeB.dispatchSize=[this._dispatchX,this._dispatchY,1]}dispose(){this._computeNodeA?.dispose(),this._computeNodeB?.dispose(),this._storageTexA?.dispose(),this._storageTexB?.dispose(),this._colorTexNode?.dispose(),this._readTexNodeA?.dispose(),this._readTexNodeB?.dispose()}},so=(0,n.wgslFn)(`
529
+ `),Wa=class extends R{constructor(e,i={}){super(`VarianceEstimation`,{...i,executionMode:L.ALWAYS}),this.renderer=e,this.inputTextureName=i.inputTextureName||`pathtracer:color`,this.varianceBoost=(0,n.uniform)(i.varianceBoost??1),this.temporalAlpha=(0,n.uniform)(i.temporalAlpha??.1),this.resW=(0,n.uniform)(i.width||1),this.resH=(0,n.uniform)(i.height||1),this._colorTexNode=new t.TextureNode;let a=i.width||1,o=i.height||1;this._storageTexA=new t.StorageTexture(a,o),this._storageTexA.type=r.FloatType,this._storageTexA.format=r.RGBAFormat,this._storageTexA.minFilter=r.LinearFilter,this._storageTexA.magFilter=r.LinearFilter,this._storageTexB=new t.StorageTexture(a,o),this._storageTexB.type=r.FloatType,this._storageTexB.format=r.RGBAFormat,this._storageTexB.minFilter=r.LinearFilter,this._storageTexB.magFilter=r.LinearFilter,this.currentMoments=0,this._compiled=!1,this._needsWarmReset=!1,this._dispatchX=Math.ceil(a/8),this._dispatchY=Math.ceil(o/8),this._buildCompute()}setupEventListeners(){this.on(`pathtracer:viewpointChanged`,()=>this.reset())}_buildCompute(){this._readTexNodeA=new t.TextureNode,this._readTexNodeB=new t.TextureNode,this._computeNodeA=this._buildComputeForDirection(this._storageTexA,this._readTexNodeB),this._computeNodeB=this._buildComputeForDirection(this._storageTexB,this._readTexNodeA)}_buildComputeForDirection(e,t){let r=this._colorTexNode,i=this.temporalAlpha,a=this.varianceBoost,o=this.resW,s=this.resH,c=(0,n.workgroupArray)(`float`,100);return(0,n.Fn)(()=>{let l=n.localId.x,u=n.localId.y,d=u.mul(8).add(l),f=(0,n.int)(n.workgroupId.x).mul(8).sub(1),p=(0,n.int)(n.workgroupId.y).mul(8).sub(1),m=d.mod(10),h=d.div(10),g=(0,n.textureLoad)(r,(0,n.ivec2)(f.add((0,n.int)(m)).clamp((0,n.int)(0),(0,n.int)(o).sub(1)),p.add((0,n.int)(h)).clamp((0,n.int)(0),(0,n.int)(s).sub(1)))).xyz;c.element(d).assign(Ht(g)),(0,n.If)(d.lessThan((0,n.uint)(36)),()=>{let e=d.add((0,n.uint)(64)),t=e.mod(10),i=e.div(10),a=(0,n.textureLoad)(r,(0,n.ivec2)(f.add((0,n.int)(t)).clamp((0,n.int)(0),(0,n.int)(o).sub(1)),p.add((0,n.int)(i)).clamp((0,n.int)(0),(0,n.int)(s).sub(1)))).xyz;c.element(e).assign(Ht(a))}),(0,n.workgroupBarrier)();let _=(0,n.int)(n.workgroupId.x).mul(8).add((0,n.int)(l)),v=(0,n.int)(n.workgroupId.y).mul(8).add((0,n.int)(u));(0,n.If)(_.lessThan((0,n.int)(o)).and(v.lessThan((0,n.int)(s))),()=>{let r=(0,n.float)(0).toVar(),o=(0,n.float)(0).toVar();for(let e=-1;e<=1;e++)for(let t=-1;t<=1;t++){let n=c.element(u.add(1+e).mul(10).add(l.add(1+t)));r.addAssign(n),o.addAssign(n.mul(n))}r.divAssign(9),o.divAssign(9);let s=(0,n.max)(o.sub(r.mul(r)),(0,n.float)(0)),d=c.element(u.add(1).mul(10).add(l.add(1))),f=(0,n.textureLoad)(t,(0,n.ivec2)(_,v));(0,n.textureStore)(e,(0,n.uvec2)((0,n.uint)(_),(0,n.uint)(v)),Ua(d,f.x,f.y,i,s,a)).toWriteOnly()})})().compute([this._dispatchX,this._dispatchY,1],[8,8,1])}render(e){if(!this.enabled)return;let t=e.getTexture(this.inputTextureName);if(!t)return;let n=t.image;if(n&&n.width>0&&n.height>0&&(n.width!==this._storageTexA.image.width||n.height!==this._storageTexA.image.height)&&this.setSize(n.width,n.height),this._colorTexNode.value=t,this._compiled||=(this.renderer.compute(this._computeNodeA),this.renderer.compute(this._computeNodeB),!0),this._readTexNodeA.value=this._storageTexA,this._readTexNodeB.value=this._storageTexB,this._needsWarmReset){let e=this.temporalAlpha.value;this.temporalAlpha.value=1,this.renderer.compute(this._computeNodeA),this.renderer.compute(this._computeNodeB),this.temporalAlpha.value=e,this._needsWarmReset=!1}let r=this.currentMoments===0?this._computeNodeA:this._computeNodeB;this.renderer.compute(r);let i=this.currentMoments===0?this._storageTexA:this._storageTexB;this.currentMoments=1-this.currentMoments,e.setTexture(`variance:output`,i)}reset(){this.currentMoments=0,this._needsWarmReset=!0,this.context&&this.context.removeTexture(`variance:output`)}setSize(e,t){this._storageTexA.setSize(e,t),this._storageTexB.setSize(e,t),this.resW.value=e,this.resH.value=t,this._dispatchX=Math.ceil(e/8),this._dispatchY=Math.ceil(t/8),this._computeNodeA.dispatchSize=[this._dispatchX,this._dispatchY,1],this._computeNodeB.dispatchSize=[this._dispatchX,this._dispatchY,1]}dispose(){this._computeNodeA?.dispose(),this._computeNodeB?.dispose(),this._storageTexA?.dispose(),this._storageTexB?.dispose(),this._colorTexNode?.dispose(),this._readTexNodeA?.dispose(),this._readTexNodeB?.dispose()}},Ga=(0,n.wgslFn)(`
554
530
  fn bilateralWeight(
555
531
  centerLum: f32, sLum: f32,
556
532
  centerNormal: vec3f, sNormal: vec3f,
@@ -573,7 +549,7 @@
573
549
  return kernelW * lumW * normW * depW * colW;
574
550
 
575
551
  }
576
- `),co=class extends I{constructor(e,i={}){super(`BilateralFiltering`,{...i,executionMode:F.ALWAYS}),this.renderer=e,this.inputTextureName=i.inputTextureName||`asvgf:output`,this.normalDepthTextureName=i.normalDepthTextureName||`pathtracer:normalDepth`,this.iterations=i.iterations??4,this.phiColor=(0,n.uniform)(i.phiColor??10),this.phiNormal=(0,n.uniform)(i.phiNormal??128),this.phiDepth=(0,n.uniform)(i.phiDepth??1),this.phiLuminance=(0,n.uniform)(i.phiLuminance??4),this.stepSizeU=(0,n.uniform)(1,`int`),this.resW=(0,n.uniform)(i.width||1),this.resH=(0,n.uniform)(i.height||1),this._readTexNode=new t.TextureNode,this._normalDepthTexNode=new t.TextureNode;let a=i.width||1,o=i.height||1;this._storageTexA=new t.StorageTexture(a,o),this._storageTexA.type=r.HalfFloatType,this._storageTexA.format=r.RGBAFormat,this._storageTexA.minFilter=r.LinearFilter,this._storageTexA.magFilter=r.LinearFilter,this._storageTexB=new t.StorageTexture(a,o),this._storageTexB.type=r.HalfFloatType,this._storageTexB.format=r.RGBAFormat,this._storageTexB.minFilter=r.LinearFilter,this._storageTexB.magFilter=r.LinearFilter,this._compiled=!1,this._dispatchX=Math.ceil(a/8),this._dispatchY=Math.ceil(o/8),this._buildCompute()}_buildCompute(){this._computeNodeA=this._buildComputeForDirection(this._storageTexA),this._computeNodeB=this._buildComputeForDirection(this._storageTexB)}_buildComputeForDirection(e){let t=this._readTexNode,r=this._normalDepthTexNode,i=this.phiColor,a=this.phiNormal,o=this.phiDepth,s=this.phiLuminance,c=this.stepSizeU,l=this.resW,u=this.resH,d=[1/256,4/256,6/256,4/256,1/256,4/256,16/256,24/256,16/256,4/256,6/256,24/256,36/256,24/256,6/256,4/256,16/256,24/256,16/256,4/256,1/256,4/256,6/256,4/256,1/256];return(0,n.Fn)(()=>{let f=(0,n.int)(n.workgroupId.x).mul(8).add((0,n.int)(n.localId.x)),p=(0,n.int)(n.workgroupId.y).mul(8).add((0,n.int)(n.localId.y));(0,n.If)(f.lessThan((0,n.int)(l)).and(p.lessThan((0,n.int)(u))),()=>{let m=(0,n.ivec2)(f,p),h=(0,n.textureLoad)(t,m).xyz,g=(0,n.textureLoad)(r,m),_=g.xyz.mul(2).sub(1),v=g.w,y=Qt(h),b=(0,n.vec3)(0).toVar(),x=(0,n.float)(0).toVar();for(let e=0;e<5;e++)for(let m=0;m<5;m++){let g=m-2,S=e-2,C=d[e*5+m],w=f.add(c.mul(g)).clamp((0,n.int)(0),(0,n.int)(l).sub(1)),T=p.add(c.mul(S)).clamp((0,n.int)(0),(0,n.int)(u).sub(1)),E=(0,n.textureLoad)(t,(0,n.ivec2)(w,T)).xyz,D=(0,n.textureLoad)(r,(0,n.ivec2)(w,T)),O=D.xyz.mul(2).sub(1),k=D.w,A=so(y,Qt(E),_,O,v,k,h,E,(0,n.float)(C),s,a,o,i);b.addAssign(E.mul(A)),x.addAssign(A)}let S=b.div((0,n.max)(x,(0,n.float)(1e-4)));(0,n.textureStore)(e,(0,n.uvec2)((0,n.uint)(f),(0,n.uint)(p)),(0,n.vec4)(S,1)).toWriteOnly()})})().compute([this._dispatchX,this._dispatchY,1],[8,8,1])}render(e){if(!this.enabled)return;let t=e.getTexture(this.inputTextureName)||e.getTexture(`pathtracer:color`),n=e.getTexture(this.normalDepthTextureName);if(!t)return;let r=t.image;r&&r.width>0&&r.height>0&&(r.width!==this._storageTexA.image.width||r.height!==this._storageTexA.image.height)&&this.setSize(r.width,r.height),n&&(this._normalDepthTexNode.value=n),this._compiled||=(this.renderer.compute(this._computeNodeA),this.renderer.compute(this._computeNodeB),!0);let i=t,a=this._computeNodeA,o=this._computeNodeB;for(let e=0;e<this.iterations;e++){this.stepSizeU.value=1<<e,this._readTexNode.value=i,this.renderer.compute(a),i=a===this._computeNodeA?this._storageTexA:this._storageTexB;let t=a;a=o,o=t}e.setTexture(`bilateralFiltering:output`,i)}setSize(e,t){this._storageTexA.setSize(e,t),this._storageTexB.setSize(e,t),this.resW.value=e,this.resH.value=t,this._dispatchX=Math.ceil(e/8),this._dispatchY=Math.ceil(t/8),this._computeNodeA.dispatchSize=[this._dispatchX,this._dispatchY,1],this._computeNodeB.dispatchSize=[this._dispatchX,this._dispatchY,1]}reset(){}dispose(){this._computeNodeA?.dispose(),this._computeNodeB?.dispose(),this._storageTexA?.dispose(),this._storageTexB?.dispose(),this._readTexNode?.dispose(),this._normalDepthTexNode?.dispose()}},lo=(0,n.wgslFn)(`
552
+ `),Ka=class extends R{constructor(e,i={}){super(`BilateralFiltering`,{...i,executionMode:L.ALWAYS}),this.renderer=e,this.inputTextureName=i.inputTextureName||`asvgf:output`,this.normalDepthTextureName=i.normalDepthTextureName||`pathtracer:normalDepth`,this.iterations=i.iterations??4,this.phiColor=(0,n.uniform)(i.phiColor??10),this.phiNormal=(0,n.uniform)(i.phiNormal??128),this.phiDepth=(0,n.uniform)(i.phiDepth??1),this.phiLuminance=(0,n.uniform)(i.phiLuminance??4),this.stepSizeU=(0,n.uniform)(1,`int`),this.resW=(0,n.uniform)(i.width||1),this.resH=(0,n.uniform)(i.height||1),this._readTexNode=new t.TextureNode,this._normalDepthTexNode=new t.TextureNode;let a=i.width||1,o=i.height||1;this._storageTexA=new t.StorageTexture(a,o),this._storageTexA.type=r.HalfFloatType,this._storageTexA.format=r.RGBAFormat,this._storageTexA.minFilter=r.LinearFilter,this._storageTexA.magFilter=r.LinearFilter,this._storageTexB=new t.StorageTexture(a,o),this._storageTexB.type=r.HalfFloatType,this._storageTexB.format=r.RGBAFormat,this._storageTexB.minFilter=r.LinearFilter,this._storageTexB.magFilter=r.LinearFilter,this._compiled=!1,this._dispatchX=Math.ceil(a/8),this._dispatchY=Math.ceil(o/8),this._buildCompute()}_buildCompute(){this._computeNodeA=this._buildComputeForDirection(this._storageTexA),this._computeNodeB=this._buildComputeForDirection(this._storageTexB)}_buildComputeForDirection(e){let t=this._readTexNode,r=this._normalDepthTexNode,i=this.phiColor,a=this.phiNormal,o=this.phiDepth,s=this.phiLuminance,c=this.stepSizeU,l=this.resW,u=this.resH,d=[1/256,4/256,6/256,4/256,1/256,4/256,16/256,24/256,16/256,4/256,6/256,24/256,36/256,24/256,6/256,4/256,16/256,24/256,16/256,4/256,1/256,4/256,6/256,4/256,1/256];return(0,n.Fn)(()=>{let f=(0,n.int)(n.workgroupId.x).mul(8).add((0,n.int)(n.localId.x)),p=(0,n.int)(n.workgroupId.y).mul(8).add((0,n.int)(n.localId.y));(0,n.If)(f.lessThan((0,n.int)(l)).and(p.lessThan((0,n.int)(u))),()=>{let m=(0,n.ivec2)(f,p),h=(0,n.textureLoad)(t,m).xyz,g=(0,n.textureLoad)(r,m),_=g.xyz.mul(2).sub(1),v=g.w,y=Ht(h),b=(0,n.vec3)(0).toVar(),x=(0,n.float)(0).toVar();for(let e=0;e<5;e++)for(let m=0;m<5;m++){let g=m-2,S=e-2,C=d[e*5+m],w=f.add(c.mul(g)).clamp((0,n.int)(0),(0,n.int)(l).sub(1)),T=p.add(c.mul(S)).clamp((0,n.int)(0),(0,n.int)(u).sub(1)),E=(0,n.textureLoad)(t,(0,n.ivec2)(w,T)).xyz,D=(0,n.textureLoad)(r,(0,n.ivec2)(w,T)),O=D.xyz.mul(2).sub(1),k=D.w,A=Ga(y,Ht(E),_,O,v,k,h,E,(0,n.float)(C),s,a,o,i);b.addAssign(E.mul(A)),x.addAssign(A)}let S=b.div((0,n.max)(x,(0,n.float)(1e-4)));(0,n.textureStore)(e,(0,n.uvec2)((0,n.uint)(f),(0,n.uint)(p)),(0,n.vec4)(S,1)).toWriteOnly()})})().compute([this._dispatchX,this._dispatchY,1],[8,8,1])}render(e){if(!this.enabled)return;let t=e.getTexture(this.inputTextureName)||e.getTexture(`pathtracer:color`),n=e.getTexture(this.normalDepthTextureName);if(!t)return;let r=t.image;r&&r.width>0&&r.height>0&&(r.width!==this._storageTexA.image.width||r.height!==this._storageTexA.image.height)&&this.setSize(r.width,r.height),n&&(this._normalDepthTexNode.value=n),this._compiled||=(this.renderer.compute(this._computeNodeA),this.renderer.compute(this._computeNodeB),!0);let i=t,a=this._computeNodeA,o=this._computeNodeB;for(let e=0;e<this.iterations;e++){this.stepSizeU.value=1<<e,this._readTexNode.value=i,this.renderer.compute(a),i=a===this._computeNodeA?this._storageTexA:this._storageTexB;let t=a;a=o,o=t}e.setTexture(`bilateralFiltering:output`,i)}setSize(e,t){this._storageTexA.setSize(e,t),this._storageTexB.setSize(e,t),this.resW.value=e,this.resH.value=t,this._dispatchX=Math.ceil(e/8),this._dispatchY=Math.ceil(t/8),this._computeNodeA.dispatchSize=[this._dispatchX,this._dispatchY,1],this._computeNodeB.dispatchSize=[this._dispatchX,this._dispatchY,1]}reset(){}dispose(){this._computeNodeA?.dispose(),this._computeNodeB?.dispose(),this._storageTexA?.dispose(),this._storageTexB?.dispose(),this._readTexNode?.dispose(),this._normalDepthTexNode?.dispose()}},qa=(0,n.wgslFn)(`
577
553
  fn computeSamplingGuidance(
578
554
  temporalVariance: f32,
579
555
  spatialVariance: f32,
@@ -635,7 +611,7 @@
635
611
  );
636
612
 
637
613
  }
638
- `),uo=(0,n.wgslFn)(`
614
+ `),Ja=(0,n.wgslFn)(`
639
615
  fn heatmapGradient( t: f32, normalizedVariance: f32, converged: f32 ) -> vec4f {
640
616
 
641
617
  let r = clamp( ( t - 0.5 ) * 4.0, 0.0, 1.0 );
@@ -658,7 +634,7 @@
658
634
  return vec4f( color, 1.0 );
659
635
 
660
636
  }
661
- `),fo=class extends I{constructor(e,i={}){super(`AdaptiveSampling`,{...i,executionMode:F.PER_CYCLE}),this.renderer=e,this.debugContainer=i.debugContainer||null,this.frameNumber=0,this.delayByFrames=i.delayByFrames??2,this.showAdaptiveSamplingHelper=!1,this.adaptiveSamplingMax=(0,n.uniform)(i.adaptiveSamplingMax??z.adaptiveSamplingMax??32,`int`),this.varianceThreshold=(0,n.uniform)(i.varianceThreshold??z.adaptiveSamplingVarianceThreshold??.01),this.materialBias=(0,n.uniform)(i.materialBias??z.adaptiveSamplingMaterialBias??1.2),this.edgeBias=(0,n.uniform)(i.edgeBias??z.adaptiveSamplingEdgeBias??1.5),this.convergenceSpeed=(0,n.uniform)(i.convergenceSpeed??z.adaptiveSamplingConvergenceSpeed??2),this.frameNumberUniform=(0,n.uniform)(0,`int`),this.resolutionWidth=(0,n.uniform)(i.width||1024),this.resolutionHeight=(0,n.uniform)(i.height||1024),this.minConvergenceFrames=(0,n.uniform)(10),this.convergenceThreshold=(0,n.uniform)(.01);let a=i.width||1,o=i.height||1;this._outputStorageTex=new t.StorageTexture(a,o),this._outputStorageTex.type=r.HalfFloatType,this._outputStorageTex.format=r.RGBAFormat,this._outputStorageTex.minFilter=r.LinearFilter,this._outputStorageTex.magFilter=r.LinearFilter,this._heatmapStorageTex=new t.StorageTexture(a,o),this._heatmapStorageTex.type=r.FloatType,this._heatmapStorageTex.format=r.RGBAFormat,this._heatmapStorageTex.minFilter=r.NearestFilter,this._heatmapStorageTex.magFilter=r.NearestFilter,this.heatmapTarget=new t.RenderTarget(a,o,{format:r.RGBAFormat,type:r.FloatType,minFilter:r.NearestFilter,magFilter:r.NearestFilter,depthBuffer:!1,stencilBuffer:!1}),this._dispatchX=Math.ceil(a/16),this._dispatchY=Math.ceil(o/16),this._varianceTexNode=new t.TextureNode,this._buildCompute(),this._buildHeatmapCompute(),this.helper=ro(this.renderer,this.heatmapTarget,{width:400,height:400,position:`bottom-right`,theme:`dark`,title:`Adaptive Sampling`,autoUpdate:!1}),this.helper.hide(),(this.debugContainer||document.body).appendChild(this.helper)}setupEventListeners(){this.on(`pathtracer:viewpointChanged`,()=>this.reset())}_buildCompute(){let e=this._varianceTexNode,t=this.varianceThreshold,r=this.materialBias,i=this.convergenceSpeed,a=this.frameNumberUniform,o=this.minConvergenceFrames,s=this.convergenceThreshold,c=this.resolutionWidth,l=this.resolutionHeight,u=this._outputStorageTex;this._computeNode=(0,n.Fn)(()=>{let d=(0,n.int)(n.workgroupId.x).mul(16).add((0,n.int)(n.localId.x)),f=(0,n.int)(n.workgroupId.y).mul(16).add((0,n.int)(n.localId.y));(0,n.If)(d.lessThan((0,n.int)(c)).and(f.lessThan((0,n.int)(l))),()=>{let c=(0,n.textureLoad)(e,(0,n.ivec2)(d,f)),l=lo(c.z,c.w,c.x,t,(0,n.int)(a),(0,n.int)(o),s,r,i);(0,n.textureStore)(u,(0,n.uvec2)((0,n.uint)(d),(0,n.uint)(f)),l).toWriteOnly()})})().compute([this._dispatchX,this._dispatchY,1],[16,16,1])}_buildHeatmapCompute(){let e=this._outputStorageTex,t=this._heatmapStorageTex,r=this.resolutionWidth,i=this.resolutionHeight;this._heatmapComputeNode=(0,n.Fn)(()=>{let a=(0,n.int)(n.workgroupId.x).mul(16).add((0,n.int)(n.localId.x)),o=(0,n.int)(n.workgroupId.y).mul(16).add((0,n.int)(n.localId.y));(0,n.If)(a.lessThan((0,n.int)(r)).and(o.lessThan((0,n.int)(i))),()=>{let r=(0,n.textureLoad)(e,(0,n.ivec2)(a,o)),i=uo(r.x.clamp(0,1),r.y,r.z);(0,n.textureStore)(t,(0,n.uvec2)((0,n.uint)(a),(0,n.uint)(o)),i).toWriteOnly()})})().compute([this._dispatchX,this._dispatchY,1],[16,16,1])}toggleHelper(e){this.showAdaptiveSamplingHelper=e,e?this.helper.show():this.helper.hide()}render(e){if(!this.enabled||(this.frameNumber++,this.frameNumber<=this.delayByFrames))return;this.frameNumberUniform.value=this.frameNumber;let t=e.getTexture(`variance:output`);if(!t)return;let n=t.image;n&&n.width>0&&n.height>0&&(n.width!==this._outputStorageTex.image.width||n.height!==this._outputStorageTex.image.height)&&this.setSize(n.width,n.height),this._varianceTexNode.value=t,this.renderer.compute(this._computeNode),e.setTexture(`adaptiveSampling:output`,this._outputStorageTex),this.showAdaptiveSamplingHelper&&(this.renderer.compute(this._heatmapComputeNode),this.renderer.copyTextureToTexture(this._heatmapStorageTex,this.heatmapTarget.texture),this.helper.update())}reset(){this.frameNumber=0,this.frameNumberUniform.value=0,this.context&&this.context.removeTexture(`adaptiveSampling:output`)}setSize(e,t){this._outputStorageTex.setSize(e,t),this._heatmapStorageTex.setSize(e,t),this.heatmapTarget.setSize(e,t),this.heatmapTarget.texture.needsUpdate=!0,this.resolutionWidth.value=e,this.resolutionHeight.value=t,this._dispatchX=Math.ceil(e/16),this._dispatchY=Math.ceil(t/16),this._computeNode.dispatchSize=[this._dispatchX,this._dispatchY,1],this._heatmapComputeNode.dispatchSize=[this._dispatchX,this._dispatchY,1]}setAdaptiveSamplingMax(e){this.adaptiveSamplingMax.value=e}setVarianceThreshold(e){this.varianceThreshold.value=e}setMaterialBias(e){this.materialBias.value=e}setEdgeBias(e){this.edgeBias.value=e}setConvergenceSpeed(e){this.convergenceSpeed.value=e}setAdaptiveSamplingParameters(e){e.threshold!==void 0&&this.setVarianceThreshold(e.threshold),e.materialBias!==void 0&&this.setMaterialBias(e.materialBias),e.edgeBias!==void 0&&this.setEdgeBias(e.edgeBias),e.convergenceSpeedUp!==void 0&&this.setConvergenceSpeed(e.convergenceSpeedUp),e.adaptiveSamplingMax!==void 0&&this.setAdaptiveSamplingMax(e.adaptiveSamplingMax)}dispose(){this._computeNode?.dispose(),this._heatmapComputeNode?.dispose(),this._heatmapStorageTex?.dispose(),this._outputStorageTex?.dispose(),this.heatmapTarget?.dispose(),this._varianceTexNode?.dispose(),this.helper?.dispose(),this._computeNode=null,this._heatmapComputeNode=null,this._heatmapStorageTex=null,this._outputStorageTex=null,this.heatmapTarget=null,this._varianceTexNode=null,this.helper=null}},po=class extends I{constructor(e,i={}){super(`EdgeAwareFiltering`,{...i,executionMode:F.PER_CYCLE}),this.renderer=e,this.filterStrength=(0,n.uniform)(i.filterStrength??.75),this.strengthDecaySpeed=(0,n.uniform)(i.strengthDecaySpeed??.05),this.edgeThreshold=(0,n.uniform)(i.edgeThreshold??1),this.phiNormal=(0,n.uniform)(i.phiNormal??128),this.phiDepth=(0,n.uniform)(i.phiDepth??1),this.iterationCount=(0,n.uniform)(0),this.resW=(0,n.uniform)(i.width||1),this.resH=(0,n.uniform)(i.height||1),this._iterations=0,this._inputTexNode=new t.TextureNode,this._ndTexNode=new t.TextureNode;let a=2048,o=i.width||1,s=i.height||1;this._outputStorageTex=new t.StorageTexture(a,a),this._outputStorageTex.type=r.HalfFloatType,this._outputStorageTex.format=r.RGBAFormat,this._outputStorageTex.minFilter=r.NearestFilter,this._outputStorageTex.magFilter=r.NearestFilter,this._srcRegion=new r.Box2(new r.Vector2(0,0),new r.Vector2(0,0)),this.outputTarget=new t.RenderTarget(o,s,{type:r.HalfFloatType,format:r.RGBAFormat,minFilter:r.NearestFilter,magFilter:r.NearestFilter,depthBuffer:!1,stencilBuffer:!1}),this._dispatchX=Math.ceil(o/16),this._dispatchY=Math.ceil(s/16),this._buildCompute()}_buildCompute(){let e=this._inputTexNode,t=this._ndTexNode,r=this._outputStorageTex,i=this.filterStrength,a=this.strengthDecaySpeed,o=this.edgeThreshold,s=this.phiNormal,c=this.phiDepth,l=this.iterationCount,u=this.resW,d=this.resH;this._computeNode=(0,n.Fn)(()=>{let f=(0,n.int)(n.workgroupId.x).mul(16).add((0,n.int)(n.localId.x)),p=(0,n.int)(n.workgroupId.y).mul(16).add((0,n.int)(n.localId.y));(0,n.If)(f.lessThan((0,n.int)(u)).and(p.lessThan((0,n.int)(d))),()=>{let m=(0,n.ivec2)(f,p),h=(0,n.textureLoad)(e,m).xyz,g=(0,n.dot)(h,qt),_=1e5,v=(0,n.textureLoad)(t,m),y=v.xyz.mul(2).sub(1),b=v.w,x=(0,n.step)((0,n.float)(_),b).oneMinus(),S=i.sub(l.mul(a)).clamp(0,1),C=h.toVar(),w=(0,n.float)(1).toVar();for(let[r,i]of[[1,0],[0,1],[-1,0],[0,-1],[1,1],[-1,1],[-1,-1],[1,-1]])for(let a of[1,2]){let l=(0,n.ivec2)(f.add(r*a).clamp((0,n.int)(0),(0,n.int)(u).sub(1)),p.add(i*a).clamp((0,n.int)(0),(0,n.int)(d).sub(1))),m=(0,n.textureLoad)(e,l).xyz,h=(0,n.dot)(m,qt),v=(0,n.textureLoad)(t,l),S=v.xyz.mul(2).sub(1),T=v.w,E=(0,n.step)((0,n.float)(_),T).oneMinus(),D=(0,n.abs)(g.sub(h)).div((0,n.max)(o,(0,n.float)(.001))).negate().exp(),O=x.mul(E),k=x.oneMinus().mul(E.oneMinus()),A=O.add(k),j=(0,n.pow)((0,n.dot)(y,S).clamp(0,1),s),M=(0,n.abs)(b.sub(T)).div((0,n.max)(c,(0,n.float)(.001))).negate().exp(),N=(0,n.mix)((0,n.float)(1),j.mul(M),O),ee=(0,n.float)(1).div((0,n.float)(a).add(.5)),te=D.mul(N).mul(A).mul(ee);C.addAssign(m.mul(te)),w.addAssign(te)}let T=(0,n.mix)(h,C.div((0,n.max)(w,(0,n.float)(1e-4))),S),E=(0,n.dot)(T,qt),D=T.toVar();(0,n.If)(E.greaterThan(10),()=>{D.assign(T.mul((0,n.float)(10).div(E)))}),(0,n.textureStore)(r,(0,n.uvec2)((0,n.uint)(f),(0,n.uint)(p)),(0,n.vec4)(D,1)).toWriteOnly()})})().compute([this._dispatchX,this._dispatchY,1],[16,16,1])}render(e){if(!this.enabled)return;let t=e.getTexture(`asvgf:output`)||e.getTexture(`bilateralFiltering:output`)||e.getTexture(`pathtracer:color`),n=e.getTexture(`pathtracer:normalDepth`);if(!t||!n){t&&e.setTexture(`edgeFiltering:output`,t);return}if(e.getState(`interactionMode`)){e.setTexture(`edgeFiltering:output`,t);return}let r=t.image;r&&r.width>0&&r.height>0&&(r.width!==this.outputTarget.width||r.height!==this.outputTarget.height)&&this.setSize(r.width,r.height),this._inputTexNode.value=t,this._ndTexNode.value=n,this._iterations++,this.iterationCount.value=this._iterations,this.renderer.compute(this._computeNode),this._srcRegion.min.set(0,0),this._srcRegion.max.set(this.outputTarget.width,this.outputTarget.height),this.renderer.copyTextureToTexture(this._outputStorageTex,this.outputTarget.texture,this._srcRegion),e.setTexture(`edgeFiltering:output`,this.outputTarget.texture)}setFilteringEnabled(e){this.enabled=e}updateUniforms(e){e&&(e.filterStrength!==void 0&&(this.filterStrength.value=e.filterStrength),e.strengthDecaySpeed!==void 0&&(this.strengthDecaySpeed.value=e.strengthDecaySpeed),e.edgeThreshold!==void 0&&(this.edgeThreshold.value=e.edgeThreshold),e.phiNormal!==void 0&&(this.phiNormal.value=e.phiNormal),e.phiDepth!==void 0&&(this.phiDepth.value=e.phiDepth))}reset(){this._iterations=0,this.iterationCount.value=0}setSize(e,t){this.outputTarget.setSize(e,t),this.outputTarget.texture.needsUpdate=!0,this.resW.value=e,this.resH.value=t,this._dispatchX=Math.ceil(e/16),this._dispatchY=Math.ceil(t/16),this._computeNode.dispatchSize=[this._dispatchX,this._dispatchY,1]}dispose(){this._computeNode?.dispose(),this._outputStorageTex?.dispose(),this.outputTarget?.dispose(),this._inputTexNode?.dispose(),this._ndTexNode?.dispose()}},mo=256,ho=-8,go=6-ho,_o=go/mo,vo=1e4,yo=(0,n.wgslFn)(`
637
+ `),Ya=class extends R{constructor(e,i={}){super(`AdaptiveSampling`,{...i,executionMode:L.PER_CYCLE}),this.renderer=e,this.frameNumber=0,this.delayByFrames=i.delayByFrames??2,this.showAdaptiveSamplingHelper=!1,this.adaptiveSamplingMax=(0,n.uniform)(i.adaptiveSamplingMax??V.adaptiveSamplingMax??32,`int`),this.varianceThreshold=(0,n.uniform)(i.varianceThreshold??V.adaptiveSamplingVarianceThreshold??.01),this.materialBias=(0,n.uniform)(i.materialBias??V.adaptiveSamplingMaterialBias??1.2),this.edgeBias=(0,n.uniform)(i.edgeBias??V.adaptiveSamplingEdgeBias??1.5),this.convergenceSpeed=(0,n.uniform)(i.convergenceSpeed??V.adaptiveSamplingConvergenceSpeed??2),this.frameNumberUniform=(0,n.uniform)(0,`int`),this.resolutionWidth=(0,n.uniform)(i.width||1024),this.resolutionHeight=(0,n.uniform)(i.height||1024),this.minConvergenceFrames=(0,n.uniform)(10),this.convergenceThreshold=(0,n.uniform)(.01);let a=i.width||1,o=i.height||1;this._outputStorageTex=new t.StorageTexture(a,o),this._outputStorageTex.type=r.HalfFloatType,this._outputStorageTex.format=r.RGBAFormat,this._outputStorageTex.minFilter=r.LinearFilter,this._outputStorageTex.magFilter=r.LinearFilter,this._heatmapStorageTex=new t.StorageTexture(a,o),this._heatmapStorageTex.type=r.FloatType,this._heatmapStorageTex.format=r.RGBAFormat,this._heatmapStorageTex.minFilter=r.NearestFilter,this._heatmapStorageTex.magFilter=r.NearestFilter,this.heatmapTarget=new t.RenderTarget(a,o,{format:r.RGBAFormat,type:r.FloatType,minFilter:r.NearestFilter,magFilter:r.NearestFilter,depthBuffer:!1,stencilBuffer:!1}),this._dispatchX=Math.ceil(a/16),this._dispatchY=Math.ceil(o/16),this._varianceTexNode=new t.TextureNode,this._buildCompute(),this._buildHeatmapCompute()}setupEventListeners(){this.on(`pathtracer:viewpointChanged`,()=>this.reset())}_buildCompute(){let e=this._varianceTexNode,t=this.varianceThreshold,r=this.materialBias,i=this.convergenceSpeed,a=this.frameNumberUniform,o=this.minConvergenceFrames,s=this.convergenceThreshold,c=this.resolutionWidth,l=this.resolutionHeight,u=this._outputStorageTex;this._computeNode=(0,n.Fn)(()=>{let d=(0,n.int)(n.workgroupId.x).mul(16).add((0,n.int)(n.localId.x)),f=(0,n.int)(n.workgroupId.y).mul(16).add((0,n.int)(n.localId.y));(0,n.If)(d.lessThan((0,n.int)(c)).and(f.lessThan((0,n.int)(l))),()=>{let c=(0,n.textureLoad)(e,(0,n.ivec2)(d,f)),l=qa(c.z,c.w,c.x,t,(0,n.int)(a),(0,n.int)(o),s,r,i);(0,n.textureStore)(u,(0,n.uvec2)((0,n.uint)(d),(0,n.uint)(f)),l).toWriteOnly()})})().compute([this._dispatchX,this._dispatchY,1],[16,16,1])}_buildHeatmapCompute(){let e=this._outputStorageTex,t=this._heatmapStorageTex,r=this.resolutionWidth,i=this.resolutionHeight;this._heatmapComputeNode=(0,n.Fn)(()=>{let a=(0,n.int)(n.workgroupId.x).mul(16).add((0,n.int)(n.localId.x)),o=(0,n.int)(n.workgroupId.y).mul(16).add((0,n.int)(n.localId.y));(0,n.If)(a.lessThan((0,n.int)(r)).and(o.lessThan((0,n.int)(i))),()=>{let r=(0,n.textureLoad)(e,(0,n.ivec2)(a,o)),i=Ja(r.x.clamp(0,1),r.y,r.z);(0,n.textureStore)(t,(0,n.uvec2)((0,n.uint)(a),(0,n.uint)(o)),i).toWriteOnly()})})().compute([this._dispatchX,this._dispatchY,1],[16,16,1])}setHeatmapEnabled(e){this.showAdaptiveSamplingHelper=e}render(e){if(!this.enabled||(this.frameNumber++,this.frameNumber<=this.delayByFrames))return;this.frameNumberUniform.value=this.frameNumber;let t=e.getTexture(`variance:output`);if(!t)return;let n=t.image;n&&n.width>0&&n.height>0&&(n.width!==this._outputStorageTex.image.width||n.height!==this._outputStorageTex.image.height)&&this.setSize(n.width,n.height),this._varianceTexNode.value=t,this.renderer.compute(this._computeNode),e.setTexture(`adaptiveSampling:output`,this._outputStorageTex),this.showAdaptiveSamplingHelper&&(this.renderer.compute(this._heatmapComputeNode),this.renderer.copyTextureToTexture(this._heatmapStorageTex,this.heatmapTarget.texture))}reset(){this.frameNumber=0,this.frameNumberUniform.value=0,this.context&&this.context.removeTexture(`adaptiveSampling:output`)}setSize(e,t){this._outputStorageTex.setSize(e,t),this._heatmapStorageTex.setSize(e,t),this.heatmapTarget.setSize(e,t),this.heatmapTarget.texture.needsUpdate=!0,this.resolutionWidth.value=e,this.resolutionHeight.value=t,this._dispatchX=Math.ceil(e/16),this._dispatchY=Math.ceil(t/16),this._computeNode.dispatchSize=[this._dispatchX,this._dispatchY,1],this._heatmapComputeNode.dispatchSize=[this._dispatchX,this._dispatchY,1]}setAdaptiveSamplingMax(e){this.adaptiveSamplingMax.value=e}setVarianceThreshold(e){this.varianceThreshold.value=e}setMaterialBias(e){this.materialBias.value=e}setEdgeBias(e){this.edgeBias.value=e}setConvergenceSpeed(e){this.convergenceSpeed.value=e}setAdaptiveSamplingParameters(e){e.threshold!==void 0&&this.setVarianceThreshold(e.threshold),e.materialBias!==void 0&&this.setMaterialBias(e.materialBias),e.edgeBias!==void 0&&this.setEdgeBias(e.edgeBias),e.convergenceSpeedUp!==void 0&&this.setConvergenceSpeed(e.convergenceSpeedUp),e.adaptiveSamplingMax!==void 0&&this.setAdaptiveSamplingMax(e.adaptiveSamplingMax)}dispose(){this._computeNode?.dispose(),this._heatmapComputeNode?.dispose(),this._heatmapStorageTex?.dispose(),this._outputStorageTex?.dispose(),this.heatmapTarget?.dispose(),this._varianceTexNode?.dispose(),this._computeNode=null,this._heatmapComputeNode=null,this._heatmapStorageTex=null,this._outputStorageTex=null,this.heatmapTarget=null,this._varianceTexNode=null}},Xa=class extends R{constructor(e,i={}){super(`EdgeAwareFiltering`,{...i,executionMode:L.PER_CYCLE}),this.renderer=e,this.filterStrength=(0,n.uniform)(i.filterStrength??.75),this.strengthDecaySpeed=(0,n.uniform)(i.strengthDecaySpeed??.05),this.edgeThreshold=(0,n.uniform)(i.edgeThreshold??1),this.phiNormal=(0,n.uniform)(i.phiNormal??128),this.phiDepth=(0,n.uniform)(i.phiDepth??1),this.iterationCount=(0,n.uniform)(0),this.resW=(0,n.uniform)(i.width||1),this.resH=(0,n.uniform)(i.height||1),this._iterations=0,this._inputTexNode=new t.TextureNode,this._ndTexNode=new t.TextureNode;let a=2048,o=i.width||1,s=i.height||1;this._outputStorageTex=new t.StorageTexture(a,a),this._outputStorageTex.type=r.HalfFloatType,this._outputStorageTex.format=r.RGBAFormat,this._outputStorageTex.minFilter=r.NearestFilter,this._outputStorageTex.magFilter=r.NearestFilter,this._srcRegion=new r.Box2(new r.Vector2(0,0),new r.Vector2(0,0)),this.outputTarget=new t.RenderTarget(o,s,{type:r.HalfFloatType,format:r.RGBAFormat,minFilter:r.NearestFilter,magFilter:r.NearestFilter,depthBuffer:!1,stencilBuffer:!1}),this._dispatchX=Math.ceil(o/16),this._dispatchY=Math.ceil(s/16),this._buildCompute()}_buildCompute(){let e=this._inputTexNode,t=this._ndTexNode,r=this._outputStorageTex,i=this.filterStrength,a=this.strengthDecaySpeed,o=this.edgeThreshold,s=this.phiNormal,c=this.phiDepth,l=this.iterationCount,u=this.resW,d=this.resH;this._computeNode=(0,n.Fn)(()=>{let f=(0,n.int)(n.workgroupId.x).mul(16).add((0,n.int)(n.localId.x)),p=(0,n.int)(n.workgroupId.y).mul(16).add((0,n.int)(n.localId.y));(0,n.If)(f.lessThan((0,n.int)(u)).and(p.lessThan((0,n.int)(d))),()=>{let m=(0,n.ivec2)(f,p),h=(0,n.textureLoad)(e,m).xyz,g=(0,n.dot)(h,Lt),_=1e5,v=(0,n.textureLoad)(t,m),y=v.xyz.mul(2).sub(1),b=v.w,x=(0,n.step)((0,n.float)(_),b).oneMinus(),S=i.sub(l.mul(a)).clamp(0,1),C=h.toVar(),w=(0,n.float)(1).toVar();for(let[r,i]of[[1,0],[0,1],[-1,0],[0,-1],[1,1],[-1,1],[-1,-1],[1,-1]])for(let a of[1,2]){let l=(0,n.ivec2)(f.add(r*a).clamp((0,n.int)(0),(0,n.int)(u).sub(1)),p.add(i*a).clamp((0,n.int)(0),(0,n.int)(d).sub(1))),m=(0,n.textureLoad)(e,l).xyz,h=(0,n.dot)(m,Lt),v=(0,n.textureLoad)(t,l),S=v.xyz.mul(2).sub(1),T=v.w,E=(0,n.step)((0,n.float)(_),T).oneMinus(),D=(0,n.abs)(g.sub(h)).div((0,n.max)(o,(0,n.float)(.001))).negate().exp(),O=x.mul(E),k=x.oneMinus().mul(E.oneMinus()),A=O.add(k),j=(0,n.pow)((0,n.dot)(y,S).clamp(0,1),s),M=(0,n.abs)(b.sub(T)).div((0,n.max)(c,(0,n.float)(.001))).negate().exp(),N=(0,n.mix)((0,n.float)(1),j.mul(M),O),P=(0,n.float)(1).div((0,n.float)(a).add(.5)),ee=D.mul(N).mul(A).mul(P);C.addAssign(m.mul(ee)),w.addAssign(ee)}let T=(0,n.mix)(h,C.div((0,n.max)(w,(0,n.float)(1e-4))),S),E=(0,n.dot)(T,Lt),D=T.toVar();(0,n.If)(E.greaterThan(10),()=>{D.assign(T.mul((0,n.float)(10).div(E)))}),(0,n.textureStore)(r,(0,n.uvec2)((0,n.uint)(f),(0,n.uint)(p)),(0,n.vec4)(D,1)).toWriteOnly()})})().compute([this._dispatchX,this._dispatchY,1],[16,16,1])}render(e){if(!this.enabled)return;let t=e.getTexture(`asvgf:output`)||e.getTexture(`bilateralFiltering:output`)||e.getTexture(`pathtracer:color`),n=e.getTexture(`pathtracer:normalDepth`);if(!t||!n){t&&e.setTexture(`edgeFiltering:output`,t);return}if(e.getState(`interactionMode`)){e.setTexture(`edgeFiltering:output`,t);return}let r=t.image;r&&r.width>0&&r.height>0&&(r.width!==this.outputTarget.width||r.height!==this.outputTarget.height)&&this.setSize(r.width,r.height),this._inputTexNode.value=t,this._ndTexNode.value=n,this._iterations++,this.iterationCount.value=this._iterations,this.renderer.compute(this._computeNode),this._srcRegion.min.set(0,0),this._srcRegion.max.set(this.outputTarget.width,this.outputTarget.height),this.renderer.copyTextureToTexture(this._outputStorageTex,this.outputTarget.texture,this._srcRegion),e.setTexture(`edgeFiltering:output`,this.outputTarget.texture)}setFilteringEnabled(e){this.enabled=e}updateUniforms(e){e&&(e.filterStrength!==void 0&&(this.filterStrength.value=e.filterStrength),e.strengthDecaySpeed!==void 0&&(this.strengthDecaySpeed.value=e.strengthDecaySpeed),e.edgeThreshold!==void 0&&(this.edgeThreshold.value=e.edgeThreshold),e.phiNormal!==void 0&&(this.phiNormal.value=e.phiNormal),e.phiDepth!==void 0&&(this.phiDepth.value=e.phiDepth))}reset(){this._iterations=0,this.iterationCount.value=0}setSize(e,t){this.outputTarget.setSize(e,t),this.outputTarget.texture.needsUpdate=!0,this.resW.value=e,this.resH.value=t,this._dispatchX=Math.ceil(e/16),this._dispatchY=Math.ceil(t/16),this._computeNode.dispatchSize=[this._dispatchX,this._dispatchY,1]}dispose(){this._computeNode?.dispose(),this._outputStorageTex?.dispose(),this.outputTarget?.dispose(),this._inputTexNode?.dispose(),this._ndTexNode?.dispose()}},Za=256,Qa=-8,$a=6-Qa,eo=$a/Za,to=1e4,no=(0,n.wgslFn)(`
662
638
  fn adaptExposure(
663
639
  geoMean: f32,
664
640
  prevExposure: f32,
@@ -687,5 +663,5 @@
687
663
  return vec4f( newExposure, geoMean, targetExp, 1.0 );
688
664
 
689
665
  }
690
- `),bo=class extends I{constructor(e,r={}){super(`AutoExposure`,{...r,executionMode:F.ALWAYS}),this.renderer=e,this.REDUCTION_SIZE=64,this.keyValueU=(0,n.uniform)(r.keyValue??.18),this.minExposureU=(0,n.uniform)(r.minExposure??.1),this.maxExposureU=(0,n.uniform)(r.maxExposure??20),this.adaptSpeedBrightU=(0,n.uniform)(r.adaptSpeedBright??3),this.adaptSpeedDarkU=(0,n.uniform)(r.adaptSpeedDark??.5),this.epsilonU=(0,n.uniform)(r.epsilon??1e-4),this.deltaTimeU=(0,n.uniform)(1/60),this.isFirstFrameU=(0,n.uniform)(1),this.previousExposureU=(0,n.uniform)(r.initialExposure??1),this.lowPercentileU=(0,n.uniform)(r.lowPercentile??.1),this.highPercentileU=(0,n.uniform)(r.highPercentile??.9),this.centerWeightU=(0,n.uniform)(r.centerWeight??8),this.inputResW=(0,n.uniform)(1),this.inputResH=(0,n.uniform)(1),this._inputTexNode=new t.TextureNode,this._reductionReadTexNode=new t.TextureNode,this.currentExposure=r.initialExposure??1,this.currentLuminance=.18,this.targetExposure=1,this.lastTime=performance.now(),this.isFirstFrame=!0,this._pendingReadback=!1,this._readbackGeneration=0,this._initRenderTargets(),this._buildCompute()}_initRenderTargets(){let e={type:r.FloatType,format:r.RGBAFormat,minFilter:r.NearestFilter,magFilter:r.NearestFilter,depthBuffer:!1,stencilBuffer:!1};this._downsampleTarget=new t.RenderTarget(this.REDUCTION_SIZE,this.REDUCTION_SIZE,e),this._downsampleStorageTex=new t.StorageTexture(this.REDUCTION_SIZE,this.REDUCTION_SIZE),this._downsampleStorageTex.type=r.FloatType,this._downsampleStorageTex.format=r.RGBAFormat,this._downsampleStorageTex.minFilter=r.NearestFilter,this._downsampleStorageTex.magFilter=r.NearestFilter,this._reductionStorageTex=new t.StorageTexture(1,1),this._reductionStorageTex.type=r.FloatType,this._reductionStorageTex.format=r.RGBAFormat,this._reductionStorageTex.minFilter=r.NearestFilter,this._reductionStorageTex.magFilter=r.NearestFilter,this._reductionReadTarget=new t.RenderTarget(1,1,e),this._adaptationResult=(0,n.attributeArray)(1,`vec4`),this._readbackBuffer=new t.ReadbackBuffer(16),this._readbackBuffer.name=`AutoExposureAdaptation`,this._histogramBuffer=(0,n.attributeArray)(mo,`uint`).toAtomic()}_buildCompute(){this._buildDownsampleCompute(),this._buildHistogramCompute(),this._buildHistogramAnalyzeCompute(),this._buildAdaptationCompute()}_buildDownsampleCompute(){let e=this._inputTexNode,t=this._downsampleStorageTex,r=this.epsilonU,i=this.inputResW,a=this.inputResH;this._downsampleComputeNode=(0,n.Fn)(()=>{let o=(0,n.int)(n.workgroupId.x).mul(8).add((0,n.int)(n.localId.x)),s=(0,n.int)(n.workgroupId.y).mul(8).add((0,n.int)(n.localId.y)),c=i.div((0,n.float)(64)),l=a.div((0,n.float)(64)),u=(0,n.float)(o).mul(c),d=(0,n.float)(s).mul(l),f=(0,n.float)(0).toVar(),p=(0,n.float)(0).toVar();for(let t=0;t<4;t++)for(let i=0;i<4;i++){let a=Qt((0,n.textureLoad)(e,(0,n.ivec2)((0,n.int)(u.add((0,n.float)((i+.5)/4).mul(c))),(0,n.int)(d.add((0,n.float)((t+.5)/4).mul(l))))).xyz);(0,n.If)(a.greaterThan(r),()=>{f.addAssign(a.add(r).log()),p.addAssign(1)})}(0,n.textureStore)(t,(0,n.uvec2)((0,n.uint)(o),(0,n.uint)(s)),(0,n.vec4)(f,p,0,1)).toWriteOnly()})().compute([64/8,64/8,1],[8,8,1])}_buildHistogramCompute(){let e=this._downsampleTarget.texture,t=this._histogramBuffer,r=this.centerWeightU;this._histogramComputeNode=(0,n.Fn)(()=>{let i=n.localId.x;(0,n.atomicStore)(t.element(i),(0,n.uint)(0)),(0,n.workgroupBarrier)();for(let a=0;a<16;a++){let o=i.mul(16).add(a),s=o.mod(64),c=o.div(64),l=(0,n.textureLoad)(e,(0,n.ivec2)((0,n.int)(s),(0,n.int)(c))),u=l.x,d=l.y;(0,n.If)(d.greaterThan(0),()=>{let e=(0,n.uint)(u.div(d).sub((0,n.float)(ho)).div((0,n.float)(go)).mul((0,n.float)(mo)).floor().clamp(0,(0,n.float)(mo-1))),i=(0,n.float)(s).add(.5).div((0,n.float)(64)),a=(0,n.float)(c).add(.5).div((0,n.float)(64)),o=i.sub(.5),l=a.sub(.5),f=(0,n.uint)(o.mul(o).add(l.mul(l)).mul(r).negate().exp().mul((0,n.float)(vo)));(0,n.atomicAdd)(t.element(e),f)})}})().compute([1,1,1],[256,1,1])}_buildHistogramAnalyzeCompute(){let e=this._histogramBuffer,t=this._reductionStorageTex,r=this.lowPercentileU,i=this.highPercentileU;this._histogramAnalyzeNode=(0,n.Fn)(()=>{let a=(0,n.float)(0).toVar();(0,n.Loop)(mo,({i:t})=>{a.addAssign((0,n.float)((0,n.atomicLoad)(e.element(t))))});let o=a.mul(r),s=a.mul(i),c=(0,n.float)(0).toVar(),l=(0,n.float)(0).toVar(),u=(0,n.float)(0).toVar(),d=(0,n.float)(0).toVar();(0,n.Loop)(mo,({i:t})=>{let r=(0,n.float)((0,n.atomicLoad)(e.element(t)));d.assign(c),c.addAssign(r),(0,n.If)(d.lessThan(s).and(c.greaterThan(o)),()=>{let e=(0,n.float)(ho).add((0,n.float)(t).add(.5).mul((0,n.float)(_o)));l.addAssign(e.mul(r)),u.addAssign(r)})});let f=(0,n.max)(u,(0,n.float)(1)),p=l.div(f),m=p.exp();(0,n.textureStore)(t,(0,n.uvec2)((0,n.uint)(0),(0,n.uint)(0)),(0,n.vec4)(m,a,p,1)).toWriteOnly()})().compute(1,[1,1,1])}_buildAdaptationCompute(){let e=this._reductionReadTexNode,t=this._adaptationResult,r=this.keyValueU,i=this.minExposureU,a=this.maxExposureU,o=this.adaptSpeedBrightU,s=this.adaptSpeedDarkU,c=this.deltaTimeU,l=this.isFirstFrameU,u=this.previousExposureU;this._adaptationComputeNode=(0,n.Fn)(()=>{let d=(0,n.textureLoad)(e,(0,n.ivec2)((0,n.int)(0),(0,n.int)(0))).x,f=yo(d,u,r,i,a,o,s,c,l);t.element((0,n.uint)(0)).assign(f)})().compute(1,[1,1,1])}setupEventListeners(){this.on(`pipeline:reset`,()=>this.reset()),this.on(`autoexposure:resetHistory`,()=>this.resetHistory()),this.on(`autoexposure:toggle`,e=>{this.enabled=e}),this.on(`autoexposure:updateParameters`,e=>e&&this.updateParameters(e))}render(e){if(!this.enabled)return;let t=e.getTexture(`edgeFiltering:output`)||e.getTexture(`asvgf:output`)||e.getTexture(`pathtracer:color`);if(!t)return;let n=performance.now(),r=Math.min((n-this.lastTime)/1e3,.1);if(this.lastTime=n,this.deltaTimeU.value=this.isFirstFrame?1:r,this.isFirstFrameU.value=+!!this.isFirstFrame,this.previousExposureU.value=this.currentExposure,this.inputResW.value=t.image?.width||1,this.inputResH.value=t.image?.height||1,this._inputTexNode.value=t,this.renderer.compute(this._downsampleComputeNode),this.renderer.copyTextureToTexture(this._downsampleStorageTex,this._downsampleTarget.texture),this.renderer.compute(this._histogramComputeNode),this.renderer.compute(this._histogramAnalyzeNode),this.renderer.copyTextureToTexture(this._reductionStorageTex,this._reductionReadTarget.texture),this._reductionReadTexNode.value=this._reductionReadTarget.texture,this.renderer.compute(this._adaptationComputeNode),!this._pendingReadback){this._pendingReadback=!0;let e=this._readbackGeneration;this.renderer.getArrayBufferAsync(this._adaptationResult.value,this._readbackBuffer).then(t=>{let n=t&&t.buffer?new Float32Array(t.buffer.slice(0)):null;this._readbackBuffer.release(),this._pendingReadback=!1,n&&e===this._readbackGeneration&&this._applyReadback(n)}).catch(()=>{try{this._readbackBuffer.release()}catch{}this._pendingReadback=!1})}e.setState(`autoexposure:value`,this.currentExposure),e.setState(`autoexposure:avgLuminance`,this.currentLuminance),this.emit(`autoexposure:updated`,{exposure:this.currentExposure,luminance:this.currentLuminance,targetExposure:this.targetExposure}),this.isFirstFrame=!1}_applyReadback(e){if(!this.enabled||!e||e.length<3)return;let t=e[0],n=e[1],r=e[2];(!isFinite(t)||t<=0)&&(t=1),(!isFinite(n)||n<=0)&&(n=.18),(!isFinite(r)||r<=0)&&(r=t),this.currentExposure=t,this.currentLuminance=n,this.targetExposure=r,this.renderer.toneMappingExposure=t}reset(){this.lastTime=performance.now(),this._readbackGeneration++,this._pendingReadback=!1}resetHistory(){this.isFirstFrame=!0,this.currentExposure=1,this.currentLuminance=.18,this.targetExposure=1,this.lastTime=performance.now(),this._readbackGeneration++,this._pendingReadback=!1}setSize(){}setExposure(e){this.currentExposure=e,this.previousExposureU.value=e,this.renderer.toneMappingExposure=e}getExposure(){return this.currentExposure}getLuminance(){return this.currentLuminance}updateParameters(e){e.keyValue!==void 0&&(this.keyValueU.value=e.keyValue),e.minExposure!==void 0&&(this.minExposureU.value=e.minExposure),e.maxExposure!==void 0&&(this.maxExposureU.value=e.maxExposure),e.adaptSpeedBright!==void 0&&(this.adaptSpeedBrightU.value=e.adaptSpeedBright),e.adaptSpeedDark!==void 0&&(this.adaptSpeedDarkU.value=e.adaptSpeedDark),e.lowPercentile!==void 0&&(this.lowPercentileU.value=e.lowPercentile),e.highPercentile!==void 0&&(this.highPercentileU.value=e.highPercentile),e.centerWeight!==void 0&&(this.centerWeightU.value=e.centerWeight)}dispose(){this._downsampleComputeNode?.dispose(),this._histogramComputeNode?.dispose(),this._histogramAnalyzeNode?.dispose(),this._adaptationComputeNode?.dispose(),this._downsampleTarget?.dispose(),this._downsampleStorageTex?.dispose(),this._reductionStorageTex?.dispose(),this._reductionReadTarget?.dispose(),this._readbackBuffer?.dispose(),this._inputTexNode?.dispose(),this._reductionReadTexNode?.dispose()}};function xo({colorTexNode:e,ndTexNode:t,motionTexNode:r,readCacheTexNode:i,readPrevNDTexNode:a,writeCacheTex:o,writePrevNDTex:s,resW:c,resH:l,temporalAlpha:u,phiNormal:d,phiDepth:f,maxHistory:p,framesSinceReset:m}){return(0,n.Fn)(()=>{let h=(0,n.int)(n.workgroupId.x).mul(8).add((0,n.int)(n.localId.x)),g=(0,n.int)(n.workgroupId.y).mul(8).add((0,n.int)(n.localId.y));(0,n.If)(h.lessThan((0,n.int)(c)).and(g.lessThan((0,n.int)(l))),()=>{let _=(0,n.ivec2)(h,g),v=(0,n.textureLoad)(e,_).xyz,y=(0,n.textureLoad)(t,_),b=(0,n.vec4)(v,1).toVar();(0,n.If)(m.greaterThan((0,n.int)(0)),()=>{let e=(0,n.textureLoad)(r,_),t=e.w.greaterThan(.5),o=(0,n.float)(h).sub(e.x.mul(c)),s=(0,n.float)(g).sub(e.y.mul(l)),m=o.greaterThanEqual(0).and(o.lessThan((0,n.float)(c))).and(s.greaterThanEqual(0)).and(s.lessThan((0,n.float)(l)));(0,n.If)(t.and(m),()=>{let e=(0,n.ivec2)((0,n.int)(o).clamp((0,n.int)(0),(0,n.int)(c).sub(1)),(0,n.int)(s).clamp((0,n.int)(0),(0,n.int)(l).sub(1))),t=y.xyz.mul(2).sub(1),r=(0,n.textureLoad)(a,e),m=fn(t,r.xyz.mul(2).sub(1),y.w,r.w,d,f);(0,n.If)(m.greaterThan(.01),()=>{let t=(0,n.textureLoad)(i,e),r=t.xyz,a=t.w,o=(0,n.mix)(r,v,(0,n.min)((0,n.max)(u,(0,n.float)(1).div(a.add(1))).div((0,n.max)(m,(0,n.float)(.1))),1)),s=(0,n.min)(a.add(1),p);b.assign((0,n.vec4)(o,s))}).Else(()=>{b.assign((0,n.vec4)(v,1))})}).Else(()=>{b.assign((0,n.vec4)(v,1))})}),(0,n.textureStore)(o,(0,n.uvec2)(h,g),b).toWriteOnly(),(0,n.textureStore)(s,(0,n.uvec2)(h,g),y).toWriteOnly()})})}function So({colorTexNode:e,ndTexNode:t,readCacheTexNode:r,outputTex:i,resW:a,resH:o,spatialRadius:s,spatialWeight:c,phiNormal:l,phiDepth:u}){let d=[[1,0],[-1,0],[0,1],[0,-1],[1,1],[-1,1],[1,-1],[-1,-1]];return(0,n.Fn)(()=>{let f=(0,n.int)(n.workgroupId.x).mul(8).add((0,n.int)(n.localId.x)),p=(0,n.int)(n.workgroupId.y).mul(8).add((0,n.int)(n.localId.y));(0,n.If)(f.lessThan((0,n.int)(a)).and(p.lessThan((0,n.int)(o))),()=>{let m=(0,n.ivec2)(f,p),h=(0,n.textureLoad)(r,m),g=h.xyz,_=h.w,v=(0,n.textureLoad)(t,m),y=v.xyz.mul(2).sub(1),b=(0,n.float)(1).sub(_.div(16).clamp(0,1)),x=c.mul(b),S=(0,n.vec3)(g).toVar(),C=(0,n.float)(1).toVar();for(let e=0;e<d.length;e++){let[i,c]=d[e],m=(0,n.ivec2)(f.add((0,n.int)(s).mul(i)).clamp((0,n.int)(0),(0,n.int)(a).sub(1)),p.add((0,n.int)(s).mul(c)).clamp((0,n.int)(0),(0,n.int)(o).sub(1))),h=(0,n.textureLoad)(r,m).xyz,g=(0,n.textureLoad)(t,m),_=fn(y,g.xyz.mul(2).sub(1),v.w,g.w,l,u);S.addAssign(h.mul(_)),C.addAssign(_)}let w=(0,n.mix)(g,S.div((0,n.max)(C,1e-4)),x),T=(0,n.textureLoad)(e,m).w;(0,n.textureStore)(i,(0,n.uvec2)(f,p),(0,n.vec4)(w,T)).toWriteOnly()})})}var Co=class extends I{constructor(e,i={}){super(`SSRC`,{...i,executionMode:F.PER_CYCLE}),this.renderer=e,this.resW=(0,n.uniform)(1),this.resH=(0,n.uniform)(1),this.temporalAlpha=(0,n.uniform)(i.temporalAlpha??.1),this.phiNormal=(0,n.uniform)(i.phiNormal??128),this.phiDepth=(0,n.uniform)(i.phiDepth??.5),this.maxHistory=(0,n.uniform)(i.maxHistory??128),this.spatialRadius=(0,n.uniform)(i.spatialRadius??4,`int`),this.spatialWeight=(0,n.uniform)(i.spatialWeight??.4),this._framesSinceReset=(0,n.uniform)(0,`int`),this._colorTexNode=new t.TextureNode,this._ndTexNode=new t.TextureNode,this._motionTexNode=new t.TextureNode,this._readCacheTexNode=new t.TextureNode,this._readPrevNDTexNode=new t.TextureNode,this._readPass1CacheTexNode=new t.TextureNode,this._cacheTexA=this._createStorageTex(1,1,r.NearestFilter),this._cacheTexB=this._createStorageTex(1,1,r.NearestFilter),this._prevNDTexA=this._createStorageTex(1,1,r.NearestFilter),this._prevNDTexB=this._createStorageTex(1,1,r.NearestFilter),this._outputTex=this._createStorageTex(1,1,r.LinearFilter),this._currentPingPong=0,this._dispatchX=1,this._dispatchY=1,this._buildComputeNodes()}setupEventListeners(){this.on(`pipeline:reset`,()=>this._resetCache()),this.on(`camera:moved`,()=>this._resetCache())}render(e){if(!this.enabled){e.removeTexture(`ssrc:output`);return}let t=e.getTexture(`pathtracer:color`);if(t?.image){let{width:e,height:n}=t.image;(e!==this._cacheTexA.image.width||n!==this._cacheTexA.image.height)&&this.setSize(e,n)}let n=e.getTexture(`pathtracer:normalDepth`);if(!n||!t)return;this._colorTexNode.value=t,this._ndTexNode.value=n;let r=e.getTexture(`motionVector:screenSpace`);r&&(this._motionTexNode.value=r);let[i,a,o]=this._currentPingPong===0?[this._cacheTexB,this._cacheTexA,this._prevNDTexB]:[this._cacheTexA,this._cacheTexB,this._prevNDTexA];this._readCacheTexNode.value=i,this._readPrevNDTexNode.value=o,this.renderer.compute(this._currentPingPong===0?this._pass1NodeA:this._pass1NodeB),this._readPass1CacheTexNode.value=a,this.renderer.compute(this._pass2Node),this._framesSinceReset.value=Math.min(this._framesSinceReset.value+1,9999),e.setTexture(`ssrc:output`,this._outputTex),this._currentPingPong=1-this._currentPingPong}reset(){this._resetCache()}setSize(e,t){if(e<1||t<1)return;this._cacheTexA.setSize(e,t),this._cacheTexB.setSize(e,t),this._prevNDTexA.setSize(e,t),this._prevNDTexB.setSize(e,t),this._outputTex.setSize(e,t),this.resW.value=e,this.resH.value=t,this._dispatchX=Math.ceil(e/8),this._dispatchY=Math.ceil(t/8);let n=[this._dispatchX,this._dispatchY,1];this._pass1NodeA&&(this._pass1NodeA.dispatchSize=n),this._pass1NodeB&&(this._pass1NodeB.dispatchSize=n),this._pass2Node&&(this._pass2Node.dispatchSize=n),this._resetCache()}dispose(){this._pass1NodeA?.dispose(),this._pass1NodeB?.dispose(),this._pass2Node?.dispose(),this._cacheTexA.dispose(),this._cacheTexB.dispose(),this._prevNDTexA.dispose(),this._prevNDTexB.dispose(),this._outputTex.dispose(),this._colorTexNode?.dispose(),this._ndTexNode?.dispose(),this._motionTexNode?.dispose(),this._readCacheTexNode?.dispose(),this._readPrevNDTexNode?.dispose(),this._readPass1CacheTexNode?.dispose()}updateParameters(e){e.temporalAlpha!==void 0&&(this.temporalAlpha.value=e.temporalAlpha),e.phiNormal!==void 0&&(this.phiNormal.value=e.phiNormal),e.phiDepth!==void 0&&(this.phiDepth.value=e.phiDepth),e.maxHistory!==void 0&&(this.maxHistory.value=e.maxHistory),e.spatialRadius!==void 0&&(this.spatialRadius.value=e.spatialRadius),e.spatialWeight!==void 0&&(this.spatialWeight.value=e.spatialWeight)}_createStorageTex(e,n,i){let a=new t.StorageTexture(e,n);return a.type=r.HalfFloatType,a.format=r.RGBAFormat,a.minFilter=i,a.magFilter=i,a}_resetCache(){this._currentPingPong=0,this._framesSinceReset.value=0}_buildComputeNodes(){let e={colorTexNode:this._colorTexNode,ndTexNode:this._ndTexNode,motionTexNode:this._motionTexNode,readCacheTexNode:this._readCacheTexNode,readPrevNDTexNode:this._readPrevNDTexNode,resW:this.resW,resH:this.resH,temporalAlpha:this.temporalAlpha,phiNormal:this.phiNormal,phiDepth:this.phiDepth,maxHistory:this.maxHistory},t=xo({...e,writeCacheTex:this._cacheTexA,writePrevNDTex:this._prevNDTexA,framesSinceReset:this._framesSinceReset}),n=xo({...e,writeCacheTex:this._cacheTexB,writePrevNDTex:this._prevNDTexB,framesSinceReset:this._framesSinceReset}),r=[this._dispatchX,this._dispatchY,1],i=[8,8,1];this._pass1NodeA=t().compute(r,i),this._pass1NodeB=n().compute(r,i),this._pass2Node=So({colorTexNode:this._colorTexNode,ndTexNode:this._ndTexNode,readCacheTexNode:this._readPass1CacheTexNode,outputTex:this._outputTex,resW:this.resW,resH:this.resH,spatialRadius:this.spatialRadius,spatialWeight:this.spatialWeight,phiNormal:this.phiNormal,phiDepth:this.phiDepth})().compute(r,i)}},wo=class extends I{constructor(e,i={}){super(`Compositor`,{...i,executionMode:F.ALWAYS}),this.renderer=e,this.saturation=(0,n.uniform)(i.saturation??1),this._transparentBackground=(0,n.uniform)(0,`int`),this._sourceTexNode=new t.TextureNode;let a=this._sourceTexNode.sample((0,n.uv)()),o=(0,n.mix)((0,n.vec3)((0,n.dot)(a.xyz,qt)),a.xyz,this.saturation),s=(0,n.select)(this._transparentBackground,a.w,1);this.compositorMaterial=new t.MeshBasicNodeMaterial,this.compositorMaterial.colorNode=(0,n.vec4)(o,s),this.compositorMaterial.blending=r.NoBlending,this.compositorQuad=new t.QuadMesh(this.compositorMaterial)}_resolveSourceTexture(e){return e.getTexture(`bloom:output`)||e.getTexture(`edgeFiltering:output`)||e.getTexture(`asvgf:output`)||e.getTexture(`ssrc:output`)||e.getTexture(`pathtracer:color`)}render(e){if(!this.enabled)return;let t=this._resolveSourceTexture(e);t&&(this._sourceTexNode.value=t,this.renderer.setRenderTarget(null),this.compositorQuad.render(this.renderer))}setSaturation(e){this.saturation.value=e}setTransparentBackground(e){this._transparentBackground.value=+!!e}dispose(){this._sourceTexNode?.dispose(),this.compositorMaterial?.dispose(),this.compositorQuad=null}},To=class{constructor(){this.textures=new Map,this.renderTargets=new Map,this.uniforms=new Map,this.state={frame:0,accumulatedFrames:0,renderMode:0,interactionMode:!1,isComplete:!1,tileInfo:null,currentTile:0,totalTiles:0,cameraChanged:!1,cameraMoving:!1,width:0,height:0,time:0,deltaTime:0,enableASVGF:!1,enableAdaptiveSampling:!1,enableEdgeFiltering:!1},this._stateChangeCallbacks=new Map}setTexture(e,t){this.textures.set(e,t)}getTexture(e){return this.textures.get(e)}hasTexture(e){return this.textures.has(e)}removeTexture(e){this.textures.delete(e)}getTextureNames(){return Array.from(this.textures.keys())}clearTextures(){this.textures.clear()}setRenderTarget(e,t){this.renderTargets.set(e,t)}getRenderTarget(e){return this.renderTargets.get(e)}hasRenderTarget(e){return this.renderTargets.has(e)}removeRenderTarget(e){this.renderTargets.delete(e)}getRenderTargetNames(){return Array.from(this.renderTargets.keys())}clearRenderTargets(){this.renderTargets.clear()}setUniform(e,t){this.uniforms.has(e)?this.uniforms.get(e).value=t:this.uniforms.set(e,{value:t})}getUniform(e){return this.uniforms.get(e)}getUniformValue(e){return this.uniforms.get(e)?.value}hasUniform(e){return this.uniforms.has(e)}removeUniform(e){this.uniforms.delete(e)}getUniformNames(){return Array.from(this.uniforms.keys())}clearUniforms(){this.uniforms.clear()}setState(e,t){let n=this.state[e],r=n!==t;return r&&(this.state[e]=t,this._notifyStateChange(e,t,n)),r}getState(e){return this.state[e]}getAllState(){return this.state}setStates(e){let t=[];for(let[n,r]of Object.entries(e))this.setState(n,r)&&t.push(n);return t}hasState(e){return e in this.state}watchState(e,t){this._stateChangeCallbacks.has(e)||this._stateChangeCallbacks.set(e,[]),this._stateChangeCallbacks.get(e).push(t)}unwatchState(e,t){if(!this._stateChangeCallbacks.has(e))return;let n=this._stateChangeCallbacks.get(e),r=n.indexOf(t);r>-1&&n.splice(r,1)}_notifyStateChange(e,t,n){if(!this._stateChangeCallbacks.has(e))return;let r=this._stateChangeCallbacks.get(e);for(let i of r)try{i(t,n)}catch(t){console.error(`Error in state change callback for '${e}':`,t)}}reset(){this.state.frame=0,this.state.accumulatedFrames=0,this.state.isComplete=!1,this.state.cameraChanged=!0,this.state.currentTile=0}incrementFrame(){return this.state.frame++,this.state.accumulatedFrames++,this.state.frame}dispose(){this.textures.clear(),this.renderTargets.clear(),this.uniforms.clear(),this._stateChangeCallbacks.clear(),this.state={}}},Eo=class extends r.EventDispatcher{constructor(){super(),this._onceCallbacks=new Map}on(e,t){this.addEventListener(e,t)}once(e,t){let n=r=>{t(r),this.off(e,n),this._onceCallbacks.delete(t)};this._onceCallbacks.set(t,n),this.on(e,n)}off(e,t){let n=this._onceCallbacks.get(t);n?(this.removeEventListener(e,n),this._onceCallbacks.delete(t)):this.removeEventListener(e,t)}emit(e,t){t&&typeof t==`object`&&t.type?this.dispatchEvent(t):this.dispatchEvent({type:e,...t})}removeAllListeners(e){if(e){for(let[t,n]of this._onceCallbacks.entries())this.hasEventListener(e,n)&&(this.removeEventListener(e,n),this._onceCallbacks.delete(t));this._listeners&&this._listeners[e]&&delete this._listeners[e]}else this._onceCallbacks.clear(),this._listeners&&={}}listenerCount(e){return!this._listeners||!this._listeners[e]?0:this._listeners[e].length}clear(){this.removeAllListeners()}eventNames(){return this._listeners?Object.keys(this._listeners):[]}},Do=class{constructor(e,t,n){this.renderer=e,this.width=t,this.height=n,this.stages=[],this.context=new To,this.eventBus=new Eo,this.context.setState(`width`,t),this.context.setState(`height`,n),this.stats={enabled:!1,logSkipped:!1,timings:new Map,frameCount:0}}addStage(e){this.stages.push(e),e.initialize(this.context,this.eventBus),this.stats.enabled&&console.log(`[Pipeline] Added stage: ${e.name}`)}getStage(e){return this.stages.find(t=>t.name===e)}removeStage(e){let t=this.stages.findIndex(t=>t.name===e);if(t>-1){let e=this.stages[t];return this.stages.splice(t,1),e.dispose&&e.dispose(),this.stats.timings.delete(e.name),!0}return!1}setStageEnabled(e,t){let n=this.getStage(e);n&&(t?n.enable():n.disable())}render(e=null){let t=this.stats.enabled?performance.now():0;for(let t of this.stages){if(!t.shouldExecuteThisFrame(this.context)){this.stats.enabled&&this.stats.logSkipped&&console.log(`[Pipeline] Skipped stage '${t.name}' (executionMode: ${t.executionMode})`);continue}try{let n=this.stats.enabled?performance.now():0;if(t.render(this.context,e),this.stats.enabled){let e=performance.now()-n;this.stats.timings.has(t.name)||this.stats.timings.set(t.name,[]);let r=this.stats.timings.get(t.name);r.push(e),r.length>60&&r.shift()}}catch(e){console.error(`[Pipeline] Error in stage '${t.name}':`,e)}}if(this.context.incrementFrame(),this.eventBus.emit(`frame:complete`,{frame:this.context.getState(`frame`),accumulatedFrames:this.context.getState(`accumulatedFrames`)}),this.stats.enabled){let e=performance.now()-t;this.stats.timings.has(`_total`)||this.stats.timings.set(`_total`,[]);let n=this.stats.timings.get(`_total`);n.push(e),n.length>60&&n.shift(),this.stats.frameCount++}}reset(){this.eventBus.emit(`pipeline:reset`);for(let e of this.stages)if(e.reset)try{e.reset()}catch(t){console.error(`[Pipeline] Error resetting stage '${e.name}':`,t)}this.context.reset(),this.stats.enabled&&(this.stats.timings.clear(),this.stats.frameCount=0)}setSize(e,t){this.width=e,this.height=t,this.context.setState(`width`,e),this.context.setState(`height`,t),this.eventBus.emit(`pipeline:resize`,{width:e,height:t});for(let n of this.stages)if(n.setSize)try{n.setSize(e,t)}catch(e){console.error(`[Pipeline] Error resizing stage '${n.name}':`,e)}}dispose(){for(let e of this.stages)if(e.dispose)try{e.dispose()}catch(t){console.error(`[Pipeline] Error disposing stage '${e.name}':`,t)}this.stages=[],this.context.dispose(),this.eventBus.clear(),this.stats.timings.clear()}setStatsEnabled(e){this.stats.enabled=e,e||(this.stats.timings.clear(),this.stats.frameCount=0)}getStats(){if(!this.stats.enabled)return null;let e={frameCount:this.stats.frameCount,stages:{},total:0};for(let[t,n]of this.stats.timings.entries()){if(n.length===0)continue;let r=n.reduce((e,t)=>e+t,0)/n.length,i=Math.min(...n),a=Math.max(...n);t===`_total`?(e.total=r,e.totalMin=i,e.totalMax=a):e.stages[t]={avg:r,min:i,max:a}}return e}logStats(){let e=this.getStats();if(!e){console.log(`[Pipeline] Stats not enabled`);return}console.group(`[Pipeline] Performance Stats`),console.log(`Frames: ${e.frameCount}`),e.totalMin===void 0?console.log(`Total: no frames recorded yet (pipeline.render() has not run since stats were enabled — the path tracer may have converged and stopped its animation loop)`):console.log(`Total: ${e.total.toFixed(2)}ms (min: ${e.totalMin.toFixed(2)}ms, max: ${e.totalMax.toFixed(2)}ms)`);for(let[t,n]of Object.entries(e.stages))console.log(` ${t}: ${n.avg.toFixed(2)}ms (min: ${n.min.toFixed(2)}ms, max: ${n.max.toFixed(2)}ms)`);console.groupEnd()}getInfo(){return{stageCount:this.stages.length,enabledStages:this.stages.filter(e=>e.enabled).length,stages:this.stages.map(e=>({name:e.name,enabled:e.enabled})),contextState:this.context.getAllState(),textures:this.context.getTextureNames(),renderTargets:this.context.getRenderTargetNames(),uniforms:this.context.getUniformNames(),events:this.eventBus.eventNames()}}logInfo(){let e=this.getInfo();console.group(`[Pipeline] Info`),console.log(`Stages:`,e.stages),console.log(`Context Textures:`,e.textures),console.log(`Context Render Targets:`,e.renderTargets),console.log(`Context Uniforms:`,e.uniforms),console.log(`Event Types:`,e.events),console.log(`State:`,e.contextState),console.groupEnd()}},Oo=class{constructor(){this.timeElapsed=0,this.lastResetTime=performance.now(),this.renderCompleteDispatched=!1}updateTime(){this.timeElapsed=(performance.now()-this.lastResetTime)/1e3}isTimeLimitReached(e,t){return e===`time`&&t>0&&this.timeElapsed>=t}isLimitReached(e,t,n){return e?this.isTimeLimitReached(t,n)?!0:e.frameCount>=e.completionThreshold:!1}markComplete(){return this.renderCompleteDispatched?!1:(this.renderCompleteDispatched=!0,!0)}reset(){this.timeElapsed=0,this.lastResetTime=performance.now(),this.renderCompleteDispatched=!1}resumeFromPause(){this.renderCompleteDispatched=!1,this.lastResetTime=performance.now()-this.timeElapsed*1e3}},ko=class extends r.EventDispatcher{constructor({scene:e,camera:t,canvas:n,assetLoader:i,pathTracer:a,floorPlane:o}){super(),this.scene=e,this.camera=t,this.canvas=n,this.assetLoader=i,this.pathTracer=a,this.floorPlane=o,this.raycaster=new r.Raycaster,this.focusMode=!1,this.focusPointIndicator=null,this.afPointPlacementMode=!1,this.handleAFPointClick=this.handleAFPointClick.bind(this),this.selectedObject=null,this.selectMode=!1,this.clickTimeout=null,this.mouseDownPosition=null,this.dragThreshold=5,this.handleFocusClick=this.handleFocusClick.bind(this),this.handleSelectClick=this.handleSelectClick.bind(this),this.handleSelectDoubleClick=this.handleSelectDoubleClick.bind(this),this.handleMouseDown=this.handleMouseDown.bind(this),this.handleMouseUp=this.handleMouseUp.bind(this),this.handleContextMenu=this.handleContextMenu.bind(this),this.handleContextPointerDown=this.handleContextPointerDown.bind(this),this.handleContextPointerUp=this.handleContextPointerUp.bind(this),this.contextPointerDownPosition=null,this.canvas.addEventListener(`pointerdown`,this.handleContextPointerDown),this.canvas.addEventListener(`pointerup`,this.handleContextPointerUp),this.canvas.addEventListener(`contextmenu`,this.handleContextMenu),this._overlayManager=null,this._transformManager=null,this._appDispatch=null,this._orbitControls=null}setDependencies({overlayManager:e,transformManager:t,appDispatch:n,orbitControls:r}){this._overlayManager=e||null,this._transformManager=t||null,this._appDispatch=n||null,this._orbitControls=r||null}select(e){let t=this._overlayManager?.getHelper(`outline`);t&&t.setSelectedObjects(e?[e]:[]),this.selectedObject=e||null,e?this._transformManager?.attach(e):this._transformManager?.detach(),this._appDispatch?.({type:L.OBJECT_SELECTED,object:e||null})}deselect(){this.select(null)}disableMode(){this.disableSelectMode(),this._transformManager?.detach()}on(e,t){return this.addEventListener(e,t),()=>this.removeEventListener(e,t)}toggleFocusMode(){return this.focusMode=!this.focusMode,this.canvas.style.cursor=this.focusMode?`crosshair`:`auto`,this.focusMode?this.canvas.addEventListener(`click`,this.handleFocusClick):this.canvas.removeEventListener(`click`,this.handleFocusClick),this._orbitControls&&(this._orbitControls.enabled=!this.focusMode),this.dispatchEvent({type:`focusModeChanged`,enabled:this.focusMode}),this.focusMode}handleFocusClick(e){let t=this.getMouseCoordinates(e);this.raycaster.setFromCamera(t,this.camera);let n=this.raycaster.intersectObjects(this.scene.children,!0);if(n.length>0){let e=n[0],t=e.distance;this.showFocusPoint(e.point),this.toggleFocusMode(),this.dispatchEvent({type:`focusChanged`,distance:t/this.assetLoader.getSceneScale(),worldDistance:t})}}showFocusPoint(e){this.focusPointIndicator&&this.scene.remove(this.focusPointIndicator),this.focusPointIndicator=new r.Mesh(new r.SphereGeometry(this.assetLoader.getSceneScale()*.02,16,16),new r.MeshBasicMaterial({color:65280,transparent:!0,opacity:.8,depthTest:!1})),this.focusPointIndicator.position.copy(e),this.scene.add(this.focusPointIndicator),setTimeout(()=>{this.focusPointIndicator&&=(this.scene.remove(this.focusPointIndicator),null)},2e3)}enterAFPointPlacementMode(){this.afPointPlacementMode=!0,this.canvas.style.cursor=`crosshair`,this.canvas.addEventListener(`click`,this.handleAFPointClick)}exitAFPointPlacementMode(){this.afPointPlacementMode=!1,this.canvas.style.cursor=`auto`,this.canvas.removeEventListener(`click`,this.handleAFPointClick)}handleAFPointClick(e){let t=this.canvas.getBoundingClientRect(),n=(e.clientX-t.left)/t.width,r=(e.clientY-t.top)/t.height;this.exitAFPointPlacementMode(),this.dispatchEvent({type:`afPointPlaced`,point:{x:n,y:r}})}toggleSelectMode(){return this.selectMode=!this.selectMode,this.canvas.style.cursor=this.selectMode?`pointer`:`auto`,this.selectMode?(this.canvas.addEventListener(`mousedown`,this.handleMouseDown),this.canvas.addEventListener(`mouseup`,this.handleMouseUp),this.canvas.addEventListener(`click`,this.handleSelectClick),this.canvas.addEventListener(`dblclick`,this.handleSelectDoubleClick)):(this.canvas.removeEventListener(`mousedown`,this.handleMouseDown),this.canvas.removeEventListener(`mouseup`,this.handleMouseUp),this.canvas.removeEventListener(`click`,this.handleSelectClick),this.canvas.removeEventListener(`dblclick`,this.handleSelectDoubleClick),this.clickTimeout&&=(clearTimeout(this.clickTimeout),null),this.mouseDownPosition=null),this.dispatchEvent({type:`selectModeChanged`,enabled:this.selectMode}),this.selectMode}disableSelectMode(){this.selectMode&&(this.selectMode=!1,this.canvas.style.cursor=`auto`,this.canvas.removeEventListener(`mousedown`,this.handleMouseDown),this.canvas.removeEventListener(`mouseup`,this.handleMouseUp),this.canvas.removeEventListener(`click`,this.handleSelectClick),this.canvas.removeEventListener(`dblclick`,this.handleSelectDoubleClick),this.clickTimeout&&=(clearTimeout(this.clickTimeout),null),this.mouseDownPosition=null,this.dispatchEvent({type:`selectModeChanged`,enabled:!1}))}handleMouseDown(e){this.mouseDownPosition={x:e.clientX,y:e.clientY,button:e.button}}wasMouseDragged(e){if(!this.mouseDownPosition)return!1;let t=Math.abs(e.clientX-this.mouseDownPosition.x),n=Math.abs(e.clientY-this.mouseDownPosition.y);return Math.sqrt(t*t+n*n)>this.dragThreshold}handleSelectClick(e){if(this.wasMouseDragged(e)){this.mouseDownPosition=null;return}if(this.mouseDownPosition=null,this.clickTimeout){clearTimeout(this.clickTimeout),this.clickTimeout=null;return}this.clickTimeout=setTimeout(()=>{this.clickTimeout=null;let t=this.getMouseCoordinates(e);this.raycaster.setFromCamera(t,this.camera);let n=this.raycaster.intersectObjects(this.scene.children,!0),r=this.filterValidIntersects(n);if(r.length>0){let e=r[0].object,t=this.selectedObject;t&&t.uuid===e.uuid?this.dispatchEvent({type:`objectDeselected`,object:e,uuid:e.uuid}):this.dispatchEvent({type:`objectSelected`,object:e,uuid:e.uuid})}else this.dispatchEvent({type:`objectDeselected`})},250)}handleSelectDoubleClick(e){if(this.wasMouseDragged(e)){this.mouseDownPosition=null;return}this.mouseDownPosition=null,this.clickTimeout&&=(clearTimeout(this.clickTimeout),null);let t=this.getMouseCoordinates(e);this.raycaster.setFromCamera(t,this.camera);let n=this.raycaster.intersectObjects(this.scene.children,!0),r=this.filterValidIntersects(n);if(r.length>0){let e=r[0].object;this.dispatchEvent({type:`objectDoubleClicked`,object:e,uuid:e.uuid})}}handleMouseUp(){}handleContextPointerDown(e){e.button===2&&(this.contextPointerDownPosition={x:e.clientX,y:e.clientY})}handleContextPointerUp(e){if(e.button!==2)return;if(this.contextPointerDownPosition){let t=Math.abs(e.clientX-this.contextPointerDownPosition.x),n=Math.abs(e.clientY-this.contextPointerDownPosition.y);if(Math.sqrt(t*t+n*n)>this.dragThreshold){this.contextPointerDownPosition=null;return}}else return;this.contextPointerDownPosition=null;let t=this.selectedObject;t&&this.dispatchEvent({type:`contextMenuRequested`,x:e.clientX,y:e.clientY,selectedObject:t})}handleContextMenu(e){e.preventDefault()}getMouseCoordinates(e){let t=this.canvas.getBoundingClientRect();return{x:(e.clientX-t.left)/t.width*2-1,y:-((e.clientY-t.top)/t.height)*2+1}}filterValidIntersects(e){return e.filter(e=>{let t=e.object;return t!==this.focusPointIndicator&&t!==this.floorPlane&&!t.name.includes(`Helper`)&&t.type===`Mesh`})}updateDependencies({scene:e,camera:t,floorPlane:n}){e&&(this.scene=e),t&&(this.camera=t),n&&(this.floorPlane=n)}wireAppEvents(e){this.addEventListener(`objectSelected`,t=>{this.select(t.object),e.refreshFrame(),e.dispatchEvent({type:L.OBJECT_SELECTED,object:t.object,uuid:t.uuid})}),this.addEventListener(`objectDeselected`,t=>{this.select(null),e.refreshFrame(),e.dispatchEvent({type:L.OBJECT_DESELECTED,object:t.object,uuid:t.uuid})}),this.addEventListener(`selectModeChanged`,t=>{e.dispatchEvent({type:L.SELECT_MODE_CHANGED,enabled:t.enabled})}),this.addEventListener(`objectDoubleClicked`,t=>{this.select(t.object),e.refreshFrame(),e.dispatchEvent({type:L.OBJECT_DOUBLE_CLICKED,object:t.object,uuid:t.uuid})}),this.addEventListener(`focusChanged`,t=>{e.settings.set(`focusDistance`,t.worldDistance),e.dispatchEvent({type:`focusChanged`,distance:t.distance})}),this.addEventListener(`afPointPlaced`,t=>{e.dispatchEvent({type:L.AF_POINT_PLACED,point:t.point})})}dispose(){this.canvas.removeEventListener(`click`,this.handleAFPointClick),this.canvas.removeEventListener(`click`,this.handleFocusClick),this.canvas.removeEventListener(`mousedown`,this.handleMouseDown),this.canvas.removeEventListener(`mouseup`,this.handleMouseUp),this.canvas.removeEventListener(`click`,this.handleSelectClick),this.canvas.removeEventListener(`dblclick`,this.handleSelectDoubleClick),this.canvas.removeEventListener(`contextmenu`,this.handleContextMenu),this.canvas.removeEventListener(`pointerdown`,this.handleContextPointerDown),this.canvas.removeEventListener(`pointerup`,this.handleContextPointerUp),this.clickTimeout&&=(clearTimeout(this.clickTimeout),null),this.mouseDownPosition=null,this.contextPointerDownPosition=null,this.focusPointIndicator&&=(this.scene.remove(this.focusPointIndicator),null),this.canvas.style.cursor=`auto`,this.scene=null,this.camera=null,this.canvas=null,this.assetLoader=null,this.pathTracer=null,this.floorPlane=null,this.raycaster=null}},Ao={glb:{type:`model`,name:`GLB (GLTF Binary)`},gltf:{type:`model`,name:`GLTF`},fbx:{type:`model`,name:`FBX`},obj:{type:`model`,name:`OBJ`},stl:{type:`model`,name:`STL`},ply:{type:`model`,name:`PLY (Polygon File Format)`},dae:{type:`model`,name:`Collada`},"3mf":{type:`model`,name:`3D Manufacturing Format`},usdz:{type:`model`,name:`Universal Scene Description`},hdr:{type:`environment`,name:`HDR (High Dynamic Range)`},exr:{type:`environment`,name:`EXR (OpenEXR)`},png:{type:`image`,name:`PNG`},jpg:{type:`image`,name:`JPEG`},jpeg:{type:`image`,name:`JPEG`},webp:{type:`image`,name:`WebP`},zip:{type:`archive`,name:`ZIP Archive`}},jo=class extends r.EventDispatcher{constructor(e,t,n){super(),this.scene=e,this.camera=t,this.controls=n,this.targetModel=null,this._externalModel=null,this.floorPlane=null,this.sceneScale=1,this.loaderCache={},this.uploadedFileInfo=null,this.animations=[],this.renderer=null}releaseTargetModel(){this.targetModel&&(this.targetModel===this._externalModel?this.targetModel.parent?.remove(this.targetModel):Oe(this.targetModel),this.targetModel=null,this._externalModel=null)}setRenderer(e){this.renderer=e}getFileFormat(e){return Ao[e.split(`.`).pop().toLowerCase()]||null}readFileAsArrayBuffer(e){return new Promise((t,n)=>{let r=new FileReader;r.onload=e=>t(e.target.result),r.onerror=e=>n(e),r.readAsArrayBuffer(e)})}readFileAsText(e){return new Promise((t,n)=>{let r=new FileReader;r.onload=e=>t(e.target.result),r.onerror=e=>n(e),r.readAsText(e)})}async loadAssetFromFile(e){let t=e.name,n=this.getFileFormat(t);if(!n)throw Error(`Unsupported file format: ${t}`);R({isLoading:!0,status:`Loading ${n.name}...`,progress:2});try{let r;switch(n.type){case`model`:r=await this.loadModelFromFile(e,t);break;case`environment`:case`image`:r=await this.loadEnvironmentFromFile(e,t);break;case`archive`:r=await this.loadArchiveFromFile(e,t);break;default:throw Error(`Unknown asset type: ${n.type}`)}return r}catch(e){throw this.dispatchEvent({type:`error`,message:e.message,filename:t}),e}}async loadModelFromFile(e,t){let n=t.split(`.`).pop().toLowerCase(),r=await this.readFileAsArrayBuffer(e);switch(n){case`glb`:case`gltf`:return await this.loadGLBFromArrayBuffer(r,t);case`fbx`:return await this.loadFBXFromArrayBuffer(r,t);case`obj`:return await this.loadOBJFromFile(e,t);case`stl`:return await this.loadSTLFromArrayBuffer(r,t);case`ply`:return await this.loadPLYFromArrayBuffer(r,t);case`dae`:return await this.loadColladaFromFile(e,t);case`3mf`:return await this.load3MFFromArrayBuffer(r,t);case`usdz`:return await this.loadUSDZFromArrayBuffer(r,t);default:throw Error(`Support for ${n} files is not yet implemented`)}}async loadEnvironmentFromFile(e,t){let n=URL.createObjectURL(e);this.uploadedFileInfo={name:t,type:e.type,size:e.size};try{let e=await this.loadEnvironment(n);return this.dispatchEvent({type:`load`,texture:e,filename:t}),e}finally{URL.revokeObjectURL(n)}}async loadEnvironment(e){try{this.dispatchEvent({type:`beforeEnvironmentLoad`,url:e});let t;if(e.startsWith(`blob:`))t=await this.loadEnvironmentFromBlob(e);else{let n=e.split(/[?#]/)[0].split(`.`).pop().toLowerCase();t=await this.loadEnvironmentByExtension(e,n)}return t.generateMipmaps=!0,this.applyEnvironmentToScene(t),this.dispatchEvent({type:`load`,texture:t}),t}catch(t){throw console.error(`Error loading environment:`,t),this.dispatchEvent({type:`error`,message:t.message,filename:e}),t}}async loadEnvironmentFromBlob(e){let t=await(await fetch(e)).blob(),n=this.determineEnvironmentExtension(t,e),r=URL.createObjectURL(t);try{return await this.loadEnvironmentByExtension(r,n)}finally{URL.revokeObjectURL(r)}}determineEnvironmentExtension(e,t){let n;if(e.type===`image/x-exr`||e.type.includes(`exr`))n=`exr`;else if(e.type===`image/vnd.radiance`||e.type.includes(`hdr`))n=`hdr`;else{let e=t.split(`/`).pop();if(e){let t=e.match(/\.([^.]+)$/);t&&(n=t[1].toLowerCase())}}return!n&&this.uploadedFileInfo&&(n=this.uploadedFileInfo.name.split(`.`).pop().toLowerCase()),n}async loadEnvironmentByExtension(e,t){let n;return t===`hdr`||t===`exr`?n=await(t===`hdr`?this.loaderCache.hdr||(this.loaderCache.hdr=new c.HDRLoader().setDataType(r.FloatType)):this.loaderCache.exr||(this.loaderCache.exr=new d.EXRLoader().setDataType(r.FloatType))).loadAsync(e):(this.loaderCache.texture||(this.loaderCache.texture=new r.TextureLoader),n=await this.loaderCache.texture.loadAsync(e)),n.mapping=r.EquirectangularReflectionMapping,n.minFilter=r.LinearFilter,n.magFilter=r.LinearFilter,n}applyEnvironmentToScene(e){this.scene.background=e,this.scene.environment=e}async loadArchiveFromFile(e,t){try{let n=await this.readFileAsArrayBuffer(e),r=(0,m.unzipSync)(new Uint8Array(n));return await this.processObjMtlPairsInZip(r,t)||await this.findAndLoadModelFromZip(r,t)}catch(e){throw console.error(`Error loading ZIP archive:`,e),e}}async processObjMtlPairsInZip(e,t){let n=[],r=[];for(let t in e){let i=t.toLowerCase();i.endsWith(`.obj`)?n.push({path:t,content:e[t]}):i.endsWith(`.mtl`)&&r.push({path:t,content:e[t]})}if(n.length>0&&r.length>0){console.log(`Found ${n.length} OBJ files and ${r.length} MTL files in ZIP`);let i=this.findMatchingObjMtlPairs(n,r);if(i.length>0)return console.log(`Found ${i.length} matching OBJ+MTL pairs`),await this.loadOBJMTLPairFromZip(i[0].obj,i[0].mtl,e,t);if(i.length===0)return console.log(`No matching pairs by name, using first OBJ and MTL files`),await this.loadOBJMTLPairFromZip(n[0],r[0],e,t)}return null}findMatchingObjMtlPairs(e,t){let n=[];for(let r of e){let e=r.path.split(`/`).pop().replace(/\.obj$/i,``).toLowerCase();for(let i of t){let t=i.path.split(`/`).pop().replace(/\.mtl$/i,``).toLowerCase();if(e===t||e.includes(t)||t.includes(e)){n.push({obj:r,mtl:i});break}}}return n}async findAndLoadModelFromZip(e){for(let t of[`scene.gltf`,`scene.glb`,`model.gltf`,`model.glb`,`main.gltf`,`main.glb`,`asset.gltf`,`asset.glb`])if(e[t]){console.log(`Found main model file: ${t}`);let n=t.split(`.`).pop().toLowerCase();return await this.loadModelFromZipEntry(e[t],t,n,e)}for(let t in e){let n=t.split(`.`).pop().toLowerCase();if(Ao[n]&&Ao[n].type===`model`)return console.log(`Loading model file from ZIP: ${t}`),await this.loadModelFromZipEntry(e[t],t,n,e)}throw Error(`No supported model files found in the ZIP archive`)}async loadModelFromZipEntry(e,t,n,r){try{R({isLoading:!0,status:`Processing ${n.toUpperCase()} from ZIP...`,progress:5});let i=new Blob([e.buffer],{type:`application/octet-stream`}),a=URL.createObjectURL(i),o;switch(n){case`glb`:case`gltf`:o=await this.handleGltfFromZip(n,e,t,r);break;case`fbx`:o=await this.loadFBXFromArrayBuffer(e.buffer,t);break;case`obj`:o=await this.handleObjFromZip(e,t,r);break;case`stl`:o=await this.loadSTLFromArrayBuffer(e.buffer,t);break;case`ply`:o=await this.loadPLYFromArrayBuffer(e.buffer,t);break;case`dae`:{let n=(0,m.strFromU8)(e),r=new File([new Blob([n])],t);o=await this.loadColladaFromFile(r,t)}break;case`3mf`:o=await this.load3MFFromArrayBuffer(e.buffer,t);break;case`usdz`:o=await this.loadUSDZFromArrayBuffer(e.buffer,t);break;default:throw Error(`Support for ${n} files is not yet implemented`)}return URL.revokeObjectURL(a),this.dispatchEvent({type:`load`,model:this.targetModel,filename:`${t} (from ZIP)`}),o}catch(e){throw console.error(`Error loading ${n} from ZIP:`,e),this.dispatchEvent({type:`error`,message:e.message,filename:t}),e}}async handleGltfFromZip(e,t,n,i){if(e===`gltf`){let e=(0,m.strFromU8)(t),a=new r.LoadingManager,o=n.split(`/`).slice(0,-1).join(`/`);a.setURLModifier(e=>this.resolveZipResource(e,o,i));let s=await this.createGLTFLoader();s.manager=a;try{return await new Promise((t,n)=>{s.parse(e,``,e=>{this.releaseTargetModel(),this.targetModel=e.scene,this.onModelLoad(this.targetModel).then(()=>t(e))},e=>n(e))})}finally{this._disposeGLTFLoader(s)}}else return await this.loadGLBFromArrayBuffer(t.buffer,n)}async handleObjFromZip(e,t,n){let r=(0,m.strFromU8)(e),i=r.match(/mtllib\s+([^\s]+)/),a=null;i&&i[1]&&(a=await this.loadMtlFromZip(i[1],t,n));let{OBJLoader:o}=await import(`three/examples/jsm/loaders/OBJLoader.js`),s=new o;a&&s.setMaterials(a);let c=s.parse(r);return c.name=t,this.releaseTargetModel(),this.targetModel=c,await this.onModelLoad(this.targetModel),c}async loadMtlFromZip(e,t,n){let i=t.split(`/`).slice(0,-1).join(`/`),a=[e,`${i}/${e}`,e.split(`/`).pop()];for(let e of a)if(n[e]){let{MTLLoader:t}=await import(`three/examples/jsm/loaders/MTLLoader.js`),a=(0,m.strFromU8)(n[e]),o=new r.LoadingManager;o.setURLModifier(e=>this.resolveZipResource(e,i,n));let s=new t(o).parse(a,i);return s.preload(),s}return null}resolveZipResource(e,t,n){let r=e.replace(/^\.\/|^\//,``),i=[r,`${t}/${r}`,r.split(`/`).pop()];for(let e of i)if(n[e]){let t=new Blob([n[e].buffer],{type:`application/octet-stream`});return URL.createObjectURL(t)}return console.warn(`Resource not found in ZIP: ${e}`),e}async loadOBJMTLPairFromZip(e,t,n,i){let{MTLLoader:a}=await import(`three/examples/jsm/loaders/MTLLoader.js`),{OBJLoader:o}=await import(`three/examples/jsm/loaders/OBJLoader.js`),s=[],c=new r.LoadingManager,l=e.path.split(`/`).slice(0,-1).join(`/`),u=t.path.split(`/`).slice(0,-1).join(`/`);c.setURLModifier(e=>this.resolveTextureInZip(e,l,u,t,n,s));let d=this.prepareFixedMtlContent(t),f=new a(c).parse(d,u);f.preload();let p=new o(c);p.setMaterials(f);let h=(0,m.strFromU8)(e.content),g=p.parse(h);return this.releaseTargetModel(),this.targetModel=g,await this.onModelLoad(this.targetModel),s.forEach(e=>URL.revokeObjectURL(e)),this.dispatchEvent({type:`load`,model:g,filename:`${e.path} (from ${i})`}),g}prepareFixedMtlContent(e){return(0,m.strFromU8)(e.content).replace(RegExp(`${e.path.split(`/`).pop()}\\s+`,`g`),` `).replace(/([a-zA-Z_]+)([\\/])/g,`$1 $2`)}resolveTextureInZip(e,t,n,r,i,a){let o=e.split(`?`)[0].split(`#`)[0].replace(/^\.\/|^\//,``),s=r.path.split(`/`).pop();o.startsWith(s)&&(o=o.substring(s.length).replace(/^\.\/|^\/|^\./,``));let c=[o,`${t}/${o}`,`${n}/${o}`,`textures/${o}`,`texture/${o}`,`materials/${o}`,o.split(`/`).pop()];for(let e of c)if(i[e]){let t=new Blob([i[e].buffer],{type:`application/octet-stream`}),n=URL.createObjectURL(t);return a.push(n),n}return this.findTextureWithFuzzyMatch(o,i,a)||e}findTextureWithFuzzyMatch(e,t,n){let r=e.split(`/`).pop();for(let e in t)if(e.endsWith(r)){let r=new Blob([t[e].buffer],{type:`application/octet-stream`}),i=URL.createObjectURL(r);return n.push(i),i}if(r&&r.length>5)for(let e in t){let i=e.split(`/`).pop();if(i.includes(r)||r.includes(i)){let r=new Blob([t[e].buffer],{type:`application/octet-stream`}),i=URL.createObjectURL(r);return n.push(i),i}}return null}async createGLTFLoader(){let e=new l.DRACOLoader;e.setDecoderConfig({type:`js`}),e.setDecoderPath(`https://www.gstatic.com/draco/v1/decoders/`);let t=new u.KTX2Loader;t.setTranscoderPath(`https://cdn.jsdelivr.net/npm/three@0.183.2/examples/jsm/libs/basis/`),this.renderer&&(t.detectSupport(this.renderer),t.workerConfig={astcSupported:!1,etc1Supported:!1,etc2Supported:!1,dxtSupported:!1,bptcSupported:!1,pvrtcSupported:!1});let n=new s.GLTFLoader;return n.setDRACOLoader(e),n.setKTX2Loader(t),n.setMeshoptDecoder(p.MeshoptDecoder),n}_disposeGLTFLoader(e){e&&(e.dracoLoader?.dispose(),e.ktx2Loader?.dispose())}async loadExampleModels(e,t){if(!t||!t[e])throw Error(`No model file at index ${e}`);let n=`${t[e].url}`;return await this.loadModel(n)}async loadModel(e){let t=await this.createGLTFLoader();try{R({status:`Loading Model...`,progress:2});let n=await t.loadAsync(e);return R({status:`Processing Data...`,progress:10}),this.releaseTargetModel(),this.targetModel=n.scene,this.animations=n.animations||[],await this.onModelLoad(this.targetModel),this.dispatchEvent({type:`load`,model:n.scene,filename:e.split(`/`).pop()}),n}catch(t){throw console.error(`Error loading model:`,t),this.dispatchEvent({type:`error`,message:t.message,filename:e}),t}finally{this._disposeGLTFLoader(t)}}async loadGLBFromArrayBuffer(e,t=`model.glb`){let n=await this.createGLTFLoader();try{R({isLoading:!0,status:`Processing GLB Data...`,progress:5}),await new Promise(e=>setTimeout(e,0));let r=await n.parseAsync(e,``);return this.releaseTargetModel(),this.targetModel=r.scene,this.animations=r.animations||[],R({isLoading:!0,status:`Processing Data...`,progress:10}),await this.onModelLoad(this.targetModel),this.dispatchEvent({type:`load`,model:r.scene,filename:t}),r}catch(e){throw console.error(`Error loading GLB:`,e),this.dispatchEvent({type:`error`,message:e.message,filename:t}),e}finally{this._disposeGLTFLoader(n)}}async loadFBXFromArrayBuffer(e,t=`model.fbx`){try{if(R({isLoading:!0,status:`Processing FBX Data...`,progress:5}),await new Promise(e=>setTimeout(e,0)),!this.loaderCache.fbx){let{FBXLoader:e}=await import(`three/examples/jsm/loaders/FBXLoader.js`);this.loaderCache.fbx=new e}let n=this.loaderCache.fbx.parse(e);return this.releaseTargetModel(),this.targetModel=n,R({isLoading:!0,status:`Processing Data...`,progress:10}),await this.onModelLoad(this.targetModel),this.dispatchEvent({type:`load`,model:n,filename:t}),n}catch(e){throw console.error(`Error loading FBX:`,e),this.dispatchEvent({type:`error`,message:e.message,filename:t}),e}}async loadOBJFromFile(e,t=`model.obj`){try{if(R({isLoading:!0,status:`Processing OBJ Data...`,progress:5}),await new Promise(e=>setTimeout(e,0)),!this.loaderCache.obj){let{OBJLoader:e}=await import(`three/examples/jsm/loaders/OBJLoader.js`);this.loaderCache.obj=new e}let n=await this.readFileAsText(e),r=this.loaderCache.obj.parse(n);return r.name=t,this.releaseTargetModel(),this.targetModel=r,R({isLoading:!0,status:`Processing Data...`,progress:10}),await this.onModelLoad(this.targetModel),this.dispatchEvent({type:`load`,model:r,filename:t}),r}catch(e){throw console.error(`Error loading OBJ:`,e),this.dispatchEvent({type:`error`,message:e.message,filename:t}),e}}async loadSTLFromArrayBuffer(e,t=`model.stl`){try{if(R({isLoading:!0,status:`Processing STL Data...`,progress:5}),await new Promise(e=>setTimeout(e,0)),!this.loaderCache.stl){let{STLLoader:e}=await import(`three/examples/jsm/loaders/STLLoader.js`);this.loaderCache.stl=new e}let n=new r.Mesh(this.loaderCache.stl.parse(e),new r.MeshStandardMaterial);return n.name=t,this.releaseTargetModel(),this.targetModel=n,R({isLoading:!0,status:`Processing Data...`,progress:10}),await this.onModelLoad(this.targetModel),this.dispatchEvent({type:`load`,model:n,filename:t}),n}catch(e){throw console.error(`Error loading STL:`,e),this.dispatchEvent({type:`error`,message:e.message,filename:t}),e}}async loadPLYFromArrayBuffer(e,t=`model.ply`){try{if(R({isLoading:!0,status:`Processing PLY Data...`,progress:5}),await new Promise(e=>setTimeout(e,0)),!this.loaderCache.ply){let{PLYLoader:e}=await import(`three/examples/jsm/loaders/PLYLoader.js`);this.loaderCache.ply=new e}let n=this.loaderCache.ply.parse(e),i;if(n.index!==null)i=new r.Mesh(n,new r.MeshStandardMaterial);else{let e=new r.PointsMaterial({size:.01});e.vertexColors=n.hasAttribute(`color`),i=new r.Points(n,e)}return i.name=t,this.releaseTargetModel(),this.targetModel=i,R({isLoading:!0,status:`Processing Data...`,progress:10}),await this.onModelLoad(this.targetModel),this.dispatchEvent({type:`load`,model:i,filename:t}),i}catch(e){throw console.error(`Error loading PLY:`,e),this.dispatchEvent({type:`error`,message:e.message,filename:t}),e}}async loadColladaFromFile(e,t=`model.dae`){try{if(R({isLoading:!0,status:`Processing Collada Data...`,progress:5}),await new Promise(e=>setTimeout(e,0)),!this.loaderCache.collada){let{ColladaLoader:e}=await import(`three/examples/jsm/loaders/ColladaLoader.js`);this.loaderCache.collada=new e}let n=await this.readFileAsText(e),r=this.loaderCache.collada.parse(n);return r.scene.name=t,this.releaseTargetModel(),this.targetModel=r.scene,R({isLoading:!0,status:`Processing Data...`,progress:10}),await this.onModelLoad(this.targetModel),this.dispatchEvent({type:`load`,model:r.scene,filename:t}),r}catch(e){throw console.error(`Error loading Collada:`,e),this.dispatchEvent({type:`error`,message:e.message,filename:t}),e}}async load3MFFromArrayBuffer(e,t=`model.3mf`){try{if(R({isLoading:!0,status:`Processing 3MF Data...`,progress:5}),await new Promise(e=>setTimeout(e,0)),!this.loaderCache.threemf){let{ThreeMFLoader:e}=await import(`three/examples/jsm/loaders/3MFLoader.js`);this.loaderCache.threemf=new e}let n=this.loaderCache.threemf.parse(e);return this.releaseTargetModel(),this.targetModel=n,R({isLoading:!0,status:`Processing Data...`,progress:10}),await this.onModelLoad(this.targetModel),this.dispatchEvent({type:`load`,model:n,filename:t}),n}catch(e){throw console.error(`Error loading 3MF:`,e),this.dispatchEvent({type:`error`,message:e.message,filename:t}),e}}async loadUSDZFromArrayBuffer(e,t=`model.usdz`){try{if(R({isLoading:!0,status:`Processing USDZ Data...`,progress:5}),await new Promise(e=>setTimeout(e,0)),!this.loaderCache.usdz){let{USDZLoader:e}=await import(`three/examples/jsm/loaders/USDZLoader.js`);this.loaderCache.usdz=new e}let n=this.loaderCache.usdz.parse(e);return n.name=t,this.releaseTargetModel(),this.targetModel=n,R({isLoading:!0,status:`Processing Data...`,progress:10}),await this.onModelLoad(this.targetModel),this.dispatchEvent({type:`load`,model:n,filename:t}),n}catch(e){throw console.error(`Error loading USDZ:`,e),this.dispatchEvent({type:`error`,message:e.message,filename:t}),e}}async loadObject3D(e,t=`object3d`){return e.name=e.name||t,this.releaseTargetModel(),this.targetModel=e,this._externalModel=e,R({isLoading:!0,status:`Processing Data...`,progress:10}),await this.onModelLoad(this.targetModel),this.dispatchEvent({type:`load`,model:e,filename:t}),e}async onModelLoad(e){let t=new ua(`onModelLoad`);t.start(`Camera extraction`);let n=this.extractCamerasFromModel(e);t.end(`Camera extraction`),t.start(`Camera setup`);let i=new r.Box3().setFromObject(e),a=i.getCenter(new r.Vector3),o=i.getSize(new r.Vector3);this.controls.target.copy(a);let s=Math.max(o.x,o.y,o.z),c=this.camera.fov*(Math.PI/180),l=Math.abs(s/Math.sin(c/2)/2),u=Math.PI/6,d=new r.Vector3(Math.cos(u)*l,l/Math.sqrt(2),Math.sin(u)*l);if(this.camera.position.copy(d.add(a)),this.camera.lookAt(a),this.camera.near=s/100,this.camera.far=s*100,this.camera.updateProjectionMatrix(),this.controls.maxDistance=l*10,this.controls.saveState(),this.controls.update(),t.end(`Camera setup`),this.floorPlane){let e=i.min.y;this.floorPlane.position.y=e,this.floorPlane.rotation.x=-Math.PI/2,this.floorPlane.scale.setScalar(s*5)}t.start(`Process model objects`),this.processModelObjects(e),t.end(`Process model objects`),t.start(`Scene add`),this.scene.add(e),t.end(`Scene add`);let f=s;return t.start(`setupPathTracing`),await this.setupPathTracing(e,f),t.end(`setupPathTracing`),t.print(),this.dispatchEvent({type:`modelProcessed`,model:e,cameras:n,sceneData:{center:a,size:o,maxDim:s,sceneScale:f}}),this.dispatchEvent({type:`SceneRebuild`}),{center:a,size:o,maxDim:s,sceneScale:f}}extractCamerasFromModel(e){let t=[];return e.updateWorldMatrix(!0,!0),e.traverse(e=>{if(e.isCamera){let n=e.clone();e.getWorldPosition(n.position),e.getWorldQuaternion(n.quaternion),(!n.name||n.name===``)&&(n.name=`Model Camera ${t.length+1}`),n.isPerspectiveCamera&&(n.aspect=this.camera.aspect,n.updateProjectionMatrix()),t.push(n)}}),t}processModelObjects(e){let t=[];e.traverse(e=>{let n=e.userData;if(e.isRectAreaLight&&!t.includes(e.uuid)&&t.push(e.uuid),e.name.startsWith(`RectAreaLightPlaceholder`)&&n.name&&n.type===`RectAreaLight`){let i=new r.RectAreaLight(new r.Color(...n.color),n.intensity*.1/Math.PI,n.width,n.height);i.position.z=-2,i.name=n.name,e.add(i),t.push(i.uuid)}if(e.isMesh&&Array.isArray(e.material)){console.log(`Found multi-material mesh:`,e.name);let t=(0,f.createMeshesFromMultiMaterialMesh)(e);e.parent&&(e.parent.add(t),e.parent.remove(e))}})}async setupPathTracing(e,t){this.sceneScale=t}createFloorPlane(){this.floorPlane=new r.Mesh(new r.CircleGeometry,new r.MeshPhysicalMaterial({transparent:!1,color:3158064,roughness:1,metalness:0,opacity:0,transmission:0})),this.floorPlane.name=`Ground`,this.floorPlane.visible=!1,this.scene.add(this.floorPlane)}setFloorPlane(e){this.floorPlane=e}getSceneScale(){return this.sceneScale}getTargetModel(){return this.targetModel}getSupportedFormats(e=null){if(e){let t={};for(let[n,r]of Object.entries(Ao))r.type===e&&(t[n]=r);return t}return Ao}dispose(){for(let e in this.loaderCache){let t=this.loaderCache[e];t&&typeof t.dispose==`function`&&t.dispose()}this.loaderCache={},this._listeners=void 0,this.releaseTargetModel()}removeAllEventListeners(){this._listeners=void 0}},Mo={maxBounces:{uniform:`maxBounces`,reset:!0},samplesPerPixel:{uniform:`samplesPerPixel`,reset:!0},transmissiveBounces:{uniform:`transmissiveBounces`,reset:!0},environmentIntensity:{uniform:`environmentIntensity`,reset:!0},backgroundIntensity:{uniform:`backgroundIntensity`,reset:!0},showBackground:{uniform:`showBackground`,reset:!0},enableEnvironment:{uniform:`enableEnvironment`,reset:!0},globalIlluminationIntensity:{uniform:`globalIlluminationIntensity`,reset:!0},enableDOF:{uniform:`enableDOF`,reset:!0},focusDistance:{uniform:`focusDistance`,reset:!1},focalLength:{uniform:`focalLength`,reset:!0},aperture:{uniform:`aperture`,reset:!0},apertureScale:{uniform:`apertureScale`,reset:!0},anamorphicRatio:{uniform:`anamorphicRatio`,reset:!0},samplingTechnique:{uniform:`samplingTechnique`,reset:!0},fireflyThreshold:{uniform:`fireflyThreshold`,reset:!0},enableAlphaShadows:{uniform:`enableAlphaShadows`,reset:!0},enableEmissiveTriangleSampling:{uniform:`enableEmissiveTriangleSampling`,reset:!0},emissiveBoost:{uniform:`emissiveBoost`,reset:!0},visMode:{uniform:`visMode`,reset:!0},debugVisScale:{uniform:`debugVisScale`,reset:!0},useAdaptiveSampling:{uniform:`useAdaptiveSampling`,reset:!0},adaptiveSamplingMax:{uniform:`adaptiveSamplingMax`,reset:!0},interactionModeEnabled:{handler:`handleInteractionModeEnabled`,reset:!1},maxSamples:{handler:`handleMaxSamples`,reset:!1},transparentBackground:{handler:`handleTransparentBackground`},exposure:{handler:`handleExposure`},saturation:{handler:`handleSaturation`},renderLimitMode:{handler:`handleRenderLimitMode`},renderTimeLimit:{handler:`handleRenderTimeLimit`,reset:!1},renderMode:{handler:`handleRenderMode`},environmentRotation:{handler:`handleEnvironmentRotation`}},No={bounces:`maxBounces`,adaptiveSampling:`useAdaptiveSampling`,debugMode:`visMode`},Po=class extends r.EventDispatcher{constructor(e=z){super(),this._values=new Map,this._pathTracer=null,this._resetCallback=null,this._handlers={},this._delegates={},this._initDefaults(e)}bind({stages:e,renderer:t,resetCallback:n,reconcileCompletion:r}){this._pathTracer=e.pathTracer,this._resetCallback=n,this._delegates={},this._handlers=this._buildHandlers(e,t,r)}_buildHandlers(e,t,n){return{handleTransparentBackground:t=>{e.pathTracer?.setUniform(`transparentBackground`,t),e.compositor?.setTransparentBackground(t)},handleExposure:n=>{!e.autoExposure?.enabled&&t&&(t.toneMappingExposure=n)},handleSaturation:t=>{e.compositor?.setSaturation(t)},handleRenderLimitMode:t=>{e.pathTracer?.setRenderLimitMode?.(t)},handleMaxSamples:t=>{e.pathTracer?.setUniform(`maxSamples`,t),e.pathTracer?.updateCompletionThreshold(),n?.()},handleRenderTimeLimit:()=>{n?.()},handleRenderMode:t=>{e.pathTracer?.setUniform(`renderMode`,parseInt(t))},handleEnvironmentRotation:t=>{e.pathTracer?.environment.setEnvironmentRotation(t)},handleInteractionModeEnabled:t=>{e.pathTracer?.setInteractionModeEnabled(t)}}}set(e,t,{reset:n,silent:r}={}){let i=this._values.get(e);if(i===t)return;this._values.set(e,t);let a=Mo[e];a&&(this._applyRoute(a,t,i),(n===void 0?a.reset??!0:n)&&this._resetCallback?.(),r||this.dispatchEvent({type:L.SETTING_CHANGED,key:e,value:t,prev:i}))}setMany(e,{silent:t}={}){let n=!1;for(let[r,i]of Object.entries(e)){let e=this._values.get(r);if(e===i)continue;this._values.set(r,i);let a=Mo[r];a&&(this._applyRoute(a,i,e),(a.reset??!0)&&(n=!0),t||this.dispatchEvent({type:L.SETTING_CHANGED,key:r,value:i,prev:e}))}n&&this._resetCallback?.()}get(e){return this._values.get(e)}getAll(){return Object.fromEntries(this._values)}applyAll(){for(let[e,t]of this._values){let n=Mo[e];n&&this._applyRoute(n,t,void 0)}}_applyRoute(e,t,n){e.uniform?(this._pathTracer?.setUniform(e.uniform,t),e.after&&this._pathTracer?.[e.after]?.()):e.handler?this._handlers[e.handler]?.(t,n):e.delegate&&this._delegates[e.delegate]?.updateParam?.(e.param,t)}_initDefaults(e){for(let t of Object.keys(Mo))t in e&&this._values.set(t,e[t]);for(let[t,n]of Object.entries(No))t in e&&this._values.set(n,e[t])}},Fo=class extends r.EventDispatcher{constructor(e){super();let t=e.clientWidth,n=e.clientHeight;this.camera=new r.PerspectiveCamera(60,t/n||1,.01,1e3),this.camera.position.set(0,0,5),this.controls=new h.OrbitControls(this.camera,e),this.controls.screenSpacePanning=!0,this.controls.zoomToCursor=!0,this.controls.saveState(),this.interactionManager=null,this.cameras=[this.camera],this.currentCameraIndex=0,this.autoFocusMode=ze.SMOOTHING_FACTOR?`auto`:`manual`,this.afScreenPoint={x:.5,y:.5},this.afSmoothingFactor=ze.SMOOTHING_FACTOR,this._lastValidFocusDistance=null,this._smoothedFocusDistance=null,this._afPointDirty=!1,this._defaultCameraState=null,this._onResize=null,this._onReset=null,this._getSettings=null}setCameras(e){this.cameras=e}getCameraNames(){return!this.cameras||this.cameras.length===0?[`Default Camera`]:this.cameras.map((e,t)=>t===0?`Default Camera`:e.name||`Camera ${t}`)}initCallbacks({onResize:e,onReset:t,getSettings:n}){this._onResize=e,this._onReset=t,this._getSettings=n}switchCamera(e,t,n,i){if(t??=this._getSettings?.(`focusDistance`),n??=this._onResize,i??=this._onReset,!(!this.cameras||this.cameras.length===0)){if((e<0||e>=this.cameras.length)&&(console.warn(`CameraManager: Invalid camera index ${e}. Using default camera.`),e=0),this.currentCameraIndex===0&&e!==0&&(this._defaultCameraState={position:this.camera.position.clone(),quaternion:this.camera.quaternion.clone(),fov:this.camera.fov,near:this.camera.near,far:this.camera.far,target:this.controls?this.controls.target.clone():null}),this.currentCameraIndex=e,e===0&&this._defaultCameraState){let e=this._defaultCameraState;this.camera.position.copy(e.position),this.camera.quaternion.copy(e.quaternion),this.camera.fov=e.fov,this.camera.near=e.near,this.camera.far=e.far,this.camera.updateProjectionMatrix(),this.camera.updateMatrixWorld(!0),this.controls&&e.target&&(this.controls.target.copy(e.target),this.controls.update())}else{let n=this.cameras[e];if(this.camera.position.copy(n.position),this.camera.quaternion.copy(n.quaternion),this.camera.fov=n.fov,this.camera.near=n.near,this.camera.far=n.far,this.camera.updateProjectionMatrix(),this.camera.updateMatrixWorld(!0),this.controls){let e=new r.Vector3(0,0,-1).applyQuaternion(n.quaternion),i=t||5;this.controls.target.copy(this.camera.position).addScaledVector(e,i),this.controls.update()}}n?.(),i?.(),this.dispatchEvent({type:`CameraSwitched`,cameraIndex:e})}}focusOn(e){!e||!this.controls||(this.controls.target.copy(e),this.controls.update(),this._onReset?.())}get active(){return this.camera}getNames(){return this.getCameraNames()}setAutoFocusMode(e){this.autoFocusMode=e,e!==`manual`&&(this._smoothedFocusDistance=null,this._afPointDirty=!0)}setAFScreenPoint(e,t){this.afScreenPoint={x:e,y:t},this._afPointDirty=!0}enterAFPointPlacementMode(){this.interactionManager&&(this.interactionManager.enterAFPointPlacementMode(),this.controls&&(this.controls.enabled=!1))}exitAFPointPlacementMode(){this.interactionManager&&(this.interactionManager.exitAFPointPlacementMode(),this.controls&&(this.controls.enabled=!0))}updateAutoFocus(e){let{meshScene:t,assetLoader:n,floorPlane:r,currentFocusDistance:i,pathTracer:a,setFocusDistance:o,softReset:s,hardReset:c}=e||this._afContext||{};if(!t||this.autoFocusMode===`manual`)return;let l=a;if(l?.isReady&&l.renderMode?.value===1&&l.frameCount>0&&!l.isComplete)return;let u=this.afScreenPoint.x*2-1,d=-(this.afScreenPoint.y*2-1),f=this.interactionManager?.raycaster;if(!f)return;f.setFromCamera({x:u,y:d},this.camera);let p=f.intersectObjects(t.children,!0).find(e=>e.object!==this.interactionManager?.focusPointIndicator&&e.object!==r&&!e.object.name.includes(`Helper`)&&e.object.type===`Mesh`),m;if(p)m=p.distance,this._lastValidFocusDistance=m;else if(this._lastValidFocusDistance!==null)m=this._lastValidFocusDistance;else{let e=n?.getSceneScale()||1;m=ze.FALLBACK_DISTANCE*e,this._lastValidFocusDistance=m}let h=this._afPointDirty;this._afPointDirty=!1,h||this._smoothedFocusDistance===null||this._smoothedFocusDistance===0||Math.abs(m-this._smoothedFocusDistance)/this._smoothedFocusDistance>ze.SNAP_THRESHOLD?this._smoothedFocusDistance=m:this._smoothedFocusDistance+=this.afSmoothingFactor*(m-this._smoothedFocusDistance);let g=i,_=this._smoothedFocusDistance;if(h||g===0||Math.abs(_-g)/Math.max(g,.001)>.001){o(_);let e=n?.getSceneScale()||1;this.dispatchEvent({type:L.AUTO_FOCUS_UPDATED,distance:_/e});let t=Math.abs(_-g)/Math.max(g,.001);h?c?.():t>ze.RESET_THRESHOLD&&s?.()}}setInteractionManager(e){this.interactionManager=e}initAutoFocus({meshScene:e,assetLoader:t,floorPlane:n,pathTracer:r,settings:i,softReset:a,hardReset:o}){this._afContext={meshScene:e,assetLoader:t,floorPlane:n,pathTracer:r,setFocusDistance:e=>i.set(`focusDistance`,e,{silent:!0}),softReset:a,hardReset:o},Object.defineProperty(this._afContext,`currentFocusDistance`,{get:()=>i.get(`focusDistance`)})}dispose(){this.controls?.dispose()}},Io=class extends r.EventDispatcher{constructor(e,t,n,r={}){super(),this.scene=e,this.sceneHelpers=t,this.pathTracer=n,this._onReset=r.onReset||null}addLight(e){let t={DirectionalLight:{position:[1,1,1],intensity:1,color:`#ffffff`},PointLight:{position:[0,2,0],intensity:100,color:`#ffffff`},SpotLight:{position:[0,1,0],intensity:300,color:`#ffffff`,angle:15},RectAreaLight:{position:[0,2,0],intensity:500,color:`#ffffff`,width:2,height:2}}[e];if(!t)return null;let n;if(e===`DirectionalLight`)n=new r.DirectionalLight(t.color,t.intensity),n.position.fromArray(t.position);else if(e===`PointLight`)n=new r.PointLight(t.color,t.intensity),n.position.fromArray(t.position);else if(e===`SpotLight`){n=new r.SpotLight(t.color,t.intensity),n.position.fromArray(t.position),n.angle=r.MathUtils.degToRad(t.angle);let e=new r.Object3D;this.scene.add(e),n.target=e}else e===`RectAreaLight`&&(n=new r.RectAreaLight(t.color,t.intensity,t.width,t.height),n.position.fromArray(t.position),n.lookAt(0,0,0));let i=this.scene.getObjectsByProperty(`isLight`,!0).length;return n.name=`${e.replace(`Light`,``)} ${i+1}`,this.scene.add(n),this.updateLights(),this._syncHelpers(),this._onReset?.(),this._buildDescriptor(n)}removeLight(e){let t=this.scene.getObjectByProperty(`uuid`,e);return!t||!t.isLight?!1:(this.sceneHelpers.remove(t),t.target&&t.target.removeFromParent(),t.removeFromParent(),this.updateLights(),this._onReset?.(),!0)}clearLights(){this.sceneHelpers.clear(),this._removeAllLights(),this.updateLights(),this._onReset?.()}getLights(){return this.scene.getObjectsByProperty(`isLight`,!0).map(e=>this._buildDescriptor(e))}updateLights(){this.pathTracer?.updateLights()}transferSceneLights(e){this._removeAllLights();let t=e.getObjectsByProperty(`isLight`,!0);if(!t||t.length===0){this.updateLights();return}for(let e of t){let t=e.clone();if(e.updateWorldMatrix(!0,!1),e.getWorldPosition(t.position),e.getWorldQuaternion(t.quaternion),e.getWorldScale(t.scale),t.isRectAreaLight&&(t.width*=t.scale.x,t.height*=t.scale.y,t.scale.set(1,1,1)),(e.isSpotLight||e.isDirectionalLight)&&e.target){let n=new r.Object3D;e.target.updateWorldMatrix(!0,!1),e.target.getWorldPosition(n.position),this.scene.add(n),t.target=n}this.scene.add(t)}this.updateLights(),this._syncHelpers()}setShowLightHelper(e){this.sceneHelpers.visible=e,e?this._syncHelpers():this.sceneHelpers.clear()}add(e){return this.addLight(e)}remove(e){return this.removeLight(e)}clear(){this.clearLights()}getAll(){return this.getLights()}sync(){this.updateLights()}showHelpers(e){this.setShowLightHelper(e)}dispose(){this._disposed||(this._disposed=!0,this.sceneHelpers?.clear(),this._removeAllLights(),this._onReset=null,this.pathTracer=null,this.sceneHelpers=null,this.scene=null)}_removeAllLights(){this.scene.getObjectsByProperty(`isLight`,!0).forEach(e=>{e.target&&this.scene.remove(e.target),this.scene.remove(e)})}_syncHelpers(){if(!this.sceneHelpers.visible)return;let e=this.scene.getObjectsByProperty(`isLight`,!0);this.sceneHelpers.sync(e)}_buildDescriptor(e){let t=0;e.type===`SpotLight`&&e.angle!==void 0&&(t=r.MathUtils.radToDeg(e.angle));let n={uuid:e.uuid,name:e.name,type:e.type,intensity:e.intensity,color:`#${e.color.getHexString()}`,position:[e.position.x,e.position.y,e.position.z],angle:t};if(e.type===`RectAreaLight`){n.width=e.width,n.height=e.height;let t=e.getWorldDirection(e.position.clone());n.target=[e.position.x+t.x,e.position.y+t.y,e.position.z+t.z]}else e.type===`SpotLight`&&e.target&&(n.target=[e.target.position.x,e.target.position.y,e.target.position.z]);return n}},Q=e=>Math.min(Math.max(e,0),1);function Lo(e,t,n,r,i){i[0]=Q(e),i[1]=Q(t),i[2]=Q(n)}function Ro(e,t,n,r,i){i[0]=Q(e*r),i[1]=Q(t*r),i[2]=Q(n*r)}function zo(e,t,n,r,i){e*=r,t*=r,n*=r,i[0]=Q(e/(e+1)),i[1]=Q(t/(t+1)),i[2]=Q(n/(n+1))}function Bo(e,t,n,r,i){e=Math.max(e*r-.004,0),t=Math.max(t*r-.004,0),n=Math.max(n*r-.004,0);let a=e=>(e*(6.2*e+.5)/(e*(6.2*e+1.7)+.06))**2.2;i[0]=a(e),i[1]=a(t),i[2]=a(n)}function Vo(e,t,n,r,i){e=e*r/.6,t=t*r/.6,n=n*r/.6;let a=.59719*e+.35458*t+.04823*n,o=.076*e+.90834*t+.01566*n,s=.0284*e+.13383*t+.83777*n,c=e=>(e*(e+.0245786)-90537e-9)/(e*(.983729*e+.432951)+.238081);a=c(a),o=c(o),s=c(s),i[0]=Q(1.60475*a-.53108*o-.07367*s),i[1]=Q(-.10208*a+1.10813*o-.00605*s),i[2]=Q(-.00327*a-.07276*o+1.07602*s)}function Ho(e,t,n,r,i){e*=r,t*=r,n*=r;let a=.6274*e+.3293*t+.0433*n,o=.0691*e+.9195*t+.0113*n,s=.0164*e+.088*t+.8956*n,c=.856627153315983*a+.0951212405381588*o+.0482516061458583*s,l=.137318972929847*a+.761241990602591*o+.101439036467562*s,u=.11189821299995*a+.0767994186031903*o+.811302368396859*s,d=-12.47393,f=4.026069-d;c=Q((Math.log2(Math.max(c,1e-10))-d)/f),l=Q((Math.log2(Math.max(l,1e-10))-d)/f),u=Q((Math.log2(Math.max(u,1e-10))-d)/f);let p=e=>{let t=e*e,n=t*t;return 15.5*n*t-40.14*n*e+31.96*n-6.868*t*e+.4298*t+.1191*e-.00232};c=p(c),l=p(l),u=p(u);let m=1.1271005818144368*c-.11060664309660323*l-.016493938717834573*u,h=-.1413297634984383*c+1.157823702216272*l-.016493938717834257*u,g=-.14132976349843826*c-.11060664309660294*l+1.2519364065950405*u;m=Math.max(0,m)**2.2,h=Math.max(0,h)**2.2,g=Math.max(0,g)**2.2,i[0]=Q(1.6605*m-.5876*h-.0728*g),i[1]=Q(-.1246*m+1.1329*h-.0083*g),i[2]=Q(-.0182*m-.1006*h+1.1187*g)}function Uo(e,t,n,r,i){let a=.76;e*=r,t*=r,n*=r;let o=Math.min(e,Math.min(t,n)),s=o<.08?o-6.25*o*o:.04;e-=s,t-=s,n-=s;let c=Math.max(e,Math.max(t,n));if(c<a){i[0]=e,i[1]=t,i[2]=n;return}let l=1-a,u=1-l*l/(c+l-a),d=u/c;e*=d,t*=d,n*=d;let f=1-1/(.15*(c-u)+1);i[0]=e+(u-e)*f,i[1]=t+(u-t)*f,i[2]=n+(u-n)*f}var Wo=new Map([[r.NoToneMapping,Lo],[r.LinearToneMapping,Ro],[r.ReinhardToneMapping,zo],[r.CineonToneMapping,Bo],[r.ACESFilmicToneMapping,Vo],[r.AgXToneMapping,Ho],[r.NeutralToneMapping,Uo]]),Go=1/2.2;function Ko(e){return e<=.0031308?12.92*e:1.055*e**(1/2.4)-.055}var qo=.2126,Jo=.7152,Yo=.0722;function Xo(e,t){if(t===1)return;let n=e[0]*qo+e[1]*Jo+e[2]*Yo;e[0]=n+(e[0]-n)*t,e[1]=n+(e[1]-n)*t,e[2]=n+(e[2]-n)*t}var Zo=null,Qo=null;async function $o(){if(!Zo){let[e,t]=await Promise.all([import(`oidn-web`),import(`@tensorflow/tfjs-core`)]);Zo=e.initUNetFromURL,Qo=t.engine}return Zo}function es(){if(Qo)try{let e=Qo();e?.registryFactory&&`webgpu-oidn`in e.registryFactory&&e.removeBackend(`webgpu-oidn`)}catch(e){console.warn(`OIDNDenoiser: failed to clear cached TFJS backend`,e)}}var $=new Float32Array(3),ts={BASE_URL:`https://cdn.jsdelivr.net/npm/denoiser/tzas/`,QUALITY_MODELS:{fast:`rt_hdr_alb_nrm_small`,balance:`rt_hdr_alb_nrm`,high:`rt_hdr_calb_cnrm_large`},DEFAULT_OPTIONS:{enableOIDN:!0,oidnQuality:`fast`,debugGbufferMaps:!0,tileSize:256}},ns=class extends r.EventDispatcher{constructor(e,t,n,i,a={}){if(super(),!e||!t||!n||!i)throw Error(`OIDNDenoiser requires output canvas, renderer, scene, and camera`);this.renderer=t,this.scene=n,this.camera=i,this.input=t.domElement,this.output=e,this.debugContainer=a.debugContainer||null,this.extractGBufferData=a.extractGBufferData||null,this.getMRTRenderTarget=a.getMRTRenderTarget||null,this.backendParamsGetter=a.backendParams||null,this.getGPUTextures=a.getGPUTextures||null,this.getExposure=a.getExposure||(()=>1),this.getToneMapping=a.getToneMapping||(()=>r.ACESFilmicToneMapping),this.getSaturation=a.getSaturation||(()=>1),this.getTransparentBackground=a.getTransparentBackground||(()=>!1),this.isGPUMode=!!this.backendParamsGetter,this.gpuDevice=null,this._gpuInputBuffers={color:null,albedo:null,normal:null},this._gpuInputBufferSize={width:0,height:0},this._gpuInputPadBuffer=null,this._gpuInputPaddedRowBytes=0,this._alphaReadbackBuffer=null,this._alphaReadbackMapped=!1,this._cachedAlpha=null,this._cachedAlphaWidth=0,this.config={...ts.DEFAULT_OPTIONS,...a},this.enabled=this.config.enableOIDN,this.quality=this.config.oidnQuality,this.debugGbufferMaps=this.config.debugGbufferMaps,this.tileSize=this.config.tileSize,this.state={isDenoising:!1,isLoading:!1,abortController:null},this._pendingStagingBuffers=new Set,this.currentTZAUrl=null,this.unet=null,this.debugHelpers=null,this._lastAlbedoTexture=null,this._lastNormalTexture=null,this._initialize().catch(e=>{console.error(`Failed to initialize OIDNDenoiser:`,e),this.dispatchEvent({type:`error`,error:e})})}async _initialize(){try{this._setupCanvas(),this._initDebugVisualization(),await this._setupUNetDenoiser()}catch(e){throw Error(`Initialization failed: ${e.message}`)}}_initDebugVisualization(){this.debugHelpers=null}_setupCanvas(){if(!this.output.getContext)throw Error(`Output must be a valid Canvas element`);this.output.willReadFrequently=!0,this.output.width=this.input.width,this.output.height=this.input.height,Object.assign(this.output.style,{position:`absolute`,top:`0`,left:`0`,width:`100%`,height:`100%`,borderRadius:`5px`,background:`repeating-conic-gradient(#808080 0% 25%, transparent 0% 50%) 50% / 20px 20px`}),this.ctx=this.output.getContext(`2d`,{willReadFrequently:!0,alpha:!0})}async _setupUNetDenoiser(){if(this.state.isLoading)return;this.state.isLoading=!0;let e=this._generateTzaUrl();if(this.currentTZAUrl===e&&this.unet){this.state.isLoading=!1;return}try{this.dispatchEvent({type:`loading`,message:`Loading UNet denoiser...`}),this.unet&&=(this.unet.dispose(),null);let t;if(this.isGPUMode&&this.backendParamsGetter){let e=this.backendParamsGetter();this.gpuDevice=e?.device??null,t=e?.device?e:void 0}this.unet=await(await $o())(e,t,{aux:!0,hdr:!0,maxTileSize:this.tileSize}),this.currentTZAUrl=e,this.dispatchEvent({type:`loaded`}),console.log(`UNet denoiser loaded successfully:`,e)}catch(e){console.error(`Failed to load UNet denoiser:`,e),this.dispatchEvent({type:`error`,error:Error(`Denoiser loading failed: ${e.message}`)})}finally{this.state.isLoading=!1}}_generateTzaUrl(){let{BASE_URL:e,QUALITY_MODELS:t}=ts;return`${e}${t[this.quality]||t.balance}.tza`}async updateConfiguration(e){Object.keys(e).some(t=>this.config[t]!==e[t])&&(Object.assign(this.config,e),this.quality=this.config.oidnQuality,this.debugGbufferMaps=this.config.debugGbufferMaps,this.tileSize=this.config.tileSize,await this._setupUNetDenoiser())}async updateQuality(e){if(!Object.prototype.hasOwnProperty.call(ts.QUALITY_MODELS,e))throw Error(`Invalid quality setting: ${e}. Must be one of: ${Object.keys(ts.QUALITY_MODELS).join(`, `)}`);await this.updateConfiguration({oidnQuality:e})}async start(){if(!this.enabled||this.state.isDenoising||this.state.isLoading)return!1;this.dispatchEvent({type:`start`});let e=performance.now(),t=await this.execute();if(t){this.renderer?.resetState?.(),this.input.style.opacity=`0`;let t=performance.now()-e;console.log(`Denoising completed in ${t.toFixed(1)}ms (quality: ${this.quality})`)}return t}async execute(){if(!this.enabled||!this.unet)return!1;this.state.abortController=new AbortController,this.state.isDenoising=!0,this.input.style.opacity=`0`,this.output.style.display=`block`;try{return await this._executeUNet(),!0}catch(e){return e.name===`AbortError`?console.log(`Denoising was aborted`):console.error(`Denoising error:`,e),this.input.style.opacity=`1`,!1}finally{this.state.isDenoising=!1,this.state.abortController=null,this.dispatchEvent({type:`end`})}}async _executeUNet(){return this._executeUNetGPU()}async _executeUNetGPU(){let{width:e,height:t}=this.output;if(!this.getGPUTextures)return console.warn(`OIDNDenoiser: GPU mode enabled but getGPUTextures not provided`),!1;let n=this.getGPUTextures();if(!n?.color)return console.warn(`OIDNDenoiser: GPU textures not ready yet`),!1;let r=this.gpuDevice;if(!r)return console.warn(`OIDNDenoiser: gpuDevice not available`),!1;this._ensureGPUInputBuffers(e,t);let i=r.createCommandEncoder({label:`oidn-tex-to-buf`}),a=e*16,o=this._gpuInputPaddedRowBytes,s=o>a,c=this._gpuInputPadBuffer,l=(n,r)=>{if(!s)i.copyTextureToBuffer({texture:n,mipLevel:0},{buffer:r,offset:0,bytesPerRow:a,rowsPerImage:t},{width:e,height:t,depthOrArrayLayers:1});else{i.copyTextureToBuffer({texture:n,mipLevel:0},{buffer:c,offset:0,bytesPerRow:o,rowsPerImage:t},{width:e,height:t,depthOrArrayLayers:1});for(let e=0;e<t;e++)i.copyBufferToBuffer(c,e*o,r,e*a,a)}};l(n.color,this._gpuInputBuffers.color),l(n.albedo,this._gpuInputBuffers.albedo),l(n.normal,this._gpuInputBuffers.normal),r.queue.submit([i.finish()]),this.getTransparentBackground()?await this._cacheInputAlpha(r,e,t):this._cachedAlpha=null,this.ctx.drawImage(this.input,0,0,e,t);let u={color:{data:this._gpuInputBuffers.color,width:e,height:t},albedo:{data:this._gpuInputBuffers.albedo,width:e,height:t},normal:{data:this._gpuInputBuffers.normal,width:e,height:t}};return this._executeWithAbortGPU(u)}_ensureGPUInputBuffers(e,t){let{width:n,height:r}=this._gpuInputBufferSize;if(n===e&&r===t&&this._gpuInputBuffers.color)return;this._destroyGPUInputBuffers();let i=this.gpuDevice,a=e*t*16,o=GPUBufferUsage.COPY_DST|GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_SRC;this._gpuInputBuffers.color=i.createBuffer({label:`oidn-in-color`,size:a,usage:o}),this._gpuInputBuffers.albedo=i.createBuffer({label:`oidn-in-albedo`,size:a,usage:o}),this._gpuInputBuffers.normal=i.createBuffer({label:`oidn-in-normal`,size:a,usage:o}),this._gpuInputBufferSize={width:e,height:t};let s=e*16,c=Math.ceil(s/256)*256;c===s?this._gpuInputPaddedRowBytes=s:(this._gpuInputPadBuffer=i.createBuffer({label:`oidn-in-pad`,size:c*t,usage:GPUBufferUsage.COPY_DST|GPUBufferUsage.COPY_SRC}),this._gpuInputPaddedRowBytes=c)}_destroyGPUInputBuffers(){if(this._gpuInputBuffers.color?.destroy(),this._gpuInputBuffers.albedo?.destroy(),this._gpuInputBuffers.normal?.destroy(),this._gpuInputPadBuffer?.destroy(),this._alphaReadbackMapped&&this._alphaReadbackBuffer)try{this._alphaReadbackBuffer.unmap()}catch{}this._alphaReadbackBuffer?.destroy(),this._alphaReadbackMapped=!1,this._gpuInputBuffers={color:null,albedo:null,normal:null},this._gpuInputPadBuffer=null,this._gpuInputPaddedRowBytes=0,this._alphaReadbackBuffer=null,this._gpuInputBufferSize={width:0,height:0}}async _cacheInputAlpha(e,t,n){let r=t*n*16;this._alphaReadbackBuffer===null&&(this._alphaReadbackBuffer=e.createBuffer({label:`oidn-alpha-readback`,size:r,usage:GPUBufferUsage.MAP_READ|GPUBufferUsage.COPY_DST}));let i=this._alphaReadbackBuffer,a=e.createCommandEncoder();a.copyBufferToBuffer(this._gpuInputBuffers.color,0,i,0,r),e.queue.submit([a.finish()]),this._alphaReadbackMapped=!0;try{await i.mapAsync(GPUMapMode.READ)}catch{this._alphaReadbackMapped=!1;return}let o=new Float32Array(i.getMappedRange()),s=t*n,c=new Uint8Array(s);for(let e=0;e<s;e++)c[e]=Math.min(Math.max(o[e*4+3]*255,0),255)|0;i.unmap(),this._alphaReadbackMapped=!1,this._cachedAlpha=c,this._cachedAlphaWidth=t}_executeWithAbortGPU(e){return new Promise((t,n)=>{if(this.state.abortController?.signal.aborted){n(new DOMException(`Aborted`,`AbortError`));return}let i=null,a=()=>{i&&=(i(),null),n(new DOMException(`Aborted`,`AbortError`))};this.state.abortController.signal.addEventListener(`abort`,a,{once:!0}),i=this.unet.tileExecute({...e,done:async e=>{this.state.abortController.signal.removeEventListener(`abort`,a),i=null;try{await this._displayGPUOutput(e),t()}catch(e){n(e)}},progress:(e,t,n)=>{if(!e?.data||!n)return;let i=this.gpuDevice,a=e.width,o=e.height,s=Math.min(n.width,a-n.x),c=Math.min(n.height,o-n.y);if(s<=0||c<=0)return;let l=s*16,u=s*c*16,d=i.createBuffer({size:u,usage:GPUBufferUsage.MAP_READ|GPUBufferUsage.COPY_DST});this._pendingStagingBuffers.add(d);let f=i.createCommandEncoder();for(let t=0;t<c;t++){let r=((n.y+t)*a+n.x)*16,i=t*l;f.copyBufferToBuffer(e.data,r,d,i,l)}i.queue.submit([f.finish()]),d.mapAsync(GPUMapMode.READ).then(()=>{let e=new Float32Array(d.getMappedRange()),t=new ImageData(s,c),i=this.getExposure(),l=this.getSaturation(),u=Wo.get(this.getToneMapping())||Wo.get(r.ACESFilmicToneMapping),f=this._cachedAlpha,p=this._cachedAlphaWidth;for(let r=0,a=e.length;r<a;r+=4){let a=e[r]*i,o=e[r+1]*i,c=e[r+2]*i;if(l!==1&&($[0]=a,$[1]=o,$[2]=c,Xo($,l),a=$[0],o=$[1],c=$[2]),u(a,o,c,1,$),t.data[r]=Ko($[0])*255+.5|0,t.data[r+1]=Ko($[1])*255+.5|0,t.data[r+2]=Ko($[2])*255+.5|0,f){let e=(r>>2)%s,i=(r>>2)/s|0;t.data[r+3]=f[(n.y+i)*p+n.x+e]}else t.data[r+3]=255}d.unmap(),d.destroy(),this._pendingStagingBuffers.delete(d),this.ctx.putImageData(t,n.x,n.y),this.dispatchEvent({type:`tileProgress`,tile:{x:n.x,y:n.y,width:s,height:c},imageWidth:a,imageHeight:o})}).catch(()=>{d.destroy(),this._pendingStagingBuffers.delete(d)})}})})}async _displayGPUOutput({data:e,width:t,height:n}){let i=this.gpuDevice;if(!i){console.error(`OIDNDenoiser: gpuDevice not available for output readback`);return}let a=t*n*4*4,o=i.createBuffer({label:`oidn-output-staging`,size:a,usage:GPUBufferUsage.MAP_READ|GPUBufferUsage.COPY_DST});try{let s=i.createCommandEncoder({label:`oidn-readback`});s.copyBufferToBuffer(e,0,o,0,a),i.queue.submit([s.finish()]),await o.mapAsync(GPUMapMode.READ);let c=new Float32Array(o.getMappedRange()),l=new ImageData(t,n),u=this.getExposure(),d=this.getSaturation(),f=Wo.get(this.getToneMapping())||Wo.get(r.ACESFilmicToneMapping),p=this._cachedAlpha;for(let e=0,t=c.length;e<t;e+=4){let t=c[e]*u,n=c[e+1]*u,r=c[e+2]*u;d!==1&&($[0]=t,$[1]=n,$[2]=r,Xo($,d),t=$[0],n=$[1],r=$[2]),f(t,n,r,1,$),l.data[e]=Ko($[0])*255+.5|0,l.data[e+1]=Ko($[1])*255+.5|0,l.data[e+2]=Ko($[2])*255+.5|0,l.data[e+3]=p?p[e>>2]:255}o.unmap(),this.ctx.putImageData(l,0,0)}finally{o.destroy()}}abort(){!this.enabled||!this.state.isDenoising||(this.state.abortController?.abort(),this._destroyPendingStagingBuffers(),this.input.style.opacity=`1`,this.state.isDenoising=!1,this.dispatchEvent({type:`end`}),console.log(`Denoising aborted`))}setSize(e,t){if(e<=0||t<=0)throw Error(`Invalid dimensions: ${e}x${t}`);this.output.width=e,this.output.height=t,this._setupUNetDenoiser().catch(e=>{console.error(`Failed to reinitialize denoiser after size change:`,e)})}_updateDebugVisualization(e){if(!e?.textures||e.textures.length<3)return;let t=this.debugHelpers&&(this._lastAlbedoTexture!==e.textures[2]||this._lastNormalTexture!==e.textures[1]);if(!this.debugHelpers||t){this.debugHelpers&&(this.debugHelpers.albedo?.dispose(),this.debugHelpers.normal?.dispose(),console.log(`OIDNDenoiser: Recreating debug helpers due to texture change`)),this.debugHelpers={albedo:ro(this.renderer,e,{width:250,height:250,position:`bottom-right`,theme:`dark`,title:`OIDN Albedo`,autoUpdate:!1,textureIndex:2}),normal:ro(this.renderer,e,{width:250,height:250,position:`bottom-left`,theme:`dark`,title:`OIDN Normal`,autoUpdate:!1,textureIndex:1})},this._lastAlbedoTexture=e.textures[2],this._lastNormalTexture=e.textures[1];let t=this.debugContainer||document.body;t.appendChild(this.debugHelpers.albedo),t.appendChild(this.debugHelpers.normal),this.debugHelpers.albedo.hide(),this.debugHelpers.normal.hide()}this.debugHelpers.albedo.update(),this.debugHelpers.normal.update()}_destroyPendingStagingBuffers(){for(let e of this._pendingStagingBuffers)e.destroy();this._pendingStagingBuffers.clear()}dispose(){this.abort(),this._destroyPendingStagingBuffers(),this.unet?.dispose(),es(),this._destroyGPUInputBuffers(),this.debugHelpers&&=(this.debugHelpers.albedo?.dispose(),this.debugHelpers.normal?.dispose(),null),this._lastAlbedoTexture=null,this._lastNormalTexture=null,this.output?.parentNode&&this.output.remove(),this.unet=null,this.ctx=null,this.state.abortController=null,this.removeAllListeners?.(),console.log(`OIDNDenoiser disposed`)}},rs=``+(typeof document>`u`&&typeof location>`u`?require(`url`).pathToFileURL(__dirname+`/assets/AIUpscalerWorker-D58dcMrY.js`).href:new URL(`assets/AIUpscalerWorker-D58dcMrY.js`,typeof document>`u`?location.href:document.currentScript&&document.currentScript.tagName.toUpperCase()===`SCRIPT`&&document.currentScript.src||document.baseURI).href),is=`https://huggingface.co/notaneimu/onnx-image-models/resolve/main/`,as={QUALITY_PRESETS:{fast:{2:is+`2x-spanx2-ch48.onnx`,4:is+`4xNomos8k_span_otf_strong_fp32_opset17.onnx`},balanced:{2:is+`2xNomosUni_compact_otf_medium.onnx`,4:is+`RealESRGAN_x4plus.onnx`},quality:{2:is+`2x-realesrgan-x2plus.onnx`,4:is+`4xNomos2_hq_mosr_fp32.onnx`}},TILE_SIZE:512,TILE_OVERLAP:16,SESSION_OPTIONS:{executionProviders:[{name:`webgpu`,preferredLayout:`NCHW`}],graphOptimizationLevel:`all`}},os=class extends r.EventDispatcher{constructor(e,t,n={}){if(super(),!e||!t)throw Error(`AIUpscaler requires output canvas and renderer`);this.renderer=t,this.input=t.domElement,this.output=e,this.getSourceCanvas=n.getSourceCanvas||null,this.getGPUTextures=n.getGPUTextures||null,this.getExposure=n.getExposure||(()=>1),this.getToneMapping=n.getToneMapping||(()=>r.ACESFilmicToneMapping),this.getSaturation=n.getSaturation||(()=>1),this.enabled=!1,this.hdr=!1,this.scaleFactor=n.scaleFactor||2,this.quality=n.quality||`fast`,this.tileSize=n.tileSize||as.TILE_SIZE,this._tileSizeOverride=!!n.tileSize,this.state={isUpscaling:!1,isLoading:!1,abortController:null},this._worker=null,this._currentModelUrl=null,this._tileId=0,this._pendingWorkerHandlers=new Set,this._upscaledAlpha=null,this._upscaledAlphaWidth=0,this._backupCanvas=null,this._baseWidth=e.width,this._baseHeight=e.height,this._hdrStagingBuffer=null,this._hdrStagingWidth=0,this._hdrStagingHeight=0}async _ensureSession(){let e=as.QUALITY_PRESETS[this.quality];if(!e)throw Error(`Unknown quality preset: ${this.quality}`);let t=e[this.scaleFactor];if(!t)throw Error(`No model for ${this.quality}/${this.scaleFactor}x`);if(!(this._worker&&this._currentModelUrl===t)){this.state.isLoading=!0,this.dispatchEvent({type:`loading`,message:`Loading ${this.scaleFactor}x upscale model...`});try{if(!this._worker)try{this._worker=new Worker(rs,{type:`module`})}catch(e){if(e.name!==`SecurityError`)throw e;this._worker=await Ze(rs)}await new Promise((e,n)=>{let r=t=>{t.data.type===`loaded`?(this._worker.removeEventListener(`message`,r),t.data.tileSize&&!this._tileSizeOverride&&(this.tileSize=t.data.tileSize),console.log(`AI Upscaler: ${this.scaleFactor}x model loaded, backend: ${t.data.backend}, tileSize: ${this.tileSize}`),e()):t.data.type===`error`&&(this._worker.removeEventListener(`message`,r),n(Error(t.data.message)))};this._worker.addEventListener(`message`,r),this._worker.postMessage({type:`load`,url:t,sessionOptions:as.SESSION_OPTIONS})}),this._currentModelUrl=t,this.dispatchEvent({type:`loaded`})}catch(e){throw console.error(`AI Upscaler: Failed to load model:`,e),this.dispatchEvent({type:`error`,error:e}),e}finally{this.state.isLoading=!1}}}async start(){if(!this.enabled||this.state.isUpscaling||this.state.isLoading)return!1;this.dispatchEvent({type:`start`});let e=performance.now(),t=await this.execute();if(t){this.renderer?.resetState?.();let t=performance.now()-e;console.log(`AI Upscaler: ${this.scaleFactor}x upscale completed in ${t.toFixed(1)}ms`)}return t}async execute(){if(!this.enabled)return!1;this.state.abortController=new AbortController,this.state.isUpscaling=!0,this.input.style.opacity=`0`,this.output.style.display=`block`,this.hdr&&this.getGPUTextures?this._capturedSource=await this._captureSourceHDR():this._capturedSource=this._captureSource(),this._createBackup(this._capturedSource);let e=this._capturedSource.width*this.scaleFactor,t=this._capturedSource.height*this.scaleFactor;this.output.width=e,this.output.height=t;let n=this.output.getContext(`2d`,{willReadFrequently:!0,alpha:!0});n.imageSmoothingEnabled=!0,n.imageSmoothingQuality=`high`,n.drawImage(this._backupCanvas,0,0,e,t);try{return await this._ensureSession(),await this._runUpscale(),this.dispatchEvent({type:`resolution_changed`,width:this.output.width,height:this.output.height}),!0}catch(e){return e.name===`AbortError`?console.log(`AI Upscaler: Upscaling was aborted`):(console.error(`AI Upscaler: Upscaling error:`,e),this.dispatchEvent({type:`error`,error:e}),this._restoreBackup(),this.input.style.opacity=`1`,this.dispatchEvent({type:`resolution_changed`,width:this._baseWidth,height:this._baseHeight})),!1}finally{this._capturedSource=null,this._upscaledAlpha=null,this._backupCanvas=null,this.state.isUpscaling&&(this.state.isUpscaling=!1,this.state.abortController=null,this.dispatchEvent({type:`end`}))}}abort(){this.state.isUpscaling&&(this.state.abortController?.abort(),this._cleanupPendingWorkerHandlers(),this.input.style.opacity=`1`,this._restoreBackup(),this.dispatchEvent({type:`resolution_changed`,width:this._baseWidth,height:this._baseHeight}),this.state.isUpscaling=!1,this.dispatchEvent({type:`end`}),console.log(`AI Upscaler: Aborted`))}async _runUpscale(){let e=this.state.abortController.signal,t=this._capturedSource;this._capturedSource=null;let{width:n,height:i}=t,a=this.scaleFactor,o=this.output.getContext(`2d`,{willReadFrequently:!0,alpha:!0});this._cacheUpscaledAlpha(t,n*a,i*a),t.isHDR&&(this._hdrToneMapFn=Wo.get(this.getToneMapping())||Wo.get(r.ACESFilmicToneMapping),this._hdrExposure=this.getExposure(),this._hdrSaturation=this.getSaturation(),this._tmOut=new Float32Array(3));let s=as.TILE_OVERLAP,c=this.tileSize,l=c-s*2,u=Math.ceil(n/l),d=Math.ceil(i/l),f=u*d,p=0;for(let r=0;r<d;r++)for(let s=0;s<u;s++){if(e.aborted)throw new DOMException(`Aborted`,`AbortError`);let u=Math.min(s*l,Math.max(0,n-c)),d=Math.min(r*l,Math.max(0,i-c)),m=Math.min(c,n-u),h=Math.min(c,i-d),g=this._extractTile(t,u,d,m,h),_=await this._inferTile(g,m,h),v=u*a,y=d*a,b=m*a,x=h*a,S=this._tensorToImageData(_,b,x,v,y);o.putImageData(S,v,y),p++,this.dispatchEvent({type:`progress`,progress:p/f,tile:{x:s,y:r,total:f,completed:p}}),this.dispatchEvent({type:`tileProgress`,tile:{x:v,y,width:b,height:x},imageWidth:n*a,imageHeight:i*a})}}_captureSource(){let e=this.getSourceCanvas?this.getSourceCanvas():null;if(e&&e!==this.output){let t=document.createElement(`canvas`);t.width=e.width,t.height=e.height;let n=t.getContext(`2d`);return n.drawImage(e,0,0),n.getImageData(0,0,t.width,t.height)}return this.output.getContext(`2d`,{willReadFrequently:!0}).getImageData(0,0,this.output.width,this.output.height)}async _captureSourceHDR(){let e=this.getGPUTextures();if(!e?.color)throw Error(`No GPU color texture available for HDR capture`);let t=this.renderer.backend.device,n=e.color,r=n.width,i=n.height,a=Math.ceil(r*16/256)*256,o=a*i;(this._hdrStagingWidth!==r||this._hdrStagingHeight!==i)&&(this._hdrStagingBuffer?.destroy(),this._hdrStagingBuffer=t.createBuffer({label:`aiupscaler-hdr-readback`,size:o,usage:GPUBufferUsage.MAP_READ|GPUBufferUsage.COPY_DST}),this._hdrStagingWidth=r,this._hdrStagingHeight=i);let s=this._hdrStagingBuffer,c=t.createCommandEncoder();c.copyTextureToBuffer({texture:n},{buffer:s,bytesPerRow:a,rowsPerImage:i},{width:r,height:i,depthOrArrayLayers:1}),t.queue.submit([c.finish()]),await s.mapAsync(GPUMapMode.READ);let l=new Float32Array(s.getMappedRange()),u=r*4,d=a/4,f=new Float32Array(r*i*4);for(let e=0;e<i;e++){let t=e*d,n=e*u;f.set(l.subarray(t,t+u),n)}return s.unmap(),{data:f,width:r,height:i,isHDR:!0}}_extractTile(e,t,n,r,i){let{data:a,width:o}=e,s=e.isHDR,c=r*i,l=new Float32Array(3*c);for(let e=0;e<i;e++)for(let i=0;i<r;i++){let u=((n+e)*o+(t+i))*4,d=e*r+i;if(s){let e=this._hdrToneMapFn,t=this._hdrExposure,n=this._hdrSaturation,r=a[u]*t,i=a[u+1]*t,o=a[u+2]*t;n!==1&&(this._tmOut[0]=r,this._tmOut[1]=i,this._tmOut[2]=o,Xo(this._tmOut,n),r=this._tmOut[0],i=this._tmOut[1],o=this._tmOut[2]),e(r,i,o,1,this._tmOut),l[d]=this._tmOut[0]**+Go,l[c+d]=this._tmOut[1]**+Go,l[2*c+d]=this._tmOut[2]**+Go}else l[d]=a[u]/255,l[c+d]=a[u+1]/255,l[2*c+d]=a[u+2]/255}return l}async _inferTile(e,t,n){let r=++this._tileId;return new Promise((i,a)=>{let o=e=>{e.data.id===r&&(this._worker.removeEventListener(`message`,o),this._pendingWorkerHandlers.delete(o),e.data.type===`inferred`?i(e.data.outputData):e.data.type===`error`&&a(Error(e.data.message)))};this._pendingWorkerHandlers.add(o),this._worker.addEventListener(`message`,o),this._worker.postMessage({type:`infer`,tileData:e,width:t,height:n,id:r},[e.buffer])})}_tensorToImageData(e,t,n,r,i){let a=new ImageData(t,n),o=a.data,s=t*n,c=this._upscaledAlpha,l=this._upscaledAlphaWidth;for(let n=0;n<s;n++)if(o[n*4]=Math.min(255,Math.max(0,e[n]*255+.5))|0,o[n*4+1]=Math.min(255,Math.max(0,e[s+n]*255+.5))|0,o[n*4+2]=Math.min(255,Math.max(0,e[2*s+n]*255+.5))|0,c){let e=n/t|0,a=n%t;o[n*4+3]=c[(i+e)*l+(r+a)]}else o[n*4+3]=255;return a}_cacheUpscaledAlpha(e,t,n){let{data:r,width:i,height:a}=e,o=e.isHDR,s=o?1:255,c=!1;for(let e=3;e<r.length;e+=4)if(r[e]<s){c=!0;break}if(!c){this._upscaledAlpha=null,this._upscaledAlphaWidth=0;return}let l=document.createElement(`canvas`);l.width=i,l.height=a;let u=l.getContext(`2d`),d=u.createImageData(i,a);for(let e=0,t=i*a;e<t;e++){let t=o?Math.min(Math.max(r[e*4+3]*255,0),255)|0:r[e*4+3];d.data[e*4]=t,d.data[e*4+1]=t,d.data[e*4+2]=t,d.data[e*4+3]=255}u.putImageData(d,0,0);let f=document.createElement(`canvas`);f.width=t,f.height=n;let p=f.getContext(`2d`);p.imageSmoothingEnabled=!0,p.imageSmoothingQuality=`high`,p.drawImage(l,0,0,t,n);let m=p.getImageData(0,0,t,n).data,h=new Uint8Array(t*n);for(let e=0,r=t*n;e<r;e++)h[e]=m[e*4];this._upscaledAlpha=h,this._upscaledAlphaWidth=t}_createBackup(e){this._backupCanvas=document.createElement(`canvas`),this._backupCanvas.width=e.width,this._backupCanvas.height=e.height;let t=this._backupCanvas.getContext(`2d`);if(e.isHDR){let{data:n,width:i,height:a}=e,o=t.createImageData(i,a),s=o.data,c=Wo.get(this.getToneMapping())||Wo.get(r.ACESFilmicToneMapping),l=this.getExposure(),u=this.getSaturation(),d=new Float32Array(3);for(let e=0,t=i*a;e<t;e++){let t=e*4,r=n[t]*l,i=n[t+1]*l,a=n[t+2]*l;u!==1&&(d[0]=r,d[1]=i,d[2]=a,Xo(d,u),r=d[0],i=d[1],a=d[2]),c(r,i,a,1,d),s[t]=d[0]**+Go*255+.5|0,s[t+1]=d[1]**+Go*255+.5|0,s[t+2]=d[2]**+Go*255+.5|0,s[t+3]=255}t.putImageData(o,0,0)}else t.putImageData(e,0,0)}_restoreBackup(){this._backupCanvas&&=(this.output.width=this._backupCanvas.width,this.output.height=this._backupCanvas.height,this.output.getContext(`2d`).drawImage(this._backupCanvas,0,0),null)}toggleHDR(e){this.hdr=!!e}setQuality(e){if(!as.QUALITY_PRESETS[e]){console.warn(`AIUpscaler: Invalid quality "${e}", must be fast/balanced/quality`);return}this.quality=e}setScaleFactor(e){if(e=Number(e),e!==2&&e!==4){console.warn(`AIUpscaler: Invalid scale factor ${e}, must be 2 or 4`);return}this.scaleFactor=e}setBaseSize(e,t){this._baseWidth=e,this._baseHeight=t}_cleanupPendingWorkerHandlers(){if(this._worker)for(let e of this._pendingWorkerHandlers)this._worker.removeEventListener(`message`,e);this._pendingWorkerHandlers.clear()}async dispose(){this.abort(),this._cleanupPendingWorkerHandlers(),this._worker&&=(this._worker.postMessage({type:`dispose`}),this._worker.terminate(),null),this._currentModelUrl=null,this._backupCanvas=null,this._upscaledAlpha=null,this.state.abortController=null,this._hdrStagingBuffer?.destroy(),this._hdrStagingBuffer=null,this._hdrStagingWidth=0,this._hdrStagingHeight=0,console.log(`AIUpscaler disposed`)}},ss=class extends r.EventDispatcher{constructor({renderer:e,mainCanvas:t,scene:n,camera:r,stages:i,pipeline:a,getExposure:o,getSaturation:s,getTransparentBg:c}){super(),this.renderer=e,this.mainCanvas=t,this.denoiserCanvas=this._createDenoiserCanvas(t),this.scene=n,this.camera=r,this.pipeline=a,this._stages=i,this._getExposure=o,this._getSaturation=s,this._getTransparentBg=c,this.denoiser=null,this.upscaler=null,this._lastRenderWidth=0,this._lastRenderHeight=0,this._pendingStartUpscaler=null,this._denoiserStartHandler=null,this._denoiserEndHandler=null,this._upscalerResChangedHandler=null,this._upscalerStartHandler=null,this._upscalerProgressHandler=null,this._upscalerEndHandler=null}_createDenoiserCanvas(e){let t=e.parentNode;if(!t)return null;let n=document.createElement(`canvas`);return n.width=e.width,n.height=e.height,n.style.position=`absolute`,n.style.inset=`0`,n.style.width=`100%`,n.style.height=`100%`,t.insertBefore(n,e),n}setRenderSize(e,t){this._lastRenderWidth=e,this._lastRenderHeight=t,this.denoiser?.setSize(e,t),this.upscaler?.setBaseSize(e,t)}restoreBaseResolution(){if(!this.denoiserCanvas||!this._lastRenderWidth||!this._lastRenderHeight)return!1;let e=this.denoiserCanvas.width!==this._lastRenderWidth||this.denoiserCanvas.height!==this._lastRenderHeight;return this.denoiserCanvas.width=this._lastRenderWidth,this.denoiserCanvas.height=this._lastRenderHeight,e}setupDenoiser(){if(!this.denoiserCanvas)return;let e=this._stages.pathTracer;this.denoiser=new ns(this.denoiserCanvas,this.renderer,this.scene,this.camera,{...z,backendParams:()=>({device:this.renderer.backend.device,adapterInfo:null}),getGPUTextures:()=>{if(!e?.storageTextures?.readTarget)return null;let t=e.storageTextures.getReadTextures(),{backend:n}=this.renderer;return{color:n.get(t.color).texture,normal:n.get(t.normalDepth).texture,albedo:n.get(t.albedo).texture}},getExposure:()=>this._getEffectiveExposure(),getToneMapping:()=>this._getToneMapping(),getSaturation:()=>this._getSaturation(),getTransparentBackground:()=>this._getTransparentBg(),getMRTRenderTarget:()=>e?.storageTextures?.readTarget??null}),this.denoiser.enabled=z.enableOIDN,this._denoiserStartHandler=()=>this.dispatchEvent({type:L.DENOISING_START}),this._denoiserEndHandler=()=>this.dispatchEvent({type:L.DENOISING_END}),this.denoiser.addEventListener(`start`,this._denoiserStartHandler),this.denoiser.addEventListener(`end`,this._denoiserEndHandler)}setupUpscaler(){if(!this.denoiserCanvas)return;let e=this._stages.pathTracer;this.upscaler=new os(this.denoiserCanvas,this.renderer,{scaleFactor:z.upscalerScale||2,quality:z.upscalerQuality||`fast`,getSourceCanvas:()=>this.denoiser?.enabled?null:this.renderer.domElement,getGPUTextures:()=>{if(!e?.storageTextures?.readTarget)return null;let t=e.storageTextures.getReadTextures();return{color:this.renderer.backend.get(t.color).texture}},getExposure:()=>this._getEffectiveExposure(),getToneMapping:()=>this._getToneMapping(),getSaturation:()=>this._getSaturation()}),this.upscaler.enabled=z.enableUpscaler||!1,this._upscalerResChangedHandler=e=>this.dispatchEvent({type:`resolution_changed`,width:e.width,height:e.height}),this._upscalerStartHandler=()=>this.dispatchEvent({type:L.UPSCALING_START}),this._upscalerProgressHandler=e=>this.dispatchEvent({type:L.UPSCALING_PROGRESS,progress:e.progress}),this._upscalerEndHandler=()=>this.dispatchEvent({type:L.UPSCALING_END}),this.upscaler.addEventListener(`resolution_changed`,this._upscalerResChangedHandler),this.upscaler.addEventListener(`start`,this._upscalerStartHandler),this.upscaler.addEventListener(`progress`,this._upscalerProgressHandler),this.upscaler.addEventListener(`end`,this._upscalerEndHandler)}setDenoiserStrategy(e,t){let n=this._stages;switch(n.asvgf&&(n.asvgf.enabled=!1),n.variance&&!this._isAdaptiveSamplingActive()&&(n.variance.enabled=!1),n.bilateralFilter&&(n.bilateralFilter.enabled=!1),n.edgeFilter&&n.edgeFilter.setFilteringEnabled(!1),n.ssrc&&(n.ssrc.enabled=!1),this._clearDenoiserTextures(),e){case`asvgf`:n.asvgf.enabled=!0,n.variance&&(n.variance.enabled=!0),n.bilateralFilter&&(n.bilateralFilter.enabled=!0),n.asvgf.setTemporalEnabled?.(!0),this._applyASVGFPreset(t||`medium`);break;case`ssrc`:n.ssrc&&(n.ssrc.enabled=!0);break;case`edgeaware`:n.edgeFilter&&n.edgeFilter.setFilteringEnabled(!0);break}}setASVGFEnabled(e,t){let n=this._stages;n.asvgf&&(n.asvgf.enabled=e),n.variance&&(n.variance.enabled=e),n.bilateralFilter&&(n.bilateralFilter.enabled=e),e&&(n.asvgf?.setTemporalEnabled?.(!0),this._applyASVGFPreset(t||`medium`)),n.edgeFilter&&n.edgeFilter.setFilteringEnabled(!e)}applyASVGFPreset(e){this._applyASVGFPreset(e)}setAutoExposureEnabled(e,t){let n=this._stages;n.autoExposure&&(n.autoExposure.enabled=e,!e&&this.renderer&&(this.renderer.toneMappingExposure=t))}setAdaptiveSamplingEnabled(e){let t=this._stages;t.adaptiveSampling&&(t.adaptiveSampling.enabled=e,t.adaptiveSampling.toggleHelper(!1)),e?t.variance&&(t.variance.enabled=!0):t.asvgf?.enabled||t.variance&&(t.variance.enabled=!1),!e&&this.pipeline?.context&&!t.asvgf?.enabled&&this.pipeline.context.removeTexture(`variance:output`)}_cleanupCompletionListener(){this._pendingStartUpscaler&&this.denoiser&&this.denoiser.removeEventListener(`end`,this._pendingStartUpscaler),this._pendingStartUpscaler=null}onRenderComplete({isStillComplete:e,context:t}){this._cleanupCompletionListener(),(this.denoiser?.enabled||this.upscaler?.enabled)&&this.denoiserCanvas&&(this.denoiserCanvas.style.display=`block`);let n=()=>{this._pendingStartUpscaler=null,e()&&this.upscaler?.enabled&&this.upscaler.start()};this.denoiser?.enabled?(this._pendingStartUpscaler=n,this.denoiser.addEventListener(`end`,n,{once:!0}),this.denoiser.start()):(this.upscaler?.enabled&&this._stages.compositor&&t&&this._stages.compositor.render(t),n())}abort(e){this._cleanupCompletionListener(),e&&(e.style.opacity=`1`),this.upscaler&&this.upscaler.abort(),this.denoiser&&(this.denoiser.enabled&&this.denoiser.abort(),this.denoiser.output&&(this.denoiser.output.style.display=`none`))}dispose(){this._cleanupCompletionListener(),this.denoiser&&=(this._denoiserStartHandler&&this.denoiser.removeEventListener(`start`,this._denoiserStartHandler),this._denoiserEndHandler&&this.denoiser.removeEventListener(`end`,this._denoiserEndHandler),this.denoiser.dispose(),null),this.upscaler&&=(this._upscalerResChangedHandler&&this.upscaler.removeEventListener(`resolution_changed`,this._upscalerResChangedHandler),this._upscalerStartHandler&&this.upscaler.removeEventListener(`start`,this._upscalerStartHandler),this._upscalerProgressHandler&&this.upscaler.removeEventListener(`progress`,this._upscalerProgressHandler),this._upscalerEndHandler&&this.upscaler.removeEventListener(`end`,this._upscalerEndHandler),this.upscaler.dispose(),null),this._denoiserStartHandler=null,this._denoiserEndHandler=null,this._upscalerResChangedHandler=null,this._upscalerStartHandler=null,this._upscalerProgressHandler=null,this._upscalerEndHandler=null,this.denoiserCanvas?.parentNode&&(this.denoiserCanvas.parentNode.removeChild(this.denoiserCanvas),this.denoiserCanvas=null)}setOverlayManager(e){this._overlayManager=e}setResetCallback(e){this._onReset=e}setSettings(e){this._settings=e}setASVGFParams(e){this._stages.asvgf?.updateParameters(e)}toggleASVGFHeatmap(e){this._stages.asvgf?.toggleHeatmap?.(e)}configureASVGFForMode(e){this._stages.asvgf&&(this._stages.asvgf.enabled=e.enabled,this._stages.variance&&(this._stages.variance.enabled=e.enabled),this._stages.bilateralFilter&&(this._stages.bilateralFilter.enabled=e.enabled),e.enabled&&this._stages.asvgf.updateParameters(e))}setSSRCParams(e){this._stages.ssrc?.updateParameters(e)}setEdgeAwareParams(e){this._stages.edgeFilter?.updateUniforms(e)}setAutoExposureParams(e){this._stages.autoExposure?.updateParameters(e)}setAdaptiveSamplingParams(e){e.min!==void 0&&this._stages.pathTracer?.setAdaptiveSamplingMin(e.min),e.adaptiveSamplingMax!==void 0&&this._settings?.set(`adaptiveSamplingMax`,e.adaptiveSamplingMax),this._stages.adaptiveSampling?.setAdaptiveSamplingParameters(e)}toggleAdaptiveSamplingHelper(e){this._stages.adaptiveSampling?.toggleHelper(e)}setOIDNEnabled(e){this.denoiser&&(this.denoiser.enabled=e)}setOIDNQuality(e){this.denoiser?.updateQuality(e)}setOIDNTileHelper(e){this._setTileHelper(e)}setTileHelperEnabled(e){this._setTileHelper(e)}setTileHighlightEnabled(e){this._setTileHelper(e)}setUpscalerEnabled(e){this.upscaler&&(this.upscaler.enabled=e)}setUpscalerScaleFactor(e){this.upscaler?.setScaleFactor(e)}setUpscalerQuality(e){this.upscaler?.setQuality(e)}setAutoExposure(e){this.setAutoExposureEnabled(e,this._getExposure()),this._onReset?.()}setAdaptiveSampling(e){this._settings?.set(`useAdaptiveSampling`,e),this.setAdaptiveSamplingEnabled(e)}setStrategy(e,t){this.setDenoiserStrategy(e,t),this._onReset?.()}_setTileHelper(e){let t=this._overlayManager?.getHelper(`tiles`);t&&(t.enabled=e,e||t.hide())}_getEffectiveExposure(){return this._stages.autoExposure?.enabled?this.renderer.toneMappingExposure:this._getExposure()}_getToneMapping(){return this.renderer.toneMapping}_isAdaptiveSamplingActive(){return this._stages.adaptiveSampling?.enabled??!1}_clearDenoiserTextures(){let e=this.pipeline?.context;e&&[`asvgf:output`,`asvgf:temporalColor`,`asvgf:variance`,`variance:output`,`bilateralFiltering:output`,`edgeFiltering:output`,`ssrc:output`].forEach(t=>e.removeTexture(t))}_applyASVGFPreset(e){let t=Pe[e];t&&this._stages.asvgf?.updateParameters(t)}},cs=class{constructor(){this.layer=`hud`,this.visible=!1,this._tileBounds=null,this._imageWidth=1,this._imageHeight=1,this.enabled=!0,this._borderColor=`rgba(255, 0, 0, 0.6)`,this._borderWidthRatio=1/540,this._borderWidthMin=1.5,this._borderWidthMax=4}setActiveTile(e){this._tileBounds=e}setRenderSize(e,t){this._imageWidth=e,this._imageHeight=t}render(e,t,n){if(!this._tileBounds)return;let r=this._tileBounds,i=t/this._imageWidth,a=n/this._imageHeight,o=r.x*i,s=r.y*a,c=r.width*i,l=r.height*a,u=Math.min(this._borderWidthMax,Math.max(this._borderWidthMin,Math.min(t,n)*this._borderWidthRatio));e.strokeStyle=this._borderColor,e.lineWidth=u,e.strokeRect(o,s,c,l)}show(){this.enabled&&(this.visible=!0)}hide(){this.visible=!1,this._tileBounds=null}dispose(){this.visible=!1}},ls=class{constructor(e,i,a){this.layer=`scene`,this.visible=!0,this._outlineNode=(0,g.outline)(i,a,{selectedObjects:[],edgeThickness:(0,n.uniform)(1),edgeGlow:(0,n.uniform)(0)}),this._displayWidth=1,this._displayHeight=1;let o=this._outlineNode.setSize.bind(this._outlineNode);this._outlineNode.setSize=()=>{o(this._displayWidth,this._displayHeight)};let s=(0,n.uniform)(3),c=(0,n.uniform)(new r.Color(16777215)),l=(0,n.uniform)(new r.Color(1640965)),{visibleEdge:u,hiddenEdge:d}=this._outlineNode,f=u.mul(c).add(d.mul(l)).mul(s);this._material=new t.MeshBasicNodeMaterial,this._material.colorNode=(0,n.vec4)(f,1),this._material.blending=r.AdditiveBlending,this._material.toneMapped=!1,this._material.depthTest=!1,this._material.depthWrite=!1,this._quad=new t.QuadMesh(this._material)}setSelectedObjects(e){this._outlineNode.selectedObjects=e}render(e){if(this._outlineNode.selectedObjects.length===0)return;let t=e.autoClear;e.autoClear=!1,e.setRenderTarget(null),this._quad.render(e),e.autoClear=t}setSize(e,t){this._displayWidth=e,this._displayHeight=t,this._outlineNode.setSize(e,t)}show(){this.visible=!0}hide(){this.visible=!1}dispose(){this.visible=!1,this._outlineNode?.dispose(),this._material?.dispose(),this._quad=null}},us=class{constructor(e,t){this.renderer=e,this.camera=t,this._helpers=new Map,this._hudCanvas=document.createElement(`canvas`),this._hudCanvas.style.cssText=`position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;`,this._hudCtx=this._hudCanvas.getContext(`2d`),this._helperScene=null}setHelperScene(e){this._helperScene=e}getHUDCanvas(){return this._hudCanvas}setupDefaultHelpers({helperScene:e,meshScene:t,pipeline:n,denoisingManager:r,app:i,renderWidth:a,renderHeight:o}){this.setHelperScene(e);let s=new cs;this.register(`tiles`,s),s.setRenderSize(a||1,o||1),i.addEventListener(`resolution_changed`,e=>{s.setRenderSize(e.width,e.height)}),n.eventBus.on(`tile:changed`,e=>{e.renderMode===1&&e.tileBounds&&(s.setActiveTile(e.tileBounds),s.show())}),n.eventBus.on(`pipeline:reset`,()=>s.hide()),i.addEventListener(L.RENDER_COMPLETE,()=>s.hide()),this._wireDenoiserTileEvents(s,r);let c=new ls(this.renderer,t,this.camera);this.register(`outline`,c)}_wireDenoiserTileEvents(e,t){let n=[t?.denoiser,t?.upscaler];for(let t of n)t&&(t.addEventListener(`tileProgress`,t=>{t.tile&&(e.setRenderSize(t.imageWidth,t.imageHeight),e.setActiveTile(t.tile),e.show(),this.refreshHUD())}),t.addEventListener(`end`,()=>{e.hide(),this.refreshHUD()}))}register(e,t){this._helpers.has(e)&&(console.warn(`OverlayManager: helper "${e}" already registered — replacing.`),this._helpers.get(e).dispose?.()),this._helpers.set(e,t)}unregister(e){let t=this._helpers.get(e);t&&(t.dispose?.(),this._helpers.delete(e))}show(e){this._helpers.get(e)?.show()}hide(e){this._helpers.get(e)?.hide()}toggle(e){let t=this._helpers.get(e);t&&(t.visible?t.hide():t.show())}getHelper(e){return this._helpers.get(e)??null}isVisible(e){return this._helpers.get(e)?.visible??!1}showAll(){for(let e of this._helpers.values())e.show()}hideAll(){for(let e of this._helpers.values())e.hide()}render(){this._helperScene&&this._helperScene.render(this.renderer,this.camera);for(let e of this._helpers.values())e.visible&&e.layer===`scene`&&e.render&&e.render(this.renderer,this.camera);this.refreshHUD()}setSize(e,t){for(let n of this._helpers.values())n.setSize?.(e,t)}refreshHUD(){let e=this._hudCanvas,t=this._hudCtx,n=!1;for(let e of this._helpers.values())if(e.visible&&e.layer===`hud`&&e.render){n=!0;break}if(!n){e.style.display!==`none`&&(e.style.display=`none`);return}let r=window.devicePixelRatio||1,i=e.clientWidth,a=e.clientHeight,o=Math.round(i*r),s=Math.round(a*r);(e.width!==o||e.height!==s)&&(e.width=o,e.height=s),t.clearRect(0,0,o,s),t.save(),t.scale(r,r);for(let e of this._helpers.values())e.visible&&e.layer===`hud`&&e.render&&e.render(t,i,a);t.restore(),e.style.display!==``&&(e.style.display=``)}dispose(){for(let e of this._helpers.values())e.dispose?.();this._helpers.clear(),this._hudCanvas.parentElement&&this._hudCanvas.parentElement.removeChild(this._hudCanvas)}},ds=class extends r.EventDispatcher{constructor(){super(),this.mixer=null,this.timer=new r.Timer,this.actions=[],this.isPlaying=!1,this._scene=null,this._mixerRoot=null,this._meshes=null,this._meshTriRanges=null,this._posBuffer=null,this._tempVec=new r.Vector3,this._skinnedCache=null,this._totalTriangleCount=0,this._clipsCache=null,this._savedTimeScale=1,this.onFinished=null,this.wakeCallback=null}init(e,t,n,i,a){if(this.dispose(),!i||i.length===0)return;this._scene=e,this._mixerRoot=t,this._meshes=n,this._totalTriangleCount=a,this.mixer=new r.AnimationMixer(t);let o=i.map(e=>this.mixer.clipAction(e)),s=(e,t)=>e.name===t||e.getObjectByName(t)!==void 0;!o.some(e=>e.getClip().tracks.some(e=>{let n=e.name.split(`.`)[0];return s(t,n)}))&&t!==e&&(console.log(`[AnimationManager] Tracks did not resolve from model root, retrying with scene root`),this.mixer=new r.AnimationMixer(e),this._mixerRoot=e,o=i.map(e=>this.mixer.clipAction(e))),this.actions=o,this.mixer.addEventListener(`finished`,()=>{this.isPlaying=!1,this.timer.reset(),this.onFinished&&this.onFinished()}),this._meshTriRanges=[],this._skinnedCache=[];let c=0;for(let e of n){let t=e.geometry,n=t.attributes.position,r=t.index?t.index.array:null,i=r?r.length/3:n.count/3,a=n.count;this._meshTriRanges.push({start:c,count:i,uniqueVerts:a,indices:r}),this._skinnedCache.push(new Float32Array(a*3)),c+=i}this._posBuffer=new Float32Array(a*9);let l=n.filter(e=>e.isSkinnedMesh).length;console.debug(`[AnimationManager] Init: ${i.length} clips, ${n.length} meshes (${l} skinned), ${a} triangles`)}play(e=0){if(!(!this.mixer||this.actions.length===0)){if(this.mixer.stopAllAction(),e===-1)for(let e of this.actions)e.play();else e>=0&&e<this.actions.length&&this.actions[e].play();this.timer.reset(),this.isPlaying=!0,this.wakeCallback?.(),this.dispatchEvent({type:L.ANIMATION_STARTED})}}pause(){this.mixer&&(this.mixer.timeScale=0,this.timer.reset(),this.isPlaying=!1,this.dispatchEvent({type:L.ANIMATION_PAUSED}))}resume(){this.mixer&&(this.mixer.timeScale=this._savedTimeScale||1,this.timer.reset(),this.isPlaying=!0,this.wakeCallback?.(),this.dispatchEvent({type:L.ANIMATION_STARTED}))}stop(){this.mixer&&(this.mixer.stopAllAction(),this.mixer.timeScale=this._savedTimeScale||1,this.timer.reset(),this.isPlaying=!1,this.dispatchEvent({type:L.ANIMATION_STOPPED}))}setSpeed(e){this._savedTimeScale=e,this.mixer&&this.isPlaying&&(this.mixer.timeScale=e)}setLoop(e){let t=e?r.LoopRepeat:r.LoopOnce;for(let n of this.actions)n.setLoop(t),n.clampWhenFinished=!e}seekTo(e,t=0){if(!this.mixer||this.actions.length===0)return null;if(this.mixer.stopAllAction(),t===-1)for(let e of this.actions)e.play();else t>=0&&t<this.actions.length&&this.actions[t].play();this.mixer.setTime(e);for(let e of this.actions)e.isRunning()&&(e.paused=!0);return this._computePositions(),this._posBuffer}get currentTime(){return this.mixer?.time||0}update(){if(!this.isPlaying||!this.mixer)return null;this.timer.update();let e=this.timer.getDelta();return this.mixer.update(e),this._computePositions(),this._posBuffer}_computePositions(){let e=this._tempVec,t=this._posBuffer;this._mixerRoot.updateMatrixWorld(!0);for(let n=0;n<this._meshes.length;n++){let r=this._meshes[n],{start:i,count:a,uniqueVerts:o,indices:s}=this._meshTriRanges[n],c=this._skinnedCache[n],l=r.matrixWorld;for(let t=0;t<o;t++)r.getVertexPosition(t,e),e.applyMatrix4(l),c[t*3]=e.x,c[t*3+1]=e.y,c[t*3+2]=e.z;if(s)for(let e=0;e<a;e++){let n=e*3,r=s[n]*3,a=s[n+1]*3,o=s[n+2]*3,l=(i+e)*9;t[l]=c[r],t[l+1]=c[r+1],t[l+2]=c[r+2],t[l+3]=c[a],t[l+4]=c[a+1],t[l+5]=c[a+2],t[l+6]=c[o],t[l+7]=c[o+1],t[l+8]=c[o+2]}else for(let e=0;e<a;e++){let n=e*3*3,r=(e*3+1)*3,a=(e*3+2)*3,o=(i+e)*9;t[o]=c[n],t[o+1]=c[n+1],t[o+2]=c[n+2],t[o+3]=c[r],t[o+4]=c[r+1],t[o+5]=c[r+2],t[o+6]=c[a],t[o+7]=c[a+1],t[o+8]=c[a+2]}}}get hasAnimations(){return this.actions.length>0}get clips(){return this._clipsCache||=this.actions.map((e,t)=>{let n=e.getClip();return{index:t,name:n.name||`Clip ${t}`,duration:n.duration}}),this._clipsCache}dispose(){this.mixer&&=(this.mixer.stopAllAction(),this.mixer.uncacheRoot(this._mixerRoot),null),this.actions=[],this.isPlaying=!1,this.timer.reset(),this._scene=null,this._mixerRoot=null,this._meshes=null,this._meshTriRanges=null,this._posBuffer=null,this._skinnedCache=null,this._clipsCache=null}},fs=class{constructor({camera:e,canvas:t,orbitControls:n,app:i}){this._app=i,this._orbitControls=n,this._camera=e,this._controls=new _.TransformControls(e,t),this._gizmoScene=new r.Scene,this._gizmoScene.add(this._controls.getHelper()),this._attached=null,this._isDragging=!1,this._meshes=null,this._meshTriRanges=null,this._posBuffer=null,this._normalBuffer=null,this._skinnedCache=null,this._normalCache=null,this._tempVec=new r.Vector3,this._normalMatrix=new r.Matrix3,this._refitInFlight=!1,this._baselineComputed=!1,this._onDraggingChanged=this._onDraggingChanged.bind(this),this._onObjectChange=this._onObjectChange.bind(this),this._controls.addEventListener(`dragging-changed`,this._onDraggingChanged),this._controls.addEventListener(`objectChange`,this._onObjectChange)}setMeshData(e,t){this._meshes=e,this._meshTriRanges=[],this._skinnedCache=[],this._normalCache=[];let n=0;for(let t of e){let e=t.geometry,r=e.attributes.position,i=e.index?e.index.array:null,a=i?i.length/3:r.count/3,o=r.count;this._meshTriRanges.push({start:n,count:a,uniqueVerts:o,indices:i}),this._skinnedCache.push(new Float32Array(o*3)),this._normalCache.push(new Float32Array(o*3)),n+=a}this._posBuffer=new Float32Array(t*9),this._normalBuffer=new Float32Array(t*9)}attach(e){this._attached!==e&&(this._controls.attach(e),this._attached=e)}detach(){this._attached&&=(this._controls.detach(),null)}setMode(e){this._controls.setMode(e),this._app?.dispatchEvent({type:L.TRANSFORM_MODE_CHANGED,mode:e})}setSpace(e){this._controls.setSpace(e)}get isDragging(){return this._isDragging}get attachedObject(){return this._attached}get controls(){return this._controls}render(e){if(!this._attached)return;let t=e.autoClear;e.autoClear=!1,e.clearDepth(),e.setRenderTarget(null),e.render(this._gizmoScene,this._camera),e.autoClear=t}_onDraggingChanged(e){this._isDragging=e.value,this._orbitControls&&(this._orbitControls.enabled=!e.value),e.value?this._app.dispatchEvent({type:L.OBJECT_TRANSFORM_START}):(this._recomputeAndRefit(),this._app.dispatchEvent({type:L.OBJECT_TRANSFORM_END}))}_onObjectChange(){this._app.needsReset=!0,this._app.wake()}_recomputeAndRefit(){if(!this._meshes||!this._posBuffer||this._refitInFlight||!this._attached)return;this._attached.updateMatrixWorld(!0);let e=this._findAffectedMeshIndices(this._attached);if(e.length!==0){if(!this._baselineComputed)this._computeAllPositions(),this._baselineComputed=!0;else for(let t of e)this._computeMeshPositions(t);this._refitInFlight=!0;try{this._app.refitBLASes(e,this._posBuffer,this._normalBuffer)}catch(e){console.error(`Transform refit error:`,e)}finally{this._refitInFlight=!1}}}_findAffectedMeshIndices(e){let t=[];for(let n=0;n<this._meshes.length;n++){let r=this._meshes[n];(r===e||this._isDescendantOf(r,e))&&t.push(n)}return t}_isDescendantOf(e,t){let n=e.parent;for(;n;){if(n===t)return!0;n=n.parent}return!1}_computeAllPositions(){for(let e=0;e<this._meshes.length;e++)this._computeMeshPositions(e)}_computeMeshPositions(e){let t=this._meshes[e],{start:n,count:r,uniqueVerts:i,indices:a}=this._meshTriRanges[e],o=this._skinnedCache[e],s=this._normalCache[e],c=this._tempVec,l=this._posBuffer,u=this._normalBuffer;t.updateMatrixWorld(!0);let d=t.matrixWorld;this._normalMatrix.getNormalMatrix(d);let f=this._normalMatrix.elements,p=t.geometry.attributes.normal;for(let e=0;e<i;e++)if(t.getVertexPosition(e,c),c.applyMatrix4(d),o[e*3]=c.x,o[e*3+1]=c.y,o[e*3+2]=c.z,p){let t=p.getX(e),n=p.getY(e),r=p.getZ(e);s[e*3]=f[0]*t+f[3]*n+f[6]*r,s[e*3+1]=f[1]*t+f[4]*n+f[7]*r,s[e*3+2]=f[2]*t+f[5]*n+f[8]*r}if(a)for(let e=0;e<r;e++){let t=e*3,r=a[t]*3,i=a[t+1]*3,c=a[t+2]*3,d=(n+e)*9;l[d]=o[r],l[d+1]=o[r+1],l[d+2]=o[r+2],l[d+3]=o[i],l[d+4]=o[i+1],l[d+5]=o[i+2],l[d+6]=o[c],l[d+7]=o[c+1],l[d+8]=o[c+2],u[d]=s[r],u[d+1]=s[r+1],u[d+2]=s[r+2],u[d+3]=s[i],u[d+4]=s[i+1],u[d+5]=s[i+2],u[d+6]=s[c],u[d+7]=s[c+1],u[d+8]=s[c+2]}else for(let e=0;e<r;e++){let t=e*3*3,r=(e*3+1)*3,i=(e*3+2)*3,a=(n+e)*9;l[a]=o[t],l[a+1]=o[t+1],l[a+2]=o[t+2],l[a+3]=o[r],l[a+4]=o[r+1],l[a+5]=o[r+2],l[a+6]=o[i],l[a+7]=o[i+1],l[a+8]=o[i+2],u[a]=s[t],u[a+1]=s[t+1],u[a+2]=s[t+2],u[a+3]=s[r],u[a+4]=s[r+1],u[a+5]=s[r+2],u[a+6]=s[i],u[a+7]=s[i+1],u[a+8]=s[i+2]}}dispose(){this._controls.removeEventListener(`dragging-changed`,this._onDraggingChanged),this._controls.removeEventListener(`objectChange`,this._onObjectChange),this.detach(),this._gizmoScene.remove(this._controls.getHelper()),this._controls.dispose(),this._meshes=null,this._meshTriRanges=null,this._posBuffer=null,this._normalBuffer=null,this._skinnedCache=null,this._normalCache=null,this._baselineComputed=!1,this._app=null,this._orbitControls=null,this._camera=null,this._controls=null,this._gizmoScene=null}},ps=new WeakMap,ms=class extends r.EventDispatcher{constructor(e,t={}){super();try{ps.get(e)?.dispose()}catch(e){console.warn(`PathTracerApp: prior canvas owner dispose failed`,e)}ps.set(e,this),this.canvas=e,this._autoResize=t.autoResize!==!1,this._showStats=t.showStats!==!1,this._statsContainer=t.statsContainer||null,this.settings=new Po(z),this.renderer=null,this.scene=null,this.meshScene=null,this._sceneHelpers=null,this.assetLoader=null,this._sdf=null,this._animRefitInFlight=!1,this.pipeline=null,this.stages={},this.cameraManager=null,this.lightManager=null,this.denoisingManager=null,this.overlayManager=null,this.interactionManager=null,this.transformManager=null,this.animationManager=new ds,this.environmentManager=null,this.isInitialized=!1,this.pauseRendering=!1,this.pathTracerEnabled=!0,this.animationManagerId=null,this.needsReset=!1,this._loadingInProgress=!1,this._needsDisplayRefresh=!1,this._paused=!1,this.completion=new Oo,this._resizeDebounceTimer=null,this._trackedListeners=[],this._disposed=!1}_addTrackedListener(e,t,n){e&&(e.addEventListener(t,n),this._trackedListeners.push({target:e,type:t,handler:n}))}_removeTrackedListeners(){for(let{target:e,type:t,handler:n}of this._trackedListeners)try{e.removeEventListener(t,n)}catch(e){console.warn(`PathTracerApp: failed to remove listener`,t,e)}this._trackedListeners.length=0}async init(){return await this._initRenderer(),this._initCameraManager(),this._initScenes(),this._initAssetPipeline(),this._initPipeline(),this._initManagers(),this._wireEvents(),this.stages.pathTracer.setTriangleData(new Float32Array(32),0),this.stages.pathTracer.setBVHData(new Float32Array(16)),this.stages.pathTracer.materialData.setMaterialData(new Float32Array(16)),this.stages.pathTracer.setupMaterial(),this._showStats&&this._initStats(),this.isInitialized=!0,console.log(`WebGPU Path Tracer App initialized`),this}animate(){if(this.animationManagerId=requestAnimationFrame(()=>this.animate()),this._loadingInProgress||this._sdf?.isProcessing){this._stats?.update();return}if(this.cameraManager.controls&&this.cameraManager.controls.update(),this.animationManager?.isPlaying&&!this._animRefitInFlight){let e=this.animationManager.update();e&&(this._animRefitInFlight=!0,this.refitBVH(e).catch(e=>console.error(`Animation refit error:`,e)).finally(()=>{this._animRefitInFlight=!1}))}if(this.needsReset&&=(this.reset(!0),!1),this.cameraManager.camera.updateMatrixWorld(),!this.pathTracerEnabled){this.renderer.render(this.meshScene,this.cameraManager.camera),this._renderHelperOverlay();return}if(!this.pauseRendering){if(this.cameraManager.updateAutoFocus(),this.stages.pathTracer?.isReady){if(this.stages.pathTracer.isComplete&&this.completion.renderCompleteDispatched){this._needsDisplayRefresh&&(this._needsDisplayRefresh=!1,this.stages.compositor.render(this.pipeline.context),this._renderHelperOverlay()),this.stopAnimation();return}this.pipeline.render(),this.stages.pathTracer.isComplete||this.completion.updateTime(),Ce({timeElapsed:this.completion.timeElapsed,samples:we(this.stages.pathTracer)}),this.completion.isTimeLimitReached(this.settings.get(`renderLimitMode`),this.settings.get(`renderTimeLimit`))&&(this.stages.pathTracer.isComplete=!0),this.stages.pathTracer.isComplete&&this.completion.markComplete()&&(this.denoisingManager.onRenderComplete({isStillComplete:()=>this.completion.renderCompleteDispatched,context:this.pipeline?.context}),this.dispatchEvent({type:`RenderComplete`}),this.dispatchEvent({type:L.RENDER_COMPLETE}))}this._renderHelperOverlay(),this._stats?.update(),this.renderer.resolveTimestampsAsync?.(r.TimestampQuery.RENDER),this.renderer.resolveTimestampsAsync?.(r.TimestampQuery.COMPUTE)}}stopAnimation(){this.animationManagerId&&=(cancelAnimationFrame(this.animationManagerId),null)}wake(){!this.animationManagerId&&this.isInitialized&&!this._paused&&this.animate()}pause(){this._paused=!0,this.stopAnimation(),this._stats&&(this._stats.dom.style.display=`none`)}resume(){this._paused=!1,this.animationManagerId||this.animate(),this._stats&&(this._stats.dom.style.display=``)}reset(e=!1){if(this.pipeline&&(this.pipeline.reset(),e||this.pipeline.eventBus.emit(`asvgf:reset`)),this.denoisingManager?.abort(this.canvas),this.denoisingManager?.restoreBaseResolution()){let e=this.denoisingManager._lastRenderWidth,t=this.denoisingManager._lastRenderHeight;this.dispatchEvent({type:`resolution_changed`,width:e,height:t})}this.completion.reset(),this.wake(),this.dispatchEvent({type:`RenderReset`}),this.dispatchEvent({type:L.RENDER_RESET})}dispose(){if(!this._disposed){if(this._disposed=!0,this.dispatchEvent({type:L.DISPOSE}),this.stopAnimation(),clearTimeout(this._resizeDebounceTimer),this._resizeDebounceTimer=null,this._removeTrackedListeners(),xe(null),this.interactionManager?.deselect?.(),this.transformManager?.detach?.(),this.animationManager?.dispose(),this.transformManager?.dispose(),this.overlayManager?.dispose(),this.lightManager?.dispose(),this.denoisingManager?.dispose(),this.interactionManager?.dispose(),this.cameraManager?.dispose(),this.pipeline?.dispose(),this._sdf?.dispose(),this._sdf=null,this.assetLoader?.dispose(),this.assetLoader=null,this.meshScene){this.meshScene.environment?.dispose(),this.meshScene.environment=null;for(let e of[...this.meshScene.children])Oe(e);this.meshScene.clear(),this.meshScene=null}this._sceneHelpers?.clear(),this._sceneHelpers=null,this.scene?.clear(),this.scene=null,this.renderer?._canvasTarget&&this.renderer._onCanvasTargetResize&&this.renderer._canvasTarget.removeEventListener(`resize`,this.renderer._onCanvasTargetResize);try{let e=(0,n.texture)().value,t=(0,n.cubeTexture)().value;e?._listeners?.dispose&&(e._listeners.dispose.length=0),t?._listeners?.dispose&&(t._listeners.dispose.length=0)}catch(e){console.warn(`PathTracerApp: failed to clear TSL texture singleton listeners`,e)}this.renderer?.dispose(),this.renderer&&(this.renderer._canvasTarget=null),this.renderer=null,this._stats&&=(this._stats.dom.remove(),null),this.stages={},this.isInitialized=!1}}unloadScene(){if(this.isInitialized){if(this._loadingInProgress)throw Error(`PathTracerApp.unloadScene: cannot unload while a load is in progress`);this._disposed||(this.animationManager?.dispose(),this._animRefitInFlight=!1,this.interactionManager?.deselect(),this.transformManager?.detach?.(),this.assetLoader?.releaseTargetModel(),this.lightManager?.clearLights?.(),this.stages.pathTracer&&(this.stages.pathTracer.setTriangleData(new Float32Array(32),0),this.stages.pathTracer.setBVHData(new Float32Array(16)),this.stages.pathTracer.materialData.setMaterialData(new Float32Array(16)),this.stages.pathTracer.setEmissiveTriangleData?.(new Float32Array,0,0),this.stages.pathTracer.setupMaterial()),this.reset(),this.dispatchEvent({type:`SceneUnloaded`}))}}async loadModel(e){await this._loadWithSceneRebuild(()=>this.assetLoader.loadModel(e),{type:`ModelLoaded`,url:e})}async loadObject3D(e,t=`object3d`){await this._loadWithSceneRebuild(()=>this.assetLoader.loadObject3D(e,t),{type:`Object3DLoaded`,name:t})}async loadEnvironment(e){if(this._loadingInProgress)throw Error(`PathTracerApp.loadEnvironment: another load is already in progress`);this._loadingInProgress=!0;try{await this.assetLoader.loadEnvironment(e);let t=this.meshScene.environment;t&&this.stages.pathTracer&&await this.stages.pathTracer.environment.setEnvironmentMap(t),this.pipeline?.eventBus.emit(`autoexposure:resetHistory`),this.reset(),this.dispatchEvent({type:`EnvironmentLoaded`,url:e})}finally{this._loadingInProgress=!1}}async loadExampleModels(e,t){await this._loadWithSceneRebuild(()=>this.assetLoader.loadExampleModels(e,t),{type:`ModelLoaded`,index:e})}async _loadWithSceneRebuild(e,t){if(this._loadingInProgress)throw Error(`PathTracerApp: another load is already in progress`);this._loadingInProgress=!0;try{await e(),this._syncControlsAfterLoad(),await this.loadSceneData(),this.pipeline?.eventBus.emit(`autoexposure:resetHistory`),this.reset(),this.cameraManager.currentCameraIndex=0,this.dispatchEvent(t),this.dispatchEvent({type:`CamerasUpdated`,cameras:this.cameraManager.cameras,cameraNames:this.cameraManager.getCameraNames()})}finally{this._loadingInProgress=!1}}async loadSceneData(){this.interactionManager?.deselect(),this.animationManager.dispose(),this._animRefitInFlight=!1;let e=new ua(`loadSceneData`),t=this.meshScene.environment,n=null;if(t?.image?.data&&(e.start(`Environment CDF build (worker)`),this.stages.pathTracer.scene.environment=t,n=this.stages.pathTracer.environment.buildEnvironmentCDF().then(()=>e.end(`Environment CDF build (worker)`))),e.start(`BVH build (SceneProcessor)`),await this._sdf.buildBVH(this.meshScene),e.end(`BVH build (SceneProcessor)`),R({status:`Transferring data to GPU...`,progress:86}),await new Promise(e=>setTimeout(e,0)),e.start(`GPU data transfer`),!this._sdf.uploadToPathTracer(this.stages.pathTracer,this.lightManager,this.meshScene,t))return!1;this.stages.pathTracer._meshRefs=this.stages.pathTracer._collectMeshRefs(this.meshScene),this.stages.pathTracer.setMeshVisibilityData(this.stages.pathTracer._meshRefs),e.end(`GPU data transfer`),R({status:`Compiling shaders...`,progress:90}),await new Promise(e=>setTimeout(e,0)),e.start(`Material setup (TSL compile)`),this.stages.pathTracer.setupMaterial(),e.end(`Material setup (TSL compile)`),e.start(`Pipeline precompile`),this.stages.pathTracer.shaderBuilder.forceCompile(this.renderer);try{await this.renderer.compileAsync(this.meshScene,this.cameraManager.camera)}catch(e){console.warn(`PathTracerApp: raster fallback precompile failed`,e)}return e.end(`Pipeline precompile`),n&&(R({status:`Finalizing environment map...`,progress:95}),await n,this.stages.pathTracer.environment.applyCDFResults()),e.start(`Apply settings`),this.settings.applyAll(),this.stages.compositor.setTransparentBackground(this.settings.get(`transparentBackground`)),e.end(`Apply settings`),e.print(),Se(),this._initAnimationAndTransforms(),this.dispatchEvent({type:`SceneRebuild`}),!0}async refitBVH(e,t){let n=await this._sdf.refitBVH(e,t);return this.stages.pathTracer.updateTriangleData(this._sdf.triangleData),this.stages.pathTracer.updateBVHData(this._sdf.bvhData),this.reset(),n}refitBLASes(e,t,n){let r=this._sdf.refitBLASes(e,t,n),{triRanges:i,bvhRanges:a}=this._sdf.computeBLASDirtyRanges(e);return this.stages.pathTracer.updateBufferRanges(i,a),this.reset(),this._sdf.scheduleBackgroundRebuild(e,()=>{this.stages.pathTracer.updateTriangleData(this._sdf.triangleData),this.stages.pathTracer.updateBVHData(this._sdf.bvhData),this.reset()}),r}onResize(){let e=this.canvas.clientWidth,t=this.canvas.clientHeight;if(e===0||t===0)return;this.renderer.setPixelRatio(1),this.renderer.setSize(e,t,!1),this.cameraManager.camera.aspect=e/t,this.cameraManager.camera.updateProjectionMatrix();let n=window.devicePixelRatio||1;this.overlayManager?.setSize(Math.round(e*n),Math.round(t*n));let r=this.denoisingManager?._lastRenderWidth??0,i=this.denoisingManager?._lastRenderHeight??0;e===r&&t===i||(clearTimeout(this._resizeDebounceTimer),this._resizeDebounceTimer=setTimeout(()=>{this._applyRenderResize(e,t)},300))}_applyRenderResize(e,t){this.pipeline?.setSize(e,t),this.denoisingManager?.setRenderSize(e,t),this.needsReset=!0,this.dispatchEvent({type:`resolution_changed`,width:e,height:t})}setCanvasSize(e,t){e===0||t===0||(this.renderer.setPixelRatio(1),this.renderer.setSize(e,t,!1),this.cameraManager.camera.aspect=e/t,this.cameraManager.camera.updateProjectionMatrix(),clearTimeout(this._resizeDebounceTimer),this._applyRenderResize(e,t))}configureForMode(e,t={}){if(e===`results`){this.pauseRendering=!0,this.cameraManager.controls.enabled=!1,this.renderer?.domElement&&(this.renderer.domElement.style.display=`none`),this.denoisingManager?.denoiser?.output&&(this.denoisingManager.denoiser.output.style.display=`none`);return}let n=e===`final-render`,r=n?Ve:He;this.cameraManager.controls.enabled=!n,this.settings.setMany({maxSamples:r.maxSamples,maxBounces:r.bounces,samplesPerPixel:r.samplesPerPixel,transmissiveBounces:r.transmissiveBounces},{silent:!0}),this.stages.pathTracer?.setUniform(`renderMode`,parseInt(r.renderMode)),this.stages.pathTracer?.setUniform(`enableAlphaShadows`,r.enableAlphaShadows??!1),this.stages.pathTracer?.tileManager?.setTileCount(r.tiles);let i=this.overlayManager?.getHelper(`tiles`);i&&(i.enabled=r.tilesHelper,r.tilesHelper||i.hide()),this.stages.pathTracer?.updateCompletionThreshold?.();let a=this.denoisingManager?.denoiser;a&&(a.abort(),a.enabled=r.enableOIDN,a.updateQuality(r.oidnQuality)),this.denoisingManager?.upscaler?.abort(),t.canvasWidth&&t.canvasHeight&&this.setCanvasSize(t.canvasWidth,t.canvasHeight),this.renderer?.domElement&&(this.renderer.domElement.style.display=`block`),this.denoisingManager?.denoiser?.output&&(this.denoisingManager.denoiser.output.style.display=`block`),this.needsReset=!1,this.pauseRendering=!1,this.reset()}refreshFrame(){this._needsDisplayRefresh=!0,this.wake()}getCanvas(){if(!this.renderer?.domElement)return null;let e=this.denoisingManager;return(e?.denoiser?.enabled||e?.upscaler?.enabled)&&e?.denoiserCanvas&&this.stages.pathTracer?.isComplete?e.denoiserCanvas:(this.stages.compositor&&this.pipeline?.context&&this.stages.compositor.render(this.pipeline.context),this.renderer.domElement)}screenshot(){let e=this.getCanvas();if(e)try{let t=e.toDataURL(`image/png`),n=document.createElement(`a`);n.href=t,n.download=`screenshot.png`,n.click()}catch(e){console.error(`Screenshot failed:`,e)}}getStatistics(){try{return this._sdf?.getStatistics?.()??null}catch{return null}}get isLoading(){return this._loadingInProgress}isComplete(){return this.stages.pathTracer?.isComplete??!1}getFrameCount(){return this.stages.pathTracer?.frameCount||0}setMaterialProperty(e,t,n){if(this.stages.pathTracer?.materialData.updateMaterialProperty(e,t,n),[`emissive`,`emissiveIntensity`].includes(t)&&this.stages.pathTracer?.enableEmissiveTriangleSampling?.value){let r=this._sdf.updateMaterialEmissive(e,t,n);r&&this.stages.pathTracer.setEmissiveTriangleData(r.rawData,r.emissiveCount,r.totalPower)}this.reset()}setMeshVisibility(e,t){this.stages.pathTracer?.updateMeshVisibility(e,t),this.reset()}updateAllMeshVisibility(){this.stages.pathTracer?.updateAllMeshVisibility(),this.reset()}setTextureTransform(e,t,n){this.stages.pathTracer?.materialData.updateTextureTransform(e,t,n),this.reset()}async rebuildMaterials(e){await this.stages.pathTracer?.rebuildMaterials(e||this.meshScene),this.reset()}async _initRenderer(){if(xe(e=>this.dispatchEvent(e)),!navigator.gpu)throw Error(`WebGPU is not supported in this browser`);let e=await navigator.gpu.requestAdapter({powerPreference:`high-performance`});if(!e)throw Error(`Failed to get WebGPU adapter`);let n=e.limits;this.renderer=new t.WebGPURenderer({canvas:this.canvas,alpha:!0,powerPreference:`high-performance`,requiredLimits:{maxBufferSize:n.maxBufferSize,maxStorageBufferBindingSize:n.maxStorageBufferBindingSize,maxColorAttachmentBytesPerSample:128}}),await this.renderer.init(),t.RectAreaLightNode.setLTC(i.RectAreaLightTexturesLib.init()),this.renderer.workingColorSpace=t.SRGBColorSpace,this.renderer.outputColorSpace=t.SRGBColorSpace,this.renderer.toneMapping=r.ACESFilmicToneMapping,this.renderer.toneMappingExposure=1,this.renderer.setPixelRatio(1)}_initCameraManager(){this.cameraManager=new Fo(this.canvas)}_initScenes(){this.scene=new r.Scene,this.meshScene=new r.Scene,this._sceneHelpers=new O}_initAssetPipeline(){this._sdf=new Ya,this.assetLoader=new jo(this.meshScene,this.cameraManager.camera,this.cameraManager.controls),this.assetLoader.setRenderer(this.renderer),this.assetLoader.createFloorPlane(),this._addTrackedListener(this.cameraManager.controls,`change`,()=>{this.needsReset=!0,this.wake()})}_initPipeline(){this._createStages();let{clientWidth:e,clientHeight:t}=this.canvas;this.pipeline=new Do(this.renderer,e||1,t||1),this.pipeline.addStage(this.stages.pathTracer),this.pipeline.addStage(this.stages.normalDepth),this.pipeline.addStage(this.stages.motionVector),this.pipeline.addStage(this.stages.ssrc),this.pipeline.addStage(this.stages.asvgf),this.pipeline.addStage(this.stages.variance),this.pipeline.addStage(this.stages.bilateralFilter),this.pipeline.addStage(this.stages.adaptiveSampling),this.pipeline.addStage(this.stages.edgeFilter),this.pipeline.addStage(this.stages.autoExposure),this.pipeline.addStage(this.stages.compositor);let n=this.canvas.clientWidth||1,r=this.canvas.clientHeight||1;this.pipeline.setSize(n,r)}_initManagers(){this.interactionManager=new ko({scene:this.meshScene,camera:this.cameraManager.camera,canvas:this.canvas,assetLoader:this.assetLoader,pathTracer:null,floorPlane:this.assetLoader.floorPlane}),this.interactionManager.wireAppEvents(this),this.cameraManager.setInteractionManager(this.interactionManager),this.lightManager=new Io(this.scene,this._sceneHelpers,this.stages.pathTracer,{onReset:()=>this.reset()}),this._setupDenoisingManager(),this._setupOverlayManager(),this.transformManager=new fs({camera:this.cameraManager.camera,canvas:this.canvas,orbitControls:this.cameraManager.controls,app:this}),this.interactionManager.setDependencies({overlayManager:this.overlayManager,transformManager:this.transformManager,appDispatch:e=>this.dispatchEvent(e),orbitControls:this.cameraManager.controls}),this.denoisingManager.setOverlayManager(this.overlayManager),this.denoisingManager.setResetCallback(()=>this.reset()),this.denoisingManager.setSettings(this.settings),this.environmentManager=this.stages.pathTracer.environment,this.environmentManager.callbacks.onAutoExposureReset=()=>this.pipeline.eventBus.emit(`autoexposure:resetHistory`)}_wireEvents(){this._addTrackedListener(this.cameraManager,`CameraSwitched`,e=>this.dispatchEvent(e)),this._addTrackedListener(this.cameraManager,L.AUTO_FOCUS_UPDATED,e=>this.dispatchEvent(e)),this._forwardEvents(this.denoisingManager,[L.DENOISING_START,L.DENOISING_END,L.UPSCALING_START,L.UPSCALING_PROGRESS,L.UPSCALING_END,`resolution_changed`]),this._setupAutoExposureListener(),this.animationManager.wakeCallback=()=>this.wake(),this._forwardEvents(this.animationManager,[L.ANIMATION_STARTED,L.ANIMATION_PAUSED,L.ANIMATION_STOPPED]),this._addTrackedListener(this.animationManager,L.ANIMATION_PAUSED,()=>{this._animRefitInFlight=!1}),this._addTrackedListener(this.animationManager,L.ANIMATION_STOPPED,()=>{this._animRefitInFlight=!1}),this.cameraManager.initCallbacks({onResize:()=>this.onResize(),onReset:()=>this.reset(),getSettings:e=>this.settings.get(e)}),this.cameraManager.initAutoFocus({meshScene:this.meshScene,assetLoader:this.assetLoader,floorPlane:this.assetLoader.floorPlane,pathTracer:this.stages.pathTracer,settings:this.settings,softReset:()=>this.reset(!0),hardReset:()=>this.reset()}),this.settings.bind({stages:this.stages,renderer:this.renderer,resetCallback:()=>this.reset(),reconcileCompletion:()=>this._reconcileCompletion()}),this.renderer.toneMappingExposure=this.settings.get(`exposure`)??1,this.onResize(),this.resizeHandler=()=>this.onResize(),this._autoResize&&this._addTrackedListener(window,`resize`,this.resizeHandler),this._onAssetLoaded=async e=>{if(!this._loadingInProgress){if(e.model)await this.loadSceneData();else if(e.texture){let e=this.meshScene.environment;e&&this.stages.pathTracer&&await this.stages.pathTracer.environment.setEnvironmentMap(e),Se()}this.pauseRendering=!1,this.reset()}},this._addTrackedListener(this.assetLoader,`load`,this._onAssetLoaded),this._addTrackedListener(this.assetLoader,`modelProcessed`,e=>{let t=[this.cameraManager.camera,...e.cameras||[]];this.cameraManager.setCameras(t),this.interactionManager&&(this.interactionManager.floorPlane=this.assetLoader.floorPlane)})}_initAnimationAndTransforms(){let e=this.assetLoader?.animations||[];if(e.length>0){let t=this.assetLoader?.targetModel||this.meshScene;this.animationManager.init(this.meshScene,t,this._sdf.meshes,e,this._sdf.triangleCount),this.animationManager.onFinished=()=>{this._animRefitInFlight=!1,this.dispatchEvent({type:L.ANIMATION_FINISHED})}}this.transformManager?.setMeshData(this._sdf.meshes,this._sdf.triangleCount)}_createStages(){let e=this.settings.get(`adaptiveSamplingMax`),t=this.settings.get(`useAdaptiveSampling`);this.stages.pathTracer=new eo(this.renderer,this.scene,this.cameraManager.camera),this.stages.normalDepth=new to(this.renderer,{pathTracer:this.stages.pathTracer}),this.stages.motionVector=new no(this.renderer,this.cameraManager.camera,{pathTracer:this.stages.pathTracer}),this.stages.ssrc=new Co(this.renderer,{enabled:!1}),this.stages.asvgf=new io(this.renderer,{enabled:!1}),this.stages.variance=new oo(this.renderer,{enabled:!1}),this.stages.bilateralFilter=new co(this.renderer,{enabled:!1}),this.stages.adaptiveSampling=new fo(this.renderer,{adaptiveSamplingMax:e,enabled:t}),this.stages.edgeFilter=new po(this.renderer,{enabled:!1}),this.stages.autoExposure=new bo(this.renderer,{enabled:z.autoExposure??!1}),this.stages.compositor=new wo(this.renderer,{saturation:this.settings.get(`saturation`)??z.saturation})}_setupDenoisingManager(){this.denoisingManager=new ss({renderer:this.renderer,mainCanvas:this.canvas,scene:this.scene,camera:this.cameraManager.camera,stages:{pathTracer:this.stages.pathTracer,asvgf:this.stages.asvgf,variance:this.stages.variance,bilateralFilter:this.stages.bilateralFilter,adaptiveSampling:this.stages.adaptiveSampling,edgeFilter:this.stages.edgeFilter,ssrc:this.stages.ssrc,autoExposure:this.stages.autoExposure,compositor:this.stages.compositor},pipeline:this.pipeline,getExposure:()=>this.settings.get(`exposure`)??1,getSaturation:()=>this.settings.get(`saturation`)??1,getTransparentBg:()=>this.settings.get(`transparentBackground`)??!1}),this.denoisingManager.setupDenoiser(),this.denoisingManager.setupUpscaler();let e=this.canvas.clientWidth||1,t=this.canvas.clientHeight||1;this.denoisingManager.setRenderSize(e,t)}_reconcileCompletion(){let e=this.stages.pathTracer;if(!e)return;let t=this.completion.isLimitReached(e,this.settings.get(`renderLimitMode`),this.settings.get(`renderTimeLimit`));if(t&&!e.isComplete)e.isComplete=!0;else if(!t&&e.isComplete){e.isComplete=!1,this.completion.resumeFromPause(),this.canvas.style.opacity=`1`;let t=this.denoisingManager?.denoiser?.output;t&&(t.style.display=`none`),this.dispatchEvent({type:L.RENDER_RESET}),this.wake()}}_initStats(){let e=this._statsContainer||this.canvas.parentElement||document.body;this._stats=k(this.renderer,e)}_setupAutoExposureListener(){this.stages.autoExposure&&this.stages.autoExposure.on(`autoexposure:updated`,e=>{this.dispatchEvent({type:L.AUTO_EXPOSURE_UPDATED,exposure:e.exposure,luminance:e.luminance})})}_renderHelperOverlay(){this.scene.updateMatrixWorld(),this.overlayManager?.render(),this.transformManager?.render(this.renderer)}_setupOverlayManager(){this.overlayManager=new us(this.renderer,this.cameraManager.camera),this.overlayManager.setupDefaultHelpers({helperScene:this._sceneHelpers,meshScene:this.meshScene,pipeline:this.pipeline,denoisingManager:this.denoisingManager,app:this,renderWidth:this.denoisingManager?._lastRenderWidth||this.canvas.clientWidth||1,renderHeight:this.denoisingManager?._lastRenderHeight||this.canvas.clientHeight||1})}_syncControlsAfterLoad(){this.cameraManager.controls.saveState(),this.cameraManager.controls.update()}_forwardEvents(e,t){if(e)for(let n of t)this._addTrackedListener(e,n,e=>this.dispatchEvent(e))}},hs=class{constructor(e){this._app=e,this._cancelled=!1,this._rendering=!1}async renderAnimation(e={}){let{clipIndex:t=0,fps:n=30,speed:r=1,samplesPerFrame:i=Ve.maxSamples,enableOIDN:a=!0,onFrame:o,onProgress:s,onComplete:c}=e,l=this._app;if(!l.animationManager?.hasAnimations){console.warn(`VideoRenderManager: No animation clips available`),c?.(!1);return}let u=l.animationManager.clips[t];if(!u){console.warn(`VideoRenderManager: Invalid clip index ${t}`),c?.(!1);return}let d=u.duration/(r||1),f=e.totalFrames||Math.ceil(d*n),p=1/n;this._cancelled=!1,this._rendering=!0;let m=this._saveState();l.stopAnimation(),l.configureForMode(`final-render`),l.settings.setMany({maxSamples:i},{silent:!0}),l.stages.pathTracer?.updateCompletionThreshold?.(),l.cameraManager.controls&&(l.cameraManager.controls.enabled=!1);try{for(let e=0;e<f&&!this._cancelled;e++){let n=e*p*r,i=l.animationManager.seekTo(n,t);if(i?await l.refitBVH(i):l.reset(),l.stopAnimation(),await this._accumulateFrame(l),this._cancelled||(a&&l.denoisingManager?.denoiser?.enabled&&await this._waitForDenoise(l),this._cancelled))break;let c=l.getCanvas();if(c&&o){let t=await createImageBitmap(c);await o(t,e,f),t.close()}let u={frame:e+1,totalFrames:f,percent:(e+1)/f*100};s?.(u),l.dispatchEvent({type:L.VIDEO_RENDER_PROGRESS,...u})}}catch(e){console.error(`VideoRenderManager: Render error:`,e),this._cancelled=!0}finally{this._restoreState(m),this._rendering=!1;let e=!this._cancelled;c?.(e),l.dispatchEvent({type:L.VIDEO_RENDER_COMPLETE,success:e})}}cancel(){this._cancelled=!0}get isRendering(){return this._rendering}async _accumulateFrame(e){let t=e.stages.pathTracer;if(t?.isReady)for(;!t.isComplete&&!this._cancelled;)e.cameraManager.camera.updateMatrixWorld(),e.pipeline.render(),t.frameCount%4==0&&(Ce({samples:we(t)}),await new Promise(e=>setTimeout(e,0)))}_waitForDenoise(e){return new Promise(t=>{let n,r=()=>{e.removeEventListener(L.DENOISING_END,i),clearTimeout(n)},i=()=>{r(),t()};n=setTimeout(()=>{console.warn(`VideoRenderManager: Denoise timed out, skipping`),r(),t()},3e4),e.addEventListener(L.DENOISING_END,i),e.denoisingManager.onRenderComplete({isStillComplete:()=>!this._cancelled,context:e.pipeline?.context})})}_saveState(){let e=this._app;return{maxSamples:e.settings.get(`maxSamples`),maxBounces:e.settings.get(`maxBounces`),samplesPerPixel:e.settings.get(`samplesPerPixel`),transmissiveBounces:e.settings.get(`transmissiveBounces`),renderMode:e.stages.pathTracer?.renderMode?.value,controlsEnabled:e.cameraManager.controls?.enabled,oidnEnabled:e.denoisingManager?.denoiser?.enabled,oidnQuality:e.denoisingManager?.denoiser?.quality,wasPlaying:e.animationManager?.isPlaying,pauseRendering:e.pauseRendering}}_restoreState(e){let t=this._app;t.settings.setMany({maxSamples:e.maxSamples,maxBounces:e.maxBounces,samplesPerPixel:e.samplesPerPixel,transmissiveBounces:e.transmissiveBounces},{silent:!0}),t.stages.pathTracer&&e.renderMode!==void 0&&t.stages.pathTracer?.setUniform(`renderMode`,parseInt(e.renderMode)),t.stages.pathTracer?.updateCompletionThreshold?.(),t.cameraManager.controls&&(t.cameraManager.controls.enabled=e.controlsEnabled??!0),t.denoisingManager?.denoiser&&(t.denoisingManager.denoiser.enabled=e.oidnEnabled??!1,e.oidnQuality&&t.denoisingManager.denoiser.updateQuality(e.oidnQuality)),t.pauseRendering=e.pauseRendering??!1,t.animationManager?.stop(),t.reset(),t.wake()}};e.AF_DEFAULTS=ze,e.ASVGF_QUALITY_PRESETS=Pe,e.AUTO_FOCUS_MODES=Re,e.AnimationManager=ds,e.BVH_LEAF_MARKERS=H,e.CAMERA_PRESETS=Le,e.CAMERA_RANGES=Fe,e.CameraManager=Fo,e.DEFAULT_TEXTURE_MATRIX=Be,e.DenoisingManager=ss,e.ENGINE_DEFAULTS=z,e.EngineEvents=L,e.FINAL_RENDER_CONFIG=Ve,e.InteractionManager=ko,e.LightManager=Io,e.MEMORY_CONSTANTS=W,e.OverlayManager=us,e.PREVIEW_RENDER_CONFIG=He,e.PathTracerApp=ms,e.PipelineContext=To,e.RenderPipeline=Do,e.RenderSettings=Po,e.RenderStage=I,e.SKY_PRESETS=Ie,e.StageExecutionMode=F,e.TEXTURE_CONSTANTS=U,e.TRIANGLE_DATA_LAYOUT=B,e.TransformManager=fs,e.VideoRenderManager=hs});
666
+ `),ro=class extends R{constructor(e,r={}){super(`AutoExposure`,{...r,executionMode:L.ALWAYS}),this.renderer=e,this.REDUCTION_SIZE=64,this.keyValueU=(0,n.uniform)(r.keyValue??.18),this.minExposureU=(0,n.uniform)(r.minExposure??.1),this.maxExposureU=(0,n.uniform)(r.maxExposure??20),this.adaptSpeedBrightU=(0,n.uniform)(r.adaptSpeedBright??3),this.adaptSpeedDarkU=(0,n.uniform)(r.adaptSpeedDark??.5),this.epsilonU=(0,n.uniform)(r.epsilon??1e-4),this.deltaTimeU=(0,n.uniform)(1/60),this.isFirstFrameU=(0,n.uniform)(1),this.previousExposureU=(0,n.uniform)(r.initialExposure??1),this.lowPercentileU=(0,n.uniform)(r.lowPercentile??.1),this.highPercentileU=(0,n.uniform)(r.highPercentile??.9),this.centerWeightU=(0,n.uniform)(r.centerWeight??8),this.inputResW=(0,n.uniform)(1),this.inputResH=(0,n.uniform)(1),this._inputTexNode=new t.TextureNode,this._reductionReadTexNode=new t.TextureNode,this.currentExposure=r.initialExposure??1,this.currentLuminance=.18,this.targetExposure=1,this.lastTime=performance.now(),this.isFirstFrame=!0,this._pendingReadback=!1,this._readbackGeneration=0,this._initRenderTargets(),this._buildCompute()}_initRenderTargets(){let e={type:r.FloatType,format:r.RGBAFormat,minFilter:r.NearestFilter,magFilter:r.NearestFilter,depthBuffer:!1,stencilBuffer:!1};this._downsampleTarget=new t.RenderTarget(this.REDUCTION_SIZE,this.REDUCTION_SIZE,e),this._downsampleStorageTex=new t.StorageTexture(this.REDUCTION_SIZE,this.REDUCTION_SIZE),this._downsampleStorageTex.type=r.FloatType,this._downsampleStorageTex.format=r.RGBAFormat,this._downsampleStorageTex.minFilter=r.NearestFilter,this._downsampleStorageTex.magFilter=r.NearestFilter,this._reductionStorageTex=new t.StorageTexture(1,1),this._reductionStorageTex.type=r.FloatType,this._reductionStorageTex.format=r.RGBAFormat,this._reductionStorageTex.minFilter=r.NearestFilter,this._reductionStorageTex.magFilter=r.NearestFilter,this._reductionReadTarget=new t.RenderTarget(1,1,e),this._adaptationResult=(0,n.attributeArray)(1,`vec4`),this._readbackBuffer=new t.ReadbackBuffer(16),this._readbackBuffer.name=`AutoExposureAdaptation`,this._histogramBuffer=(0,n.attributeArray)(Za,`uint`).toAtomic()}_buildCompute(){this._buildDownsampleCompute(),this._buildHistogramCompute(),this._buildHistogramAnalyzeCompute(),this._buildAdaptationCompute()}_buildDownsampleCompute(){let e=this._inputTexNode,t=this._downsampleStorageTex,r=this.epsilonU,i=this.inputResW,a=this.inputResH;this._downsampleComputeNode=(0,n.Fn)(()=>{let o=(0,n.int)(n.workgroupId.x).mul(8).add((0,n.int)(n.localId.x)),s=(0,n.int)(n.workgroupId.y).mul(8).add((0,n.int)(n.localId.y)),c=i.div((0,n.float)(64)),l=a.div((0,n.float)(64)),u=(0,n.float)(o).mul(c),d=(0,n.float)(s).mul(l),f=(0,n.float)(0).toVar(),p=(0,n.float)(0).toVar();for(let t=0;t<4;t++)for(let i=0;i<4;i++){let a=Ht((0,n.textureLoad)(e,(0,n.ivec2)((0,n.int)(u.add((0,n.float)((i+.5)/4).mul(c))),(0,n.int)(d.add((0,n.float)((t+.5)/4).mul(l))))).xyz);(0,n.If)(a.greaterThan(r),()=>{f.addAssign(a.add(r).log()),p.addAssign(1)})}(0,n.textureStore)(t,(0,n.uvec2)((0,n.uint)(o),(0,n.uint)(s)),(0,n.vec4)(f,p,0,1)).toWriteOnly()})().compute([64/8,64/8,1],[8,8,1])}_buildHistogramCompute(){let e=this._downsampleTarget.texture,t=this._histogramBuffer,r=this.centerWeightU;this._histogramComputeNode=(0,n.Fn)(()=>{let i=n.localId.x;(0,n.atomicStore)(t.element(i),(0,n.uint)(0)),(0,n.workgroupBarrier)();for(let a=0;a<16;a++){let o=i.mul(16).add(a),s=o.mod(64),c=o.div(64),l=(0,n.textureLoad)(e,(0,n.ivec2)((0,n.int)(s),(0,n.int)(c))),u=l.x,d=l.y;(0,n.If)(d.greaterThan(0),()=>{let e=(0,n.uint)(u.div(d).sub((0,n.float)(Qa)).div((0,n.float)($a)).mul((0,n.float)(Za)).floor().clamp(0,(0,n.float)(Za-1))),i=(0,n.float)(s).add(.5).div((0,n.float)(64)),a=(0,n.float)(c).add(.5).div((0,n.float)(64)),o=i.sub(.5),l=a.sub(.5),f=(0,n.uint)(o.mul(o).add(l.mul(l)).mul(r).negate().exp().mul((0,n.float)(to)));(0,n.atomicAdd)(t.element(e),f)})}})().compute([1,1,1],[256,1,1])}_buildHistogramAnalyzeCompute(){let e=this._histogramBuffer,t=this._reductionStorageTex,r=this.lowPercentileU,i=this.highPercentileU;this._histogramAnalyzeNode=(0,n.Fn)(()=>{let a=(0,n.float)(0).toVar();(0,n.Loop)(Za,({i:t})=>{a.addAssign((0,n.float)((0,n.atomicLoad)(e.element(t))))});let o=a.mul(r),s=a.mul(i),c=(0,n.float)(0).toVar(),l=(0,n.float)(0).toVar(),u=(0,n.float)(0).toVar(),d=(0,n.float)(0).toVar();(0,n.Loop)(Za,({i:t})=>{let r=(0,n.float)((0,n.atomicLoad)(e.element(t)));d.assign(c),c.addAssign(r),(0,n.If)(d.lessThan(s).and(c.greaterThan(o)),()=>{let e=(0,n.float)(Qa).add((0,n.float)(t).add(.5).mul((0,n.float)(eo)));l.addAssign(e.mul(r)),u.addAssign(r)})});let f=(0,n.max)(u,(0,n.float)(1)),p=l.div(f),m=p.exp();(0,n.textureStore)(t,(0,n.uvec2)((0,n.uint)(0),(0,n.uint)(0)),(0,n.vec4)(m,a,p,1)).toWriteOnly()})().compute(1,[1,1,1])}_buildAdaptationCompute(){let e=this._reductionReadTexNode,t=this._adaptationResult,r=this.keyValueU,i=this.minExposureU,a=this.maxExposureU,o=this.adaptSpeedBrightU,s=this.adaptSpeedDarkU,c=this.deltaTimeU,l=this.isFirstFrameU,u=this.previousExposureU;this._adaptationComputeNode=(0,n.Fn)(()=>{let d=(0,n.textureLoad)(e,(0,n.ivec2)((0,n.int)(0),(0,n.int)(0))).x,f=no(d,u,r,i,a,o,s,c,l);t.element((0,n.uint)(0)).assign(f)})().compute(1,[1,1,1])}setupEventListeners(){this.on(`pipeline:reset`,()=>this.reset()),this.on(`autoexposure:resetHistory`,()=>this.resetHistory()),this.on(`autoexposure:toggle`,e=>{this.enabled=e}),this.on(`autoexposure:updateParameters`,e=>e&&this.updateParameters(e))}render(e){if(!this.enabled)return;let t=e.getTexture(`edgeFiltering:output`)||e.getTexture(`asvgf:output`)||e.getTexture(`pathtracer:color`);if(!t)return;let n=performance.now(),r=Math.min((n-this.lastTime)/1e3,.1);if(this.lastTime=n,this.deltaTimeU.value=this.isFirstFrame?1:r,this.isFirstFrameU.value=+!!this.isFirstFrame,this.previousExposureU.value=this.currentExposure,this.inputResW.value=t.image?.width||1,this.inputResH.value=t.image?.height||1,this._inputTexNode.value=t,this.renderer.compute(this._downsampleComputeNode),this.renderer.copyTextureToTexture(this._downsampleStorageTex,this._downsampleTarget.texture),this.renderer.compute(this._histogramComputeNode),this.renderer.compute(this._histogramAnalyzeNode),this.renderer.copyTextureToTexture(this._reductionStorageTex,this._reductionReadTarget.texture),this._reductionReadTexNode.value=this._reductionReadTarget.texture,this.renderer.compute(this._adaptationComputeNode),!this._pendingReadback){this._pendingReadback=!0;let e=this._readbackGeneration;this.renderer.getArrayBufferAsync(this._adaptationResult.value,this._readbackBuffer).then(t=>{let n=t&&t.buffer?new Float32Array(t.buffer.slice(0)):null;this._readbackBuffer.release(),this._pendingReadback=!1,n&&e===this._readbackGeneration&&this._applyReadback(n)}).catch(()=>{try{this._readbackBuffer.release()}catch{}this._pendingReadback=!1})}e.setState(`autoexposure:value`,this.currentExposure),e.setState(`autoexposure:avgLuminance`,this.currentLuminance),this.emit(`autoexposure:updated`,{exposure:this.currentExposure,luminance:this.currentLuminance,targetExposure:this.targetExposure}),this.isFirstFrame=!1}_applyReadback(e){if(!this.enabled||!e||e.length<3)return;let t=e[0],n=e[1],r=e[2];(!isFinite(t)||t<=0)&&(t=1),(!isFinite(n)||n<=0)&&(n=.18),(!isFinite(r)||r<=0)&&(r=t),this.currentExposure=t,this.currentLuminance=n,this.targetExposure=r,this.renderer.toneMappingExposure=t}reset(){this.lastTime=performance.now(),this._readbackGeneration++,this._pendingReadback=!1}resetHistory(){this.isFirstFrame=!0,this.currentExposure=1,this.currentLuminance=.18,this.targetExposure=1,this.lastTime=performance.now(),this._readbackGeneration++,this._pendingReadback=!1}setSize(){}setExposure(e){this.currentExposure=e,this.previousExposureU.value=e,this.renderer.toneMappingExposure=e}getExposure(){return this.currentExposure}getLuminance(){return this.currentLuminance}updateParameters(e){e.keyValue!==void 0&&(this.keyValueU.value=e.keyValue),e.minExposure!==void 0&&(this.minExposureU.value=e.minExposure),e.maxExposure!==void 0&&(this.maxExposureU.value=e.maxExposure),e.adaptSpeedBright!==void 0&&(this.adaptSpeedBrightU.value=e.adaptSpeedBright),e.adaptSpeedDark!==void 0&&(this.adaptSpeedDarkU.value=e.adaptSpeedDark),e.lowPercentile!==void 0&&(this.lowPercentileU.value=e.lowPercentile),e.highPercentile!==void 0&&(this.highPercentileU.value=e.highPercentile),e.centerWeight!==void 0&&(this.centerWeightU.value=e.centerWeight)}dispose(){this._downsampleComputeNode?.dispose(),this._histogramComputeNode?.dispose(),this._histogramAnalyzeNode?.dispose(),this._adaptationComputeNode?.dispose(),this._downsampleTarget?.dispose(),this._downsampleStorageTex?.dispose(),this._reductionStorageTex?.dispose(),this._reductionReadTarget?.dispose(),this._readbackBuffer?.dispose(),this._inputTexNode?.dispose(),this._reductionReadTexNode?.dispose()}};function io({colorTexNode:e,ndTexNode:t,motionTexNode:r,readCacheTexNode:i,readPrevNDTexNode:a,writeCacheTex:o,writePrevNDTex:s,resW:c,resH:l,temporalAlpha:u,phiNormal:d,phiDepth:f,maxHistory:p,framesSinceReset:m}){return(0,n.Fn)(()=>{let h=(0,n.int)(n.workgroupId.x).mul(8).add((0,n.int)(n.localId.x)),g=(0,n.int)(n.workgroupId.y).mul(8).add((0,n.int)(n.localId.y));(0,n.If)(h.lessThan((0,n.int)(c)).and(g.lessThan((0,n.int)(l))),()=>{let _=(0,n.ivec2)(h,g),v=(0,n.textureLoad)(e,_).xyz,y=(0,n.textureLoad)(t,_),b=(0,n.vec4)(v,1).toVar();(0,n.If)(m.greaterThan((0,n.int)(0)),()=>{let e=(0,n.textureLoad)(r,_),t=e.w.greaterThan(.5),o=(0,n.float)(h).sub(e.x.mul(c)),s=(0,n.float)(g).sub(e.y.mul(l)),m=o.greaterThanEqual(0).and(o.lessThan((0,n.float)(c))).and(s.greaterThanEqual(0)).and(s.lessThan((0,n.float)(l)));(0,n.If)(t.and(m),()=>{let e=(0,n.ivec2)((0,n.int)(o).clamp((0,n.int)(0),(0,n.int)(c).sub(1)),(0,n.int)(s).clamp((0,n.int)(0),(0,n.int)(l).sub(1))),t=y.xyz.mul(2).sub(1),r=(0,n.textureLoad)(a,e),m=tn(t,r.xyz.mul(2).sub(1),y.w,r.w,d,f);(0,n.If)(m.greaterThan(.01),()=>{let t=(0,n.textureLoad)(i,e),r=t.xyz,a=t.w,o=(0,n.mix)(r,v,(0,n.min)((0,n.max)(u,(0,n.float)(1).div(a.add(1))).div((0,n.max)(m,(0,n.float)(.1))),1)),s=(0,n.min)(a.add(1),p);b.assign((0,n.vec4)(o,s))}).Else(()=>{b.assign((0,n.vec4)(v,1))})}).Else(()=>{b.assign((0,n.vec4)(v,1))})}),(0,n.textureStore)(o,(0,n.uvec2)(h,g),b).toWriteOnly(),(0,n.textureStore)(s,(0,n.uvec2)(h,g),y).toWriteOnly()})})}function ao({colorTexNode:e,ndTexNode:t,readCacheTexNode:r,outputTex:i,resW:a,resH:o,spatialRadius:s,spatialWeight:c,phiNormal:l,phiDepth:u}){let d=[[1,0],[-1,0],[0,1],[0,-1],[1,1],[-1,1],[1,-1],[-1,-1]];return(0,n.Fn)(()=>{let f=(0,n.int)(n.workgroupId.x).mul(8).add((0,n.int)(n.localId.x)),p=(0,n.int)(n.workgroupId.y).mul(8).add((0,n.int)(n.localId.y));(0,n.If)(f.lessThan((0,n.int)(a)).and(p.lessThan((0,n.int)(o))),()=>{let m=(0,n.ivec2)(f,p),h=(0,n.textureLoad)(r,m),g=h.xyz,_=h.w,v=(0,n.textureLoad)(t,m),y=v.xyz.mul(2).sub(1),b=(0,n.float)(1).sub(_.div(16).clamp(0,1)),x=c.mul(b),S=(0,n.vec3)(g).toVar(),C=(0,n.float)(1).toVar();for(let e=0;e<d.length;e++){let[i,c]=d[e],m=(0,n.ivec2)(f.add((0,n.int)(s).mul(i)).clamp((0,n.int)(0),(0,n.int)(a).sub(1)),p.add((0,n.int)(s).mul(c)).clamp((0,n.int)(0),(0,n.int)(o).sub(1))),h=(0,n.textureLoad)(r,m).xyz,g=(0,n.textureLoad)(t,m),_=tn(y,g.xyz.mul(2).sub(1),v.w,g.w,l,u);S.addAssign(h.mul(_)),C.addAssign(_)}let w=(0,n.mix)(g,S.div((0,n.max)(C,1e-4)),x),T=(0,n.textureLoad)(e,m).w;(0,n.textureStore)(i,(0,n.uvec2)(f,p),(0,n.vec4)(w,T)).toWriteOnly()})})}var oo=class extends R{constructor(e,i={}){super(`SSRC`,{...i,executionMode:L.PER_CYCLE}),this.renderer=e,this.resW=(0,n.uniform)(1),this.resH=(0,n.uniform)(1),this.temporalAlpha=(0,n.uniform)(i.temporalAlpha??.1),this.phiNormal=(0,n.uniform)(i.phiNormal??128),this.phiDepth=(0,n.uniform)(i.phiDepth??.5),this.maxHistory=(0,n.uniform)(i.maxHistory??128),this.spatialRadius=(0,n.uniform)(i.spatialRadius??4,`int`),this.spatialWeight=(0,n.uniform)(i.spatialWeight??.4),this._framesSinceReset=(0,n.uniform)(0,`int`),this._colorTexNode=new t.TextureNode,this._ndTexNode=new t.TextureNode,this._motionTexNode=new t.TextureNode,this._readCacheTexNode=new t.TextureNode,this._readPrevNDTexNode=new t.TextureNode,this._readPass1CacheTexNode=new t.TextureNode,this._cacheTexA=this._createStorageTex(1,1,r.NearestFilter),this._cacheTexB=this._createStorageTex(1,1,r.NearestFilter),this._prevNDTexA=this._createStorageTex(1,1,r.NearestFilter),this._prevNDTexB=this._createStorageTex(1,1,r.NearestFilter),this._outputTex=this._createStorageTex(1,1,r.LinearFilter),this._currentPingPong=0,this._dispatchX=1,this._dispatchY=1,this._buildComputeNodes()}setupEventListeners(){this.on(`pipeline:reset`,()=>this._resetCache()),this.on(`camera:moved`,()=>this._resetCache())}render(e){if(!this.enabled){e.removeTexture(`ssrc:output`);return}let t=e.getTexture(`pathtracer:color`);if(t?.image){let{width:e,height:n}=t.image;(e!==this._cacheTexA.image.width||n!==this._cacheTexA.image.height)&&this.setSize(e,n)}let n=e.getTexture(`pathtracer:normalDepth`);if(!n||!t)return;this._colorTexNode.value=t,this._ndTexNode.value=n;let r=e.getTexture(`motionVector:screenSpace`);r&&(this._motionTexNode.value=r);let[i,a,o]=this._currentPingPong===0?[this._cacheTexB,this._cacheTexA,this._prevNDTexB]:[this._cacheTexA,this._cacheTexB,this._prevNDTexA];this._readCacheTexNode.value=i,this._readPrevNDTexNode.value=o,this.renderer.compute(this._currentPingPong===0?this._pass1NodeA:this._pass1NodeB),this._readPass1CacheTexNode.value=a,this.renderer.compute(this._pass2Node),this._framesSinceReset.value=Math.min(this._framesSinceReset.value+1,9999),e.setTexture(`ssrc:output`,this._outputTex),this._currentPingPong=1-this._currentPingPong}reset(){this._resetCache()}setSize(e,t){if(e<1||t<1)return;this._cacheTexA.setSize(e,t),this._cacheTexB.setSize(e,t),this._prevNDTexA.setSize(e,t),this._prevNDTexB.setSize(e,t),this._outputTex.setSize(e,t),this.resW.value=e,this.resH.value=t,this._dispatchX=Math.ceil(e/8),this._dispatchY=Math.ceil(t/8);let n=[this._dispatchX,this._dispatchY,1];this._pass1NodeA&&(this._pass1NodeA.dispatchSize=n),this._pass1NodeB&&(this._pass1NodeB.dispatchSize=n),this._pass2Node&&(this._pass2Node.dispatchSize=n),this._resetCache()}dispose(){this._pass1NodeA?.dispose(),this._pass1NodeB?.dispose(),this._pass2Node?.dispose(),this._cacheTexA.dispose(),this._cacheTexB.dispose(),this._prevNDTexA.dispose(),this._prevNDTexB.dispose(),this._outputTex.dispose(),this._colorTexNode?.dispose(),this._ndTexNode?.dispose(),this._motionTexNode?.dispose(),this._readCacheTexNode?.dispose(),this._readPrevNDTexNode?.dispose(),this._readPass1CacheTexNode?.dispose()}updateParameters(e){e.temporalAlpha!==void 0&&(this.temporalAlpha.value=e.temporalAlpha),e.phiNormal!==void 0&&(this.phiNormal.value=e.phiNormal),e.phiDepth!==void 0&&(this.phiDepth.value=e.phiDepth),e.maxHistory!==void 0&&(this.maxHistory.value=e.maxHistory),e.spatialRadius!==void 0&&(this.spatialRadius.value=e.spatialRadius),e.spatialWeight!==void 0&&(this.spatialWeight.value=e.spatialWeight)}_createStorageTex(e,n,i){let a=new t.StorageTexture(e,n);return a.type=r.HalfFloatType,a.format=r.RGBAFormat,a.minFilter=i,a.magFilter=i,a}_resetCache(){this._currentPingPong=0,this._framesSinceReset.value=0}_buildComputeNodes(){let e={colorTexNode:this._colorTexNode,ndTexNode:this._ndTexNode,motionTexNode:this._motionTexNode,readCacheTexNode:this._readCacheTexNode,readPrevNDTexNode:this._readPrevNDTexNode,resW:this.resW,resH:this.resH,temporalAlpha:this.temporalAlpha,phiNormal:this.phiNormal,phiDepth:this.phiDepth,maxHistory:this.maxHistory},t=io({...e,writeCacheTex:this._cacheTexA,writePrevNDTex:this._prevNDTexA,framesSinceReset:this._framesSinceReset}),n=io({...e,writeCacheTex:this._cacheTexB,writePrevNDTex:this._prevNDTexB,framesSinceReset:this._framesSinceReset}),r=[this._dispatchX,this._dispatchY,1],i=[8,8,1];this._pass1NodeA=t().compute(r,i),this._pass1NodeB=n().compute(r,i),this._pass2Node=ao({colorTexNode:this._colorTexNode,ndTexNode:this._ndTexNode,readCacheTexNode:this._readPass1CacheTexNode,outputTex:this._outputTex,resW:this.resW,resH:this.resH,spatialRadius:this.spatialRadius,spatialWeight:this.spatialWeight,phiNormal:this.phiNormal,phiDepth:this.phiDepth})().compute(r,i)}},so=class extends R{constructor(e,i={}){super(`Compositor`,{...i,executionMode:L.ALWAYS}),this.renderer=e,this.saturation=(0,n.uniform)(i.saturation??1),this._transparentBackground=(0,n.uniform)(0,`int`),this._sourceTexNode=new t.TextureNode;let a=this._sourceTexNode.sample((0,n.uv)()),o=(0,n.mix)((0,n.vec3)((0,n.dot)(a.xyz,Lt)),a.xyz,this.saturation),s=(0,n.select)(this._transparentBackground,a.w,1);this.compositorMaterial=new t.MeshBasicNodeMaterial,this.compositorMaterial.colorNode=(0,n.vec4)(o,s),this.compositorMaterial.blending=r.NoBlending,this.compositorQuad=new t.QuadMesh(this.compositorMaterial)}_resolveSourceTexture(e){return e.getTexture(`bloom:output`)||e.getTexture(`edgeFiltering:output`)||e.getTexture(`asvgf:output`)||e.getTexture(`ssrc:output`)||e.getTexture(`pathtracer:color`)}render(e){if(!this.enabled)return;let t=this._resolveSourceTexture(e);t&&(this._sourceTexNode.value=t,this.renderer.setRenderTarget(null),this.compositorQuad.render(this.renderer))}setSaturation(e){this.saturation.value=e}setTransparentBackground(e){this._transparentBackground.value=+!!e}dispose(){this._sourceTexNode?.dispose(),this.compositorMaterial?.dispose(),this.compositorQuad=null}},co=class{constructor(){this.textures=new Map,this.renderTargets=new Map,this.uniforms=new Map,this.state={frame:0,accumulatedFrames:0,renderMode:0,interactionMode:!1,isComplete:!1,tileInfo:null,currentTile:0,totalTiles:0,cameraChanged:!1,cameraMoving:!1,width:0,height:0,time:0,deltaTime:0,enableASVGF:!1,enableAdaptiveSampling:!1,enableEdgeFiltering:!1},this._stateChangeCallbacks=new Map}setTexture(e,t){this.textures.set(e,t)}getTexture(e){return this.textures.get(e)}hasTexture(e){return this.textures.has(e)}removeTexture(e){this.textures.delete(e)}getTextureNames(){return Array.from(this.textures.keys())}clearTextures(){this.textures.clear()}setRenderTarget(e,t){this.renderTargets.set(e,t)}getRenderTarget(e){return this.renderTargets.get(e)}hasRenderTarget(e){return this.renderTargets.has(e)}removeRenderTarget(e){this.renderTargets.delete(e)}getRenderTargetNames(){return Array.from(this.renderTargets.keys())}clearRenderTargets(){this.renderTargets.clear()}setUniform(e,t){this.uniforms.has(e)?this.uniforms.get(e).value=t:this.uniforms.set(e,{value:t})}getUniform(e){return this.uniforms.get(e)}getUniformValue(e){return this.uniforms.get(e)?.value}hasUniform(e){return this.uniforms.has(e)}removeUniform(e){this.uniforms.delete(e)}getUniformNames(){return Array.from(this.uniforms.keys())}clearUniforms(){this.uniforms.clear()}setState(e,t){let n=this.state[e],r=n!==t;return r&&(this.state[e]=t,this._notifyStateChange(e,t,n)),r}getState(e){return this.state[e]}getAllState(){return this.state}setStates(e){let t=[];for(let[n,r]of Object.entries(e))this.setState(n,r)&&t.push(n);return t}hasState(e){return e in this.state}watchState(e,t){this._stateChangeCallbacks.has(e)||this._stateChangeCallbacks.set(e,[]),this._stateChangeCallbacks.get(e).push(t)}unwatchState(e,t){if(!this._stateChangeCallbacks.has(e))return;let n=this._stateChangeCallbacks.get(e),r=n.indexOf(t);r>-1&&n.splice(r,1)}_notifyStateChange(e,t,n){if(!this._stateChangeCallbacks.has(e))return;let r=this._stateChangeCallbacks.get(e);for(let i of r)try{i(t,n)}catch(t){console.error(`Error in state change callback for '${e}':`,t)}}reset(){this.state.frame=0,this.state.accumulatedFrames=0,this.state.isComplete=!1,this.state.cameraChanged=!0,this.state.currentTile=0}incrementFrame(){return this.state.frame++,this.state.accumulatedFrames++,this.state.frame}dispose(){this.textures.clear(),this.renderTargets.clear(),this.uniforms.clear(),this._stateChangeCallbacks.clear(),this.state={}}},lo=class extends r.EventDispatcher{constructor(){super(),this._onceCallbacks=new Map}on(e,t){this.addEventListener(e,t)}once(e,t){let n=r=>{t(r),this.off(e,n),this._onceCallbacks.delete(t)};this._onceCallbacks.set(t,n),this.on(e,n)}off(e,t){let n=this._onceCallbacks.get(t);n?(this.removeEventListener(e,n),this._onceCallbacks.delete(t)):this.removeEventListener(e,t)}emit(e,t){t&&typeof t==`object`&&t.type?this.dispatchEvent(t):this.dispatchEvent({type:e,...t})}removeAllListeners(e){if(e){for(let[t,n]of this._onceCallbacks.entries())this.hasEventListener(e,n)&&(this.removeEventListener(e,n),this._onceCallbacks.delete(t));this._listeners&&this._listeners[e]&&delete this._listeners[e]}else this._onceCallbacks.clear(),this._listeners&&={}}listenerCount(e){return!this._listeners||!this._listeners[e]?0:this._listeners[e].length}clear(){this.removeAllListeners()}eventNames(){return this._listeners?Object.keys(this._listeners):[]}},uo=class{constructor(e,t,n){this.renderer=e,this.width=t,this.height=n,this.stages=[],this.context=new co,this.eventBus=new lo,this.context.setState(`width`,t),this.context.setState(`height`,n),this.stats={enabled:!1,logSkipped:!1,timings:new Map,frameCount:0}}addStage(e){this.stages.push(e),e.initialize(this.context,this.eventBus),this.stats.enabled&&console.log(`[Pipeline] Added stage: ${e.name}`)}getStage(e){return this.stages.find(t=>t.name===e)}removeStage(e){let t=this.stages.findIndex(t=>t.name===e);if(t>-1){let e=this.stages[t];return this.stages.splice(t,1),e.dispose&&e.dispose(),this.stats.timings.delete(e.name),!0}return!1}setStageEnabled(e,t){let n=this.getStage(e);n&&(t?n.enable():n.disable())}render(e=null){let t=this.stats.enabled?performance.now():0;for(let t of this.stages){if(!t.shouldExecuteThisFrame(this.context)){this.stats.enabled&&this.stats.logSkipped&&console.log(`[Pipeline] Skipped stage '${t.name}' (executionMode: ${t.executionMode})`);continue}try{let n=this.stats.enabled?performance.now():0;if(t.render(this.context,e),this.stats.enabled){let e=performance.now()-n;this.stats.timings.has(t.name)||this.stats.timings.set(t.name,[]);let r=this.stats.timings.get(t.name);r.push(e),r.length>60&&r.shift()}}catch(e){console.error(`[Pipeline] Error in stage '${t.name}':`,e)}}if(this.context.incrementFrame(),this.eventBus.emit(`frame:complete`,{frame:this.context.getState(`frame`),accumulatedFrames:this.context.getState(`accumulatedFrames`)}),this.stats.enabled){let e=performance.now()-t;this.stats.timings.has(`_total`)||this.stats.timings.set(`_total`,[]);let n=this.stats.timings.get(`_total`);n.push(e),n.length>60&&n.shift(),this.stats.frameCount++}}reset(){this.eventBus.emit(`pipeline:reset`);for(let e of this.stages)if(e.reset)try{e.reset()}catch(t){console.error(`[Pipeline] Error resetting stage '${e.name}':`,t)}this.context.reset(),this.stats.enabled&&(this.stats.timings.clear(),this.stats.frameCount=0)}setSize(e,t){this.width=e,this.height=t,this.context.setState(`width`,e),this.context.setState(`height`,t),this.eventBus.emit(`pipeline:resize`,{width:e,height:t});for(let n of this.stages)if(n.setSize)try{n.setSize(e,t)}catch(e){console.error(`[Pipeline] Error resizing stage '${n.name}':`,e)}}dispose(){for(let e of this.stages)if(e.dispose)try{e.dispose()}catch(t){console.error(`[Pipeline] Error disposing stage '${e.name}':`,t)}this.stages=[],this.context.dispose(),this.eventBus.clear(),this.stats.timings.clear()}setStatsEnabled(e){this.stats.enabled=e,e||(this.stats.timings.clear(),this.stats.frameCount=0)}getStats(){if(!this.stats.enabled)return null;let e={frameCount:this.stats.frameCount,stages:{},total:0};for(let[t,n]of this.stats.timings.entries()){if(n.length===0)continue;let r=n.reduce((e,t)=>e+t,0)/n.length,i=Math.min(...n),a=Math.max(...n);t===`_total`?(e.total=r,e.totalMin=i,e.totalMax=a):e.stages[t]={avg:r,min:i,max:a}}return e}logStats(){let e=this.getStats();if(!e){console.log(`[Pipeline] Stats not enabled`);return}console.group(`[Pipeline] Performance Stats`),console.log(`Frames: ${e.frameCount}`),e.totalMin===void 0?console.log(`Total: no frames recorded yet (pipeline.render() has not run since stats were enabled — the path tracer may have converged and stopped its animation loop)`):console.log(`Total: ${e.total.toFixed(2)}ms (min: ${e.totalMin.toFixed(2)}ms, max: ${e.totalMax.toFixed(2)}ms)`);for(let[t,n]of Object.entries(e.stages))console.log(` ${t}: ${n.avg.toFixed(2)}ms (min: ${n.min.toFixed(2)}ms, max: ${n.max.toFixed(2)}ms)`);console.groupEnd()}getInfo(){return{stageCount:this.stages.length,enabledStages:this.stages.filter(e=>e.enabled).length,stages:this.stages.map(e=>({name:e.name,enabled:e.enabled})),contextState:this.context.getAllState(),textures:this.context.getTextureNames(),renderTargets:this.context.getRenderTargetNames(),uniforms:this.context.getUniformNames(),events:this.eventBus.eventNames()}}logInfo(){let e=this.getInfo();console.group(`[Pipeline] Info`),console.log(`Stages:`,e.stages),console.log(`Context Textures:`,e.textures),console.log(`Context Render Targets:`,e.renderTargets),console.log(`Context Uniforms:`,e.uniforms),console.log(`Event Types:`,e.events),console.log(`State:`,e.contextState),console.groupEnd()}},fo=class{constructor(){this.timeElapsed=0,this.lastResetTime=performance.now(),this.renderCompleteDispatched=!1}updateTime(){this.timeElapsed=(performance.now()-this.lastResetTime)/1e3}isTimeLimitReached(e,t){return e===`time`&&t>0&&this.timeElapsed>=t}isLimitReached(e,t,n){return e?this.isTimeLimitReached(t,n)?!0:e.frameCount>=e.completionThreshold:!1}markComplete(){return this.renderCompleteDispatched?!1:(this.renderCompleteDispatched=!0,!0)}reset(){this.timeElapsed=0,this.lastResetTime=performance.now(),this.renderCompleteDispatched=!1}resumeFromPause(){this.renderCompleteDispatched=!1,this.lastResetTime=performance.now()-this.timeElapsed*1e3}},po=class extends r.EventDispatcher{constructor({scene:e,camera:t,canvas:n,assetLoader:i,pathTracer:a,floorPlane:o}){super(),this.scene=e,this.camera=t,this.canvas=n,this.assetLoader=i,this.pathTracer=a,this.floorPlane=o,this.raycaster=new r.Raycaster,this.focusMode=!1,this.focusPointIndicator=null,this.afPointPlacementMode=!1,this.handleAFPointClick=this.handleAFPointClick.bind(this),this.selectedObject=null,this.selectMode=!1,this.clickTimeout=null,this.mouseDownPosition=null,this.dragThreshold=5,this.handleFocusClick=this.handleFocusClick.bind(this),this.handleSelectClick=this.handleSelectClick.bind(this),this.handleSelectDoubleClick=this.handleSelectDoubleClick.bind(this),this.handleMouseDown=this.handleMouseDown.bind(this),this.handleMouseUp=this.handleMouseUp.bind(this),this.handleContextMenu=this.handleContextMenu.bind(this),this.handleContextPointerDown=this.handleContextPointerDown.bind(this),this.handleContextPointerUp=this.handleContextPointerUp.bind(this),this.contextPointerDownPosition=null,this.canvas.addEventListener(`pointerdown`,this.handleContextPointerDown),this.canvas.addEventListener(`pointerup`,this.handleContextPointerUp),this.canvas.addEventListener(`contextmenu`,this.handleContextMenu),this._overlayManager=null,this._transformManager=null,this._appDispatch=null,this._orbitControls=null}setDependencies({overlayManager:e,transformManager:t,appDispatch:n,orbitControls:r}){this._overlayManager=e||null,this._transformManager=t||null,this._appDispatch=n||null,this._orbitControls=r||null}select(e){let t=this._overlayManager?.getHelper(`outline`);t&&t.setSelectedObjects(e?[e]:[]),this.selectedObject=e||null,e?this._transformManager?.attach(e):this._transformManager?.detach(),this._appDispatch?.({type:z.OBJECT_SELECTED,object:e||null})}deselect(){this.select(null)}disableMode(){this.disableSelectMode(),this._transformManager?.detach()}on(e,t){return this.addEventListener(e,t),()=>this.removeEventListener(e,t)}toggleFocusMode(){return this.focusMode=!this.focusMode,this.canvas.style.cursor=this.focusMode?`crosshair`:`auto`,this.focusMode?this.canvas.addEventListener(`click`,this.handleFocusClick):this.canvas.removeEventListener(`click`,this.handleFocusClick),this._orbitControls&&(this._orbitControls.enabled=!this.focusMode),this.dispatchEvent({type:`focusModeChanged`,enabled:this.focusMode}),this.focusMode}handleFocusClick(e){let t=this.getMouseCoordinates(e);this.raycaster.setFromCamera(t,this.camera);let n=this.raycaster.intersectObjects(this.scene.children,!0);if(n.length>0){let e=n[0],t=e.distance;this.showFocusPoint(e.point),this.toggleFocusMode(),this.dispatchEvent({type:`focusChanged`,distance:t/this.assetLoader.getSceneScale(),worldDistance:t})}}showFocusPoint(e){this.focusPointIndicator&&this.scene.remove(this.focusPointIndicator),this.focusPointIndicator=new r.Mesh(new r.SphereGeometry(this.assetLoader.getSceneScale()*.02,16,16),new r.MeshBasicMaterial({color:65280,transparent:!0,opacity:.8,depthTest:!1})),this.focusPointIndicator.position.copy(e),this.scene.add(this.focusPointIndicator),setTimeout(()=>{this.focusPointIndicator&&=(this.scene.remove(this.focusPointIndicator),null)},2e3)}enterAFPointPlacementMode(){this.afPointPlacementMode=!0,this.canvas.style.cursor=`crosshair`,this.canvas.addEventListener(`click`,this.handleAFPointClick)}exitAFPointPlacementMode(){this.afPointPlacementMode=!1,this.canvas.style.cursor=`auto`,this.canvas.removeEventListener(`click`,this.handleAFPointClick)}handleAFPointClick(e){let t=this.canvas.getBoundingClientRect(),n=(e.clientX-t.left)/t.width,r=(e.clientY-t.top)/t.height;this.exitAFPointPlacementMode(),this.dispatchEvent({type:`afPointPlaced`,point:{x:n,y:r}})}toggleSelectMode(){return this.selectMode=!this.selectMode,this.canvas.style.cursor=this.selectMode?`pointer`:`auto`,this.selectMode?(this.canvas.addEventListener(`mousedown`,this.handleMouseDown),this.canvas.addEventListener(`mouseup`,this.handleMouseUp),this.canvas.addEventListener(`click`,this.handleSelectClick),this.canvas.addEventListener(`dblclick`,this.handleSelectDoubleClick)):(this.canvas.removeEventListener(`mousedown`,this.handleMouseDown),this.canvas.removeEventListener(`mouseup`,this.handleMouseUp),this.canvas.removeEventListener(`click`,this.handleSelectClick),this.canvas.removeEventListener(`dblclick`,this.handleSelectDoubleClick),this.clickTimeout&&=(clearTimeout(this.clickTimeout),null),this.mouseDownPosition=null),this.dispatchEvent({type:`selectModeChanged`,enabled:this.selectMode}),this.selectMode}disableSelectMode(){this.selectMode&&(this.selectMode=!1,this.canvas.style.cursor=`auto`,this.canvas.removeEventListener(`mousedown`,this.handleMouseDown),this.canvas.removeEventListener(`mouseup`,this.handleMouseUp),this.canvas.removeEventListener(`click`,this.handleSelectClick),this.canvas.removeEventListener(`dblclick`,this.handleSelectDoubleClick),this.clickTimeout&&=(clearTimeout(this.clickTimeout),null),this.mouseDownPosition=null,this.dispatchEvent({type:`selectModeChanged`,enabled:!1}))}handleMouseDown(e){this.mouseDownPosition={x:e.clientX,y:e.clientY,button:e.button}}wasMouseDragged(e){if(!this.mouseDownPosition)return!1;let t=Math.abs(e.clientX-this.mouseDownPosition.x),n=Math.abs(e.clientY-this.mouseDownPosition.y);return Math.sqrt(t*t+n*n)>this.dragThreshold}handleSelectClick(e){if(this.wasMouseDragged(e)){this.mouseDownPosition=null;return}if(this.mouseDownPosition=null,this.clickTimeout){clearTimeout(this.clickTimeout),this.clickTimeout=null;return}this.clickTimeout=setTimeout(()=>{this.clickTimeout=null;let t=this.getMouseCoordinates(e);this.raycaster.setFromCamera(t,this.camera);let n=this.raycaster.intersectObjects(this.scene.children,!0),r=this.filterValidIntersects(n);if(r.length>0){let e=r[0].object,t=this.selectedObject;t&&t.uuid===e.uuid?this.dispatchEvent({type:`objectDeselected`,object:e,uuid:e.uuid}):this.dispatchEvent({type:`objectSelected`,object:e,uuid:e.uuid})}else this.dispatchEvent({type:`objectDeselected`})},250)}handleSelectDoubleClick(e){if(this.wasMouseDragged(e)){this.mouseDownPosition=null;return}this.mouseDownPosition=null,this.clickTimeout&&=(clearTimeout(this.clickTimeout),null);let t=this.getMouseCoordinates(e);this.raycaster.setFromCamera(t,this.camera);let n=this.raycaster.intersectObjects(this.scene.children,!0),r=this.filterValidIntersects(n);if(r.length>0){let e=r[0].object;this.dispatchEvent({type:`objectDoubleClicked`,object:e,uuid:e.uuid})}}handleMouseUp(){}handleContextPointerDown(e){e.button===2&&(this.contextPointerDownPosition={x:e.clientX,y:e.clientY})}handleContextPointerUp(e){if(e.button!==2)return;if(this.contextPointerDownPosition){let t=Math.abs(e.clientX-this.contextPointerDownPosition.x),n=Math.abs(e.clientY-this.contextPointerDownPosition.y);if(Math.sqrt(t*t+n*n)>this.dragThreshold){this.contextPointerDownPosition=null;return}}else return;this.contextPointerDownPosition=null;let t=this.selectedObject;t&&this.dispatchEvent({type:`contextMenuRequested`,x:e.clientX,y:e.clientY,selectedObject:t})}handleContextMenu(e){e.preventDefault()}getMouseCoordinates(e){let t=this.canvas.getBoundingClientRect();return{x:(e.clientX-t.left)/t.width*2-1,y:-((e.clientY-t.top)/t.height)*2+1}}filterValidIntersects(e){return e.filter(e=>{let t=e.object;return t!==this.focusPointIndicator&&t!==this.floorPlane&&!t.name.includes(`Helper`)&&t.type===`Mesh`})}updateDependencies({scene:e,camera:t,floorPlane:n}){e&&(this.scene=e),t&&(this.camera=t),n&&(this.floorPlane=n)}wireAppEvents(e){this.addEventListener(`objectSelected`,t=>{this.select(t.object),e.refreshFrame(),e.dispatchEvent({type:z.OBJECT_SELECTED,object:t.object,uuid:t.uuid})}),this.addEventListener(`objectDeselected`,t=>{this.select(null),e.refreshFrame(),e.dispatchEvent({type:z.OBJECT_DESELECTED,object:t.object,uuid:t.uuid})}),this.addEventListener(`selectModeChanged`,t=>{e.dispatchEvent({type:z.SELECT_MODE_CHANGED,enabled:t.enabled})}),this.addEventListener(`objectDoubleClicked`,t=>{this.select(t.object),e.refreshFrame(),e.dispatchEvent({type:z.OBJECT_DOUBLE_CLICKED,object:t.object,uuid:t.uuid})}),this.addEventListener(`focusChanged`,t=>{e.settings.set(`focusDistance`,t.worldDistance),e.dispatchEvent({type:`focusChanged`,distance:t.distance})}),this.addEventListener(`afPointPlaced`,t=>{e.dispatchEvent({type:z.AF_POINT_PLACED,point:t.point})})}dispose(){this.canvas.removeEventListener(`click`,this.handleAFPointClick),this.canvas.removeEventListener(`click`,this.handleFocusClick),this.canvas.removeEventListener(`mousedown`,this.handleMouseDown),this.canvas.removeEventListener(`mouseup`,this.handleMouseUp),this.canvas.removeEventListener(`click`,this.handleSelectClick),this.canvas.removeEventListener(`dblclick`,this.handleSelectDoubleClick),this.canvas.removeEventListener(`contextmenu`,this.handleContextMenu),this.canvas.removeEventListener(`pointerdown`,this.handleContextPointerDown),this.canvas.removeEventListener(`pointerup`,this.handleContextPointerUp),this.clickTimeout&&=(clearTimeout(this.clickTimeout),null),this.mouseDownPosition=null,this.contextPointerDownPosition=null,this.focusPointIndicator&&=(this.scene.remove(this.focusPointIndicator),null),this.canvas.style.cursor=`auto`,this.scene=null,this.camera=null,this.canvas=null,this.assetLoader=null,this.pathTracer=null,this.floorPlane=null,this.raycaster=null}},mo={glb:{type:`model`,name:`GLB (GLTF Binary)`},gltf:{type:`model`,name:`GLTF`},fbx:{type:`model`,name:`FBX`},obj:{type:`model`,name:`OBJ`},stl:{type:`model`,name:`STL`},ply:{type:`model`,name:`PLY (Polygon File Format)`},dae:{type:`model`,name:`Collada`},"3mf":{type:`model`,name:`3D Manufacturing Format`},usdz:{type:`model`,name:`Universal Scene Description`},hdr:{type:`environment`,name:`HDR (High Dynamic Range)`},exr:{type:`environment`,name:`EXR (OpenEXR)`},png:{type:`image`,name:`PNG`},jpg:{type:`image`,name:`JPEG`},jpeg:{type:`image`,name:`JPEG`},webp:{type:`image`,name:`WebP`},zip:{type:`archive`,name:`ZIP Archive`}},ho=class extends r.EventDispatcher{constructor(e,t,n){super(),this.scene=e,this.camera=t,this.controls=n,this.targetModel=null,this._externalModel=null,this.floorPlane=null,this.sceneScale=1,this.loaderCache={},this.uploadedFileInfo=null,this.animations=[],this.renderer=null}releaseTargetModel(){this.targetModel&&(this.targetModel===this._externalModel?this.targetModel.parent?.remove(this.targetModel):_e(this.targetModel),this.targetModel=null,this._externalModel=null)}setRenderer(e){this.renderer=e}getFileFormat(e){return mo[e.split(`.`).pop().toLowerCase()]||null}readFileAsArrayBuffer(e){return new Promise((t,n)=>{let r=new FileReader;r.onload=e=>t(e.target.result),r.onerror=e=>n(e),r.readAsArrayBuffer(e)})}readFileAsText(e){return new Promise((t,n)=>{let r=new FileReader;r.onload=e=>t(e.target.result),r.onerror=e=>n(e),r.readAsText(e)})}async loadAssetFromFile(e){let t=e.name,n=this.getFileFormat(t);if(!n)throw Error(`Unsupported file format: ${t}`);B({isLoading:!0,status:`Loading ${n.name}...`,progress:2});try{let r;switch(n.type){case`model`:r=await this.loadModelFromFile(e,t);break;case`environment`:case`image`:r=await this.loadEnvironmentFromFile(e,t);break;case`archive`:r=await this.loadArchiveFromFile(e,t);break;default:throw Error(`Unknown asset type: ${n.type}`)}return r}catch(e){throw this.dispatchEvent({type:`error`,message:e.message,filename:t}),e}}async loadModelFromFile(e,t){let n=t.split(`.`).pop().toLowerCase(),r=await this.readFileAsArrayBuffer(e);switch(n){case`glb`:case`gltf`:return await this.loadGLBFromArrayBuffer(r,t);case`fbx`:return await this.loadFBXFromArrayBuffer(r,t);case`obj`:return await this.loadOBJFromFile(e,t);case`stl`:return await this.loadSTLFromArrayBuffer(r,t);case`ply`:return await this.loadPLYFromArrayBuffer(r,t);case`dae`:return await this.loadColladaFromFile(e,t);case`3mf`:return await this.load3MFFromArrayBuffer(r,t);case`usdz`:return await this.loadUSDZFromArrayBuffer(r,t);default:throw Error(`Support for ${n} files is not yet implemented`)}}async loadEnvironmentFromFile(e,t){let n=URL.createObjectURL(e);this.uploadedFileInfo={name:t,type:e.type,size:e.size};try{let e=await this.loadEnvironment(n);return this.dispatchEvent({type:`load`,texture:e,filename:t}),e}finally{URL.revokeObjectURL(n)}}async loadEnvironment(e){try{this.dispatchEvent({type:`beforeEnvironmentLoad`,url:e});let t;if(e.startsWith(`blob:`))t=await this.loadEnvironmentFromBlob(e);else{let n=e.split(/[?#]/)[0].split(`.`).pop().toLowerCase();t=await this.loadEnvironmentByExtension(e,n)}return t.generateMipmaps=!0,this.applyEnvironmentToScene(t),this.dispatchEvent({type:`load`,texture:t}),t}catch(t){throw console.error(`Error loading environment:`,t),this.dispatchEvent({type:`error`,message:t.message,filename:e}),t}}async loadEnvironmentFromBlob(e){let t=await(await fetch(e)).blob(),n=this.determineEnvironmentExtension(t,e),r=URL.createObjectURL(t);try{return await this.loadEnvironmentByExtension(r,n)}finally{URL.revokeObjectURL(r)}}determineEnvironmentExtension(e,t){let n;if(e.type===`image/x-exr`||e.type.includes(`exr`))n=`exr`;else if(e.type===`image/vnd.radiance`||e.type.includes(`hdr`))n=`hdr`;else{let e=t.split(`/`).pop();if(e){let t=e.match(/\.([^.]+)$/);t&&(n=t[1].toLowerCase())}}return!n&&this.uploadedFileInfo&&(n=this.uploadedFileInfo.name.split(`.`).pop().toLowerCase()),n}async loadEnvironmentByExtension(e,t){let n;return t===`hdr`||t===`exr`?n=await(t===`hdr`?this.loaderCache.hdr||(this.loaderCache.hdr=new s.HDRLoader().setDataType(r.FloatType)):this.loaderCache.exr||(this.loaderCache.exr=new u.EXRLoader().setDataType(r.FloatType))).loadAsync(e):(this.loaderCache.texture||(this.loaderCache.texture=new r.TextureLoader),n=await this.loaderCache.texture.loadAsync(e)),n.mapping=r.EquirectangularReflectionMapping,n.minFilter=r.LinearFilter,n.magFilter=r.LinearFilter,n}applyEnvironmentToScene(e){this.scene.background=e,this.scene.environment=e}async loadArchiveFromFile(e,t){try{let n=await this.readFileAsArrayBuffer(e),r=(0,p.unzipSync)(new Uint8Array(n));return await this.processObjMtlPairsInZip(r,t)||await this.findAndLoadModelFromZip(r,t)}catch(e){throw console.error(`Error loading ZIP archive:`,e),e}}async processObjMtlPairsInZip(e,t){let n=[],r=[];for(let t in e){let i=t.toLowerCase();i.endsWith(`.obj`)?n.push({path:t,content:e[t]}):i.endsWith(`.mtl`)&&r.push({path:t,content:e[t]})}if(n.length>0&&r.length>0){console.log(`Found ${n.length} OBJ files and ${r.length} MTL files in ZIP`);let i=this.findMatchingObjMtlPairs(n,r);if(i.length>0)return console.log(`Found ${i.length} matching OBJ+MTL pairs`),await this.loadOBJMTLPairFromZip(i[0].obj,i[0].mtl,e,t);if(i.length===0)return console.log(`No matching pairs by name, using first OBJ and MTL files`),await this.loadOBJMTLPairFromZip(n[0],r[0],e,t)}return null}findMatchingObjMtlPairs(e,t){let n=[];for(let r of e){let e=r.path.split(`/`).pop().replace(/\.obj$/i,``).toLowerCase();for(let i of t){let t=i.path.split(`/`).pop().replace(/\.mtl$/i,``).toLowerCase();if(e===t||e.includes(t)||t.includes(e)){n.push({obj:r,mtl:i});break}}}return n}async findAndLoadModelFromZip(e){for(let t of[`scene.gltf`,`scene.glb`,`model.gltf`,`model.glb`,`main.gltf`,`main.glb`,`asset.gltf`,`asset.glb`])if(e[t]){console.log(`Found main model file: ${t}`);let n=t.split(`.`).pop().toLowerCase();return await this.loadModelFromZipEntry(e[t],t,n,e)}for(let t in e){let n=t.split(`.`).pop().toLowerCase();if(mo[n]&&mo[n].type===`model`)return console.log(`Loading model file from ZIP: ${t}`),await this.loadModelFromZipEntry(e[t],t,n,e)}throw Error(`No supported model files found in the ZIP archive`)}async loadModelFromZipEntry(e,t,n,r){try{B({isLoading:!0,status:`Processing ${n.toUpperCase()} from ZIP...`,progress:5});let i=new Blob([e.buffer],{type:`application/octet-stream`}),a=URL.createObjectURL(i),o;switch(n){case`glb`:case`gltf`:o=await this.handleGltfFromZip(n,e,t,r);break;case`fbx`:o=await this.loadFBXFromArrayBuffer(e.buffer,t);break;case`obj`:o=await this.handleObjFromZip(e,t,r);break;case`stl`:o=await this.loadSTLFromArrayBuffer(e.buffer,t);break;case`ply`:o=await this.loadPLYFromArrayBuffer(e.buffer,t);break;case`dae`:{let n=(0,p.strFromU8)(e),r=new File([new Blob([n])],t);o=await this.loadColladaFromFile(r,t)}break;case`3mf`:o=await this.load3MFFromArrayBuffer(e.buffer,t);break;case`usdz`:o=await this.loadUSDZFromArrayBuffer(e.buffer,t);break;default:throw Error(`Support for ${n} files is not yet implemented`)}return URL.revokeObjectURL(a),this.dispatchEvent({type:`load`,model:this.targetModel,filename:`${t} (from ZIP)`}),o}catch(e){throw console.error(`Error loading ${n} from ZIP:`,e),this.dispatchEvent({type:`error`,message:e.message,filename:t}),e}}async handleGltfFromZip(e,t,n,i){if(e===`gltf`){let e=(0,p.strFromU8)(t),a=new r.LoadingManager,o=n.split(`/`).slice(0,-1).join(`/`);a.setURLModifier(e=>this.resolveZipResource(e,o,i));let s=await this.createGLTFLoader();s.manager=a;try{return await new Promise((t,n)=>{s.parse(e,``,e=>{this.releaseTargetModel(),this.targetModel=e.scene,this.onModelLoad(this.targetModel).then(()=>t(e))},e=>n(e))})}finally{this._disposeGLTFLoader(s)}}else return await this.loadGLBFromArrayBuffer(t.buffer,n)}async handleObjFromZip(e,t,n){let r=(0,p.strFromU8)(e),i=r.match(/mtllib\s+([^\s]+)/),a=null;i&&i[1]&&(a=await this.loadMtlFromZip(i[1],t,n));let{OBJLoader:o}=await import(`three/examples/jsm/loaders/OBJLoader.js`),s=new o;a&&s.setMaterials(a);let c=s.parse(r);return c.name=t,this.releaseTargetModel(),this.targetModel=c,await this.onModelLoad(this.targetModel),c}async loadMtlFromZip(e,t,n){let i=t.split(`/`).slice(0,-1).join(`/`),a=[e,`${i}/${e}`,e.split(`/`).pop()];for(let e of a)if(n[e]){let{MTLLoader:t}=await import(`three/examples/jsm/loaders/MTLLoader.js`),a=(0,p.strFromU8)(n[e]),o=new r.LoadingManager;o.setURLModifier(e=>this.resolveZipResource(e,i,n));let s=new t(o).parse(a,i);return s.preload(),s}return null}resolveZipResource(e,t,n){let r=e.replace(/^\.\/|^\//,``),i=[r,`${t}/${r}`,r.split(`/`).pop()];for(let e of i)if(n[e]){let t=new Blob([n[e].buffer],{type:`application/octet-stream`});return URL.createObjectURL(t)}return console.warn(`Resource not found in ZIP: ${e}`),e}async loadOBJMTLPairFromZip(e,t,n,i){let{MTLLoader:a}=await import(`three/examples/jsm/loaders/MTLLoader.js`),{OBJLoader:o}=await import(`three/examples/jsm/loaders/OBJLoader.js`),s=[],c=new r.LoadingManager,l=e.path.split(`/`).slice(0,-1).join(`/`),u=t.path.split(`/`).slice(0,-1).join(`/`);c.setURLModifier(e=>this.resolveTextureInZip(e,l,u,t,n,s));let d=this.prepareFixedMtlContent(t),f=new a(c).parse(d,u);f.preload();let m=new o(c);m.setMaterials(f);let h=(0,p.strFromU8)(e.content),g=m.parse(h);return this.releaseTargetModel(),this.targetModel=g,await this.onModelLoad(this.targetModel),s.forEach(e=>URL.revokeObjectURL(e)),this.dispatchEvent({type:`load`,model:g,filename:`${e.path} (from ${i})`}),g}prepareFixedMtlContent(e){return(0,p.strFromU8)(e.content).replace(RegExp(`${e.path.split(`/`).pop()}\\s+`,`g`),` `).replace(/([a-zA-Z_]+)([\\/])/g,`$1 $2`)}resolveTextureInZip(e,t,n,r,i,a){let o=e.split(`?`)[0].split(`#`)[0].replace(/^\.\/|^\//,``),s=r.path.split(`/`).pop();o.startsWith(s)&&(o=o.substring(s.length).replace(/^\.\/|^\/|^\./,``));let c=[o,`${t}/${o}`,`${n}/${o}`,`textures/${o}`,`texture/${o}`,`materials/${o}`,o.split(`/`).pop()];for(let e of c)if(i[e]){let t=new Blob([i[e].buffer],{type:`application/octet-stream`}),n=URL.createObjectURL(t);return a.push(n),n}return this.findTextureWithFuzzyMatch(o,i,a)||e}findTextureWithFuzzyMatch(e,t,n){let r=e.split(`/`).pop();for(let e in t)if(e.endsWith(r)){let r=new Blob([t[e].buffer],{type:`application/octet-stream`}),i=URL.createObjectURL(r);return n.push(i),i}if(r&&r.length>5)for(let e in t){let i=e.split(`/`).pop();if(i.includes(r)||r.includes(i)){let r=new Blob([t[e].buffer],{type:`application/octet-stream`}),i=URL.createObjectURL(r);return n.push(i),i}}return null}async createGLTFLoader(){let{dracoDecoderPath:e,ktx2TranscoderPath:t}=La(),n=new c.DRACOLoader;n.setDecoderConfig({type:`js`}),n.setDecoderPath(e);let r=new l.KTX2Loader;r.setTranscoderPath(t),this.renderer&&(r.detectSupport(this.renderer),r.workerConfig={astcSupported:!1,etc1Supported:!1,etc2Supported:!1,dxtSupported:!1,bptcSupported:!1,pvrtcSupported:!1});let i=new o.GLTFLoader;return i.setDRACOLoader(n),i.setKTX2Loader(r),i.setMeshoptDecoder(f.MeshoptDecoder),i}_disposeGLTFLoader(e){e&&(e.dracoLoader?.dispose(),e.ktx2Loader?.dispose())}async loadExampleModels(e,t){if(!t||!t[e])throw Error(`No model file at index ${e}`);let n=`${t[e].url}`;return await this.loadModel(n)}async loadModel(e){let t=await this.createGLTFLoader();try{B({status:`Loading Model...`,progress:2});let n=await t.loadAsync(e);return B({status:`Processing Data...`,progress:10}),this.releaseTargetModel(),this.targetModel=n.scene,this.animations=n.animations||[],await this.onModelLoad(this.targetModel),this.dispatchEvent({type:`load`,model:n.scene,filename:e.split(`/`).pop()}),n}catch(t){throw console.error(`Error loading model:`,t),this.dispatchEvent({type:`error`,message:t.message,filename:e}),t}finally{this._disposeGLTFLoader(t)}}async loadGLBFromArrayBuffer(e,t=`model.glb`){let n=await this.createGLTFLoader();try{B({isLoading:!0,status:`Processing GLB Data...`,progress:5}),await new Promise(e=>setTimeout(e,0));let r=await n.parseAsync(e,``);return this.releaseTargetModel(),this.targetModel=r.scene,this.animations=r.animations||[],B({isLoading:!0,status:`Processing Data...`,progress:10}),await this.onModelLoad(this.targetModel),this.dispatchEvent({type:`load`,model:r.scene,filename:t}),r}catch(e){throw console.error(`Error loading GLB:`,e),this.dispatchEvent({type:`error`,message:e.message,filename:t}),e}finally{this._disposeGLTFLoader(n)}}async loadFBXFromArrayBuffer(e,t=`model.fbx`){try{if(B({isLoading:!0,status:`Processing FBX Data...`,progress:5}),await new Promise(e=>setTimeout(e,0)),!this.loaderCache.fbx){let{FBXLoader:e}=await import(`three/examples/jsm/loaders/FBXLoader.js`);this.loaderCache.fbx=new e}let n=this.loaderCache.fbx.parse(e);return this.releaseTargetModel(),this.targetModel=n,B({isLoading:!0,status:`Processing Data...`,progress:10}),await this.onModelLoad(this.targetModel),this.dispatchEvent({type:`load`,model:n,filename:t}),n}catch(e){throw console.error(`Error loading FBX:`,e),this.dispatchEvent({type:`error`,message:e.message,filename:t}),e}}async loadOBJFromFile(e,t=`model.obj`){try{if(B({isLoading:!0,status:`Processing OBJ Data...`,progress:5}),await new Promise(e=>setTimeout(e,0)),!this.loaderCache.obj){let{OBJLoader:e}=await import(`three/examples/jsm/loaders/OBJLoader.js`);this.loaderCache.obj=new e}let n=await this.readFileAsText(e),r=this.loaderCache.obj.parse(n);return r.name=t,this.releaseTargetModel(),this.targetModel=r,B({isLoading:!0,status:`Processing Data...`,progress:10}),await this.onModelLoad(this.targetModel),this.dispatchEvent({type:`load`,model:r,filename:t}),r}catch(e){throw console.error(`Error loading OBJ:`,e),this.dispatchEvent({type:`error`,message:e.message,filename:t}),e}}async loadSTLFromArrayBuffer(e,t=`model.stl`){try{if(B({isLoading:!0,status:`Processing STL Data...`,progress:5}),await new Promise(e=>setTimeout(e,0)),!this.loaderCache.stl){let{STLLoader:e}=await import(`three/examples/jsm/loaders/STLLoader.js`);this.loaderCache.stl=new e}let n=new r.Mesh(this.loaderCache.stl.parse(e),new r.MeshStandardMaterial);return n.name=t,this.releaseTargetModel(),this.targetModel=n,B({isLoading:!0,status:`Processing Data...`,progress:10}),await this.onModelLoad(this.targetModel),this.dispatchEvent({type:`load`,model:n,filename:t}),n}catch(e){throw console.error(`Error loading STL:`,e),this.dispatchEvent({type:`error`,message:e.message,filename:t}),e}}async loadPLYFromArrayBuffer(e,t=`model.ply`){try{if(B({isLoading:!0,status:`Processing PLY Data...`,progress:5}),await new Promise(e=>setTimeout(e,0)),!this.loaderCache.ply){let{PLYLoader:e}=await import(`three/examples/jsm/loaders/PLYLoader.js`);this.loaderCache.ply=new e}let n=this.loaderCache.ply.parse(e),i;if(n.index!==null)i=new r.Mesh(n,new r.MeshStandardMaterial);else{let e=new r.PointsMaterial({size:.01});e.vertexColors=n.hasAttribute(`color`),i=new r.Points(n,e)}return i.name=t,this.releaseTargetModel(),this.targetModel=i,B({isLoading:!0,status:`Processing Data...`,progress:10}),await this.onModelLoad(this.targetModel),this.dispatchEvent({type:`load`,model:i,filename:t}),i}catch(e){throw console.error(`Error loading PLY:`,e),this.dispatchEvent({type:`error`,message:e.message,filename:t}),e}}async loadColladaFromFile(e,t=`model.dae`){try{if(B({isLoading:!0,status:`Processing Collada Data...`,progress:5}),await new Promise(e=>setTimeout(e,0)),!this.loaderCache.collada){let{ColladaLoader:e}=await import(`three/examples/jsm/loaders/ColladaLoader.js`);this.loaderCache.collada=new e}let n=await this.readFileAsText(e),r=this.loaderCache.collada.parse(n);return r.scene.name=t,this.releaseTargetModel(),this.targetModel=r.scene,B({isLoading:!0,status:`Processing Data...`,progress:10}),await this.onModelLoad(this.targetModel),this.dispatchEvent({type:`load`,model:r.scene,filename:t}),r}catch(e){throw console.error(`Error loading Collada:`,e),this.dispatchEvent({type:`error`,message:e.message,filename:t}),e}}async load3MFFromArrayBuffer(e,t=`model.3mf`){try{if(B({isLoading:!0,status:`Processing 3MF Data...`,progress:5}),await new Promise(e=>setTimeout(e,0)),!this.loaderCache.threemf){let{ThreeMFLoader:e}=await import(`three/examples/jsm/loaders/3MFLoader.js`);this.loaderCache.threemf=new e}let n=this.loaderCache.threemf.parse(e);return this.releaseTargetModel(),this.targetModel=n,B({isLoading:!0,status:`Processing Data...`,progress:10}),await this.onModelLoad(this.targetModel),this.dispatchEvent({type:`load`,model:n,filename:t}),n}catch(e){throw console.error(`Error loading 3MF:`,e),this.dispatchEvent({type:`error`,message:e.message,filename:t}),e}}async loadUSDZFromArrayBuffer(e,t=`model.usdz`){try{if(B({isLoading:!0,status:`Processing USDZ Data...`,progress:5}),await new Promise(e=>setTimeout(e,0)),!this.loaderCache.usdz){let{USDZLoader:e}=await import(`three/examples/jsm/loaders/USDZLoader.js`);this.loaderCache.usdz=new e}let n=this.loaderCache.usdz.parse(e);return n.name=t,this.releaseTargetModel(),this.targetModel=n,B({isLoading:!0,status:`Processing Data...`,progress:10}),await this.onModelLoad(this.targetModel),this.dispatchEvent({type:`load`,model:n,filename:t}),n}catch(e){throw console.error(`Error loading USDZ:`,e),this.dispatchEvent({type:`error`,message:e.message,filename:t}),e}}async loadObject3D(e,t=`object3d`){return e.name=e.name||t,this.releaseTargetModel(),this.targetModel=e,this._externalModel=e,B({isLoading:!0,status:`Processing Data...`,progress:10}),await this.onModelLoad(this.targetModel),this.dispatchEvent({type:`load`,model:e,filename:t}),e}async onModelLoad(e){let t=new Ji(`onModelLoad`);t.start(`Camera extraction`);let n=this.extractCamerasFromModel(e);t.end(`Camera extraction`),t.start(`Camera setup`);let i=new r.Box3().setFromObject(e),a=i.getCenter(new r.Vector3),o=i.getSize(new r.Vector3);this.controls.target.copy(a);let s=Math.max(o.x,o.y,o.z),c=this.camera.fov*(Math.PI/180),l=Math.abs(s/Math.sin(c/2)/2),u=Math.PI/6,d=new r.Vector3(Math.cos(u)*l,l/Math.sqrt(2),Math.sin(u)*l);if(this.camera.position.copy(d.add(a)),this.camera.lookAt(a),this.camera.near=s/100,this.camera.far=s*100,this.camera.updateProjectionMatrix(),this.controls.maxDistance=l*10,this.controls.saveState(),this.controls.update(),t.end(`Camera setup`),this.floorPlane){let e=i.min.y;this.floorPlane.position.y=e,this.floorPlane.rotation.x=-Math.PI/2,this.floorPlane.scale.setScalar(s*5)}t.start(`Process model objects`),this.processModelObjects(e),t.end(`Process model objects`),t.start(`Scene add`),this.scene.add(e),t.end(`Scene add`);let f=s;return t.start(`setupPathTracing`),await this.setupPathTracing(e,f),t.end(`setupPathTracing`),t.print(),this.dispatchEvent({type:`modelProcessed`,model:e,cameras:n,sceneData:{center:a,size:o,maxDim:s,sceneScale:f}}),this.dispatchEvent({type:`SceneRebuild`}),{center:a,size:o,maxDim:s,sceneScale:f}}extractCamerasFromModel(e){let t=[];return e.updateWorldMatrix(!0,!0),e.traverse(e=>{if(e.isCamera){let n=e.clone();e.getWorldPosition(n.position),e.getWorldQuaternion(n.quaternion),(!n.name||n.name===``)&&(n.name=`Model Camera ${t.length+1}`),n.isPerspectiveCamera&&(n.aspect=this.camera.aspect,n.updateProjectionMatrix()),t.push(n)}}),t}processModelObjects(e){let t=[];e.traverse(e=>{let n=e.userData;if(e.isRectAreaLight&&!t.includes(e.uuid)&&t.push(e.uuid),e.name.startsWith(`RectAreaLightPlaceholder`)&&n.name&&n.type===`RectAreaLight`){let i=new r.RectAreaLight(new r.Color(...n.color),n.intensity*.1/Math.PI,n.width,n.height);i.position.z=-2,i.name=n.name,e.add(i),t.push(i.uuid)}if(e.isMesh&&Array.isArray(e.material)){console.log(`Found multi-material mesh:`,e.name);let t=(0,d.createMeshesFromMultiMaterialMesh)(e);e.parent&&(e.parent.add(t),e.parent.remove(e))}})}async setupPathTracing(e,t){this.sceneScale=t}createFloorPlane(){this.floorPlane=new r.Mesh(new r.CircleGeometry,new r.MeshPhysicalMaterial({transparent:!1,color:3158064,roughness:1,metalness:0,opacity:0,transmission:0})),this.floorPlane.name=`Ground`,this.floorPlane.visible=!1,this.scene.add(this.floorPlane)}setFloorPlane(e){this.floorPlane=e}getSceneScale(){return this.sceneScale}getTargetModel(){return this.targetModel}getSupportedFormats(e=null){if(e){let t={};for(let[n,r]of Object.entries(mo))r.type===e&&(t[n]=r);return t}return mo}dispose(){for(let e in this.loaderCache){let t=this.loaderCache[e];t&&typeof t.dispose==`function`&&t.dispose()}this.loaderCache={},this._listeners=void 0,this.releaseTargetModel()}removeAllEventListeners(){this._listeners=void 0}},go={maxBounces:{uniform:`maxBounces`,reset:!0},samplesPerPixel:{uniform:`samplesPerPixel`,reset:!0},transmissiveBounces:{uniform:`transmissiveBounces`,reset:!0},environmentIntensity:{uniform:`environmentIntensity`,reset:!0},backgroundIntensity:{uniform:`backgroundIntensity`,reset:!0},showBackground:{uniform:`showBackground`,reset:!0},enableEnvironment:{uniform:`enableEnvironment`,reset:!0},globalIlluminationIntensity:{uniform:`globalIlluminationIntensity`,reset:!0},enableDOF:{uniform:`enableDOF`,reset:!0},focusDistance:{uniform:`focusDistance`,reset:!1},focalLength:{uniform:`focalLength`,reset:!0},aperture:{uniform:`aperture`,reset:!0},apertureScale:{uniform:`apertureScale`,reset:!0},anamorphicRatio:{uniform:`anamorphicRatio`,reset:!0},samplingTechnique:{uniform:`samplingTechnique`,reset:!0},fireflyThreshold:{uniform:`fireflyThreshold`,reset:!0},enableAlphaShadows:{uniform:`enableAlphaShadows`,reset:!0},enableEmissiveTriangleSampling:{uniform:`enableEmissiveTriangleSampling`,reset:!0},emissiveBoost:{uniform:`emissiveBoost`,reset:!0},visMode:{uniform:`visMode`,reset:!0},debugVisScale:{uniform:`debugVisScale`,reset:!0},useAdaptiveSampling:{uniform:`useAdaptiveSampling`,reset:!0},adaptiveSamplingMax:{uniform:`adaptiveSamplingMax`,reset:!0},interactionModeEnabled:{handler:`handleInteractionModeEnabled`,reset:!1},maxSamples:{handler:`handleMaxSamples`,reset:!1},transparentBackground:{handler:`handleTransparentBackground`},exposure:{handler:`handleExposure`},saturation:{handler:`handleSaturation`},renderLimitMode:{handler:`handleRenderLimitMode`},renderTimeLimit:{handler:`handleRenderTimeLimit`,reset:!1},renderMode:{handler:`handleRenderMode`},environmentRotation:{handler:`handleEnvironmentRotation`}},_o={bounces:`maxBounces`,adaptiveSampling:`useAdaptiveSampling`,debugMode:`visMode`},vo=class extends r.EventDispatcher{constructor(e=V){super(),this._values=new Map,this._pathTracer=null,this._resetCallback=null,this._handlers={},this._delegates={},this._initDefaults(e)}bind({stages:e,renderer:t,resetCallback:n,reconcileCompletion:r}){this._pathTracer=e.pathTracer,this._resetCallback=n,this._delegates={},this._handlers=this._buildHandlers(e,t,r)}_buildHandlers(e,t,n){return{handleTransparentBackground:t=>{e.pathTracer?.setUniform(`transparentBackground`,t),e.compositor?.setTransparentBackground(t)},handleExposure:n=>{!e.autoExposure?.enabled&&t&&(t.toneMappingExposure=n)},handleSaturation:t=>{e.compositor?.setSaturation(t)},handleRenderLimitMode:t=>{e.pathTracer?.setRenderLimitMode?.(t)},handleMaxSamples:t=>{e.pathTracer?.setUniform(`maxSamples`,t),e.pathTracer?.updateCompletionThreshold(),n?.()},handleRenderTimeLimit:()=>{n?.()},handleRenderMode:t=>{e.pathTracer?.setUniform(`renderMode`,parseInt(t))},handleEnvironmentRotation:t=>{e.pathTracer?.environment.setEnvironmentRotation(t)},handleInteractionModeEnabled:t=>{e.pathTracer?.setInteractionModeEnabled(t)}}}set(e,t,{reset:n,silent:r}={}){let i=this._values.get(e);if(i===t)return;this._values.set(e,t);let a=go[e];a&&(this._applyRoute(a,t,i),(n===void 0?a.reset??!0:n)&&this._resetCallback?.(),r||this.dispatchEvent({type:z.SETTING_CHANGED,key:e,value:t,prev:i}))}setMany(e,{silent:t}={}){let n=!1;for(let[r,i]of Object.entries(e)){let e=this._values.get(r);if(e===i)continue;this._values.set(r,i);let a=go[r];a&&(this._applyRoute(a,i,e),(a.reset??!0)&&(n=!0),t||this.dispatchEvent({type:z.SETTING_CHANGED,key:r,value:i,prev:e}))}n&&this._resetCallback?.()}get(e){return this._values.get(e)}getAll(){return Object.fromEntries(this._values)}applyAll(){for(let[e,t]of this._values){let n=go[e];n&&this._applyRoute(n,t,void 0)}}_applyRoute(e,t,n){e.uniform?(this._pathTracer?.setUniform(e.uniform,t),e.after&&this._pathTracer?.[e.after]?.()):e.handler?this._handlers[e.handler]?.(t,n):e.delegate&&this._delegates[e.delegate]?.updateParam?.(e.param,t)}_initDefaults(e){for(let t of Object.keys(go))t in e&&this._values.set(t,e[t]);for(let[t,n]of Object.entries(_o))t in e&&this._values.set(n,e[t])}},yo=class extends r.EventDispatcher{constructor(e){super();let t=e.clientWidth,n=e.clientHeight;this.camera=new r.PerspectiveCamera(60,t/n||1,.01,1e3),this.camera.position.set(0,0,5),this.controls=new m.OrbitControls(this.camera,e),this.controls.screenSpacePanning=!0,this.controls.zoomToCursor=!0,this.controls.saveState(),this.interactionManager=null,this.cameras=[this.camera],this.currentCameraIndex=0,this.autoFocusMode=Oe.SMOOTHING_FACTOR?`auto`:`manual`,this.afScreenPoint={x:.5,y:.5},this.afSmoothingFactor=Oe.SMOOTHING_FACTOR,this._lastValidFocusDistance=null,this._smoothedFocusDistance=null,this._afPointDirty=!1,this._defaultCameraState=null,this._onResize=null,this._onReset=null,this._getSettings=null}setCameras(e){this.cameras=e}getCameraNames(){return!this.cameras||this.cameras.length===0?[`Default Camera`]:this.cameras.map((e,t)=>t===0?`Default Camera`:e.name||`Camera ${t}`)}initCallbacks({onResize:e,onReset:t,getSettings:n}){this._onResize=e,this._onReset=t,this._getSettings=n}switchCamera(e,t,n,i){if(t??=this._getSettings?.(`focusDistance`),n??=this._onResize,i??=this._onReset,!(!this.cameras||this.cameras.length===0)){if((e<0||e>=this.cameras.length)&&(console.warn(`CameraManager: Invalid camera index ${e}. Using default camera.`),e=0),this.currentCameraIndex===0&&e!==0&&(this._defaultCameraState={position:this.camera.position.clone(),quaternion:this.camera.quaternion.clone(),fov:this.camera.fov,near:this.camera.near,far:this.camera.far,target:this.controls?this.controls.target.clone():null}),this.currentCameraIndex=e,e===0&&this._defaultCameraState){let e=this._defaultCameraState;this.camera.position.copy(e.position),this.camera.quaternion.copy(e.quaternion),this.camera.fov=e.fov,this.camera.near=e.near,this.camera.far=e.far,this.camera.updateProjectionMatrix(),this.camera.updateMatrixWorld(!0),this.controls&&e.target&&(this.controls.target.copy(e.target),this.controls.update())}else{let n=this.cameras[e];if(this.camera.position.copy(n.position),this.camera.quaternion.copy(n.quaternion),this.camera.fov=n.fov,this.camera.near=n.near,this.camera.far=n.far,this.camera.updateProjectionMatrix(),this.camera.updateMatrixWorld(!0),this.controls){let e=new r.Vector3(0,0,-1).applyQuaternion(n.quaternion),i=t||5;this.controls.target.copy(this.camera.position).addScaledVector(e,i),this.controls.update()}}n?.(),i?.(),this.dispatchEvent({type:`CameraSwitched`,cameraIndex:e})}}focusOn(e){!e||!this.controls||(this.controls.target.copy(e),this.controls.update(),this._onReset?.())}get active(){return this.camera}getNames(){return this.getCameraNames()}setAutoFocusMode(e){this.autoFocusMode=e,e!==`manual`&&(this._smoothedFocusDistance=null,this._afPointDirty=!0)}setAFScreenPoint(e,t){this.afScreenPoint={x:e,y:t},this._afPointDirty=!0}enterAFPointPlacementMode(){this.interactionManager&&(this.interactionManager.enterAFPointPlacementMode(),this.controls&&(this.controls.enabled=!1))}exitAFPointPlacementMode(){this.interactionManager&&(this.interactionManager.exitAFPointPlacementMode(),this.controls&&(this.controls.enabled=!0))}updateAutoFocus(e){let{meshScene:t,assetLoader:n,floorPlane:r,currentFocusDistance:i,pathTracer:a,setFocusDistance:o,softReset:s,hardReset:c}=e||this._afContext||{};if(!t||this.autoFocusMode===`manual`)return;let l=a;if(l?.isReady&&l.renderMode?.value===1&&l.frameCount>0&&!l.isComplete)return;let u=this.afScreenPoint.x*2-1,d=-(this.afScreenPoint.y*2-1),f=this.interactionManager?.raycaster;if(!f)return;f.setFromCamera({x:u,y:d},this.camera);let p=f.intersectObjects(t.children,!0).find(e=>e.object!==this.interactionManager?.focusPointIndicator&&e.object!==r&&!e.object.name.includes(`Helper`)&&e.object.type===`Mesh`),m;if(p)m=p.distance,this._lastValidFocusDistance=m;else if(this._lastValidFocusDistance!==null)m=this._lastValidFocusDistance;else{let e=n?.getSceneScale()||1;m=Oe.FALLBACK_DISTANCE*e,this._lastValidFocusDistance=m}let h=this._afPointDirty;this._afPointDirty=!1,h||this._smoothedFocusDistance===null||this._smoothedFocusDistance===0||Math.abs(m-this._smoothedFocusDistance)/this._smoothedFocusDistance>Oe.SNAP_THRESHOLD?this._smoothedFocusDistance=m:this._smoothedFocusDistance+=this.afSmoothingFactor*(m-this._smoothedFocusDistance);let g=i,_=this._smoothedFocusDistance;if(h||g===0||Math.abs(_-g)/Math.max(g,.001)>.001){o(_);let e=n?.getSceneScale()||1;this.dispatchEvent({type:z.AUTO_FOCUS_UPDATED,distance:_/e});let t=Math.abs(_-g)/Math.max(g,.001);h?c?.():t>Oe.RESET_THRESHOLD&&s?.()}}setInteractionManager(e){this.interactionManager=e}initAutoFocus({meshScene:e,assetLoader:t,floorPlane:n,pathTracer:r,settings:i,softReset:a,hardReset:o}){this._afContext={meshScene:e,assetLoader:t,floorPlane:n,pathTracer:r,setFocusDistance:e=>i.set(`focusDistance`,e,{silent:!0}),softReset:a,hardReset:o},Object.defineProperty(this._afContext,`currentFocusDistance`,{get:()=>i.get(`focusDistance`)})}dispose(){this.controls?.dispose()}},bo=class extends r.EventDispatcher{constructor(e,t,n,r={}){super(),this.scene=e,this.sceneHelpers=t,this.pathTracer=n,this._onReset=r.onReset||null}addLight(e){let t={DirectionalLight:{position:[1,1,1],intensity:1,color:`#ffffff`},PointLight:{position:[0,2,0],intensity:100,color:`#ffffff`},SpotLight:{position:[0,1,0],intensity:300,color:`#ffffff`,angle:15},RectAreaLight:{position:[0,2,0],intensity:500,color:`#ffffff`,width:2,height:2}}[e];if(!t)return null;let n;if(e===`DirectionalLight`)n=new r.DirectionalLight(t.color,t.intensity),n.position.fromArray(t.position);else if(e===`PointLight`)n=new r.PointLight(t.color,t.intensity),n.position.fromArray(t.position);else if(e===`SpotLight`){n=new r.SpotLight(t.color,t.intensity),n.position.fromArray(t.position),n.angle=r.MathUtils.degToRad(t.angle);let e=new r.Object3D;this.scene.add(e),n.target=e}else e===`RectAreaLight`&&(n=new r.RectAreaLight(t.color,t.intensity,t.width,t.height),n.position.fromArray(t.position),n.lookAt(0,0,0));let i=this.scene.getObjectsByProperty(`isLight`,!0).length;return n.name=`${e.replace(`Light`,``)} ${i+1}`,this.scene.add(n),this.updateLights(),this._syncHelpers(),this._onReset?.(),this._buildDescriptor(n)}removeLight(e){let t=this.scene.getObjectByProperty(`uuid`,e);return!t||!t.isLight?!1:(this.sceneHelpers.remove(t),t.target&&t.target.removeFromParent(),t.removeFromParent(),this.updateLights(),this._onReset?.(),!0)}clearLights(){this.sceneHelpers.clear(),this._removeAllLights(),this.updateLights(),this._onReset?.()}getLights(){return this.scene.getObjectsByProperty(`isLight`,!0).map(e=>this._buildDescriptor(e))}updateLights(){this.pathTracer?.updateLights()}transferSceneLights(e){this._removeAllLights();let t=e.getObjectsByProperty(`isLight`,!0);if(!t||t.length===0){this.updateLights();return}for(let e of t){let t=e.clone();if(e.updateWorldMatrix(!0,!1),e.getWorldPosition(t.position),e.getWorldQuaternion(t.quaternion),e.getWorldScale(t.scale),t.isRectAreaLight&&(t.width*=t.scale.x,t.height*=t.scale.y,t.scale.set(1,1,1)),(e.isSpotLight||e.isDirectionalLight)&&e.target){let n=new r.Object3D;e.target.updateWorldMatrix(!0,!1),e.target.getWorldPosition(n.position),this.scene.add(n),t.target=n}this.scene.add(t)}this.updateLights(),this._syncHelpers()}setShowLightHelper(e){this.sceneHelpers.visible=e,e?this._syncHelpers():this.sceneHelpers.clear()}add(e){return this.addLight(e)}remove(e){return this.removeLight(e)}clear(){this.clearLights()}getAll(){return this.getLights()}sync(){this.updateLights()}showHelpers(e){this.setShowLightHelper(e)}dispose(){this._disposed||(this._disposed=!0,this.sceneHelpers?.clear(),this._removeAllLights(),this._onReset=null,this.pathTracer=null,this.sceneHelpers=null,this.scene=null)}_removeAllLights(){this.scene.getObjectsByProperty(`isLight`,!0).forEach(e=>{e.target&&this.scene.remove(e.target),this.scene.remove(e)})}_syncHelpers(){if(!this.sceneHelpers.visible)return;let e=this.scene.getObjectsByProperty(`isLight`,!0);this.sceneHelpers.sync(e)}_buildDescriptor(e){let t=0;e.type===`SpotLight`&&e.angle!==void 0&&(t=r.MathUtils.radToDeg(e.angle));let n={uuid:e.uuid,name:e.name,type:e.type,intensity:e.intensity,color:`#${e.color.getHexString()}`,position:[e.position.x,e.position.y,e.position.z],angle:t};if(e.type===`RectAreaLight`){n.width=e.width,n.height=e.height;let t=e.getWorldDirection(e.position.clone());n.target=[e.position.x+t.x,e.position.y+t.y,e.position.z+t.z]}else e.type===`SpotLight`&&e.target&&(n.target=[e.target.position.x,e.target.position.y,e.target.position.z]);return n}},Q=e=>Math.min(Math.max(e,0),1);function xo(e,t,n,r,i){i[0]=Q(e),i[1]=Q(t),i[2]=Q(n)}function So(e,t,n,r,i){i[0]=Q(e*r),i[1]=Q(t*r),i[2]=Q(n*r)}function Co(e,t,n,r,i){e*=r,t*=r,n*=r,i[0]=Q(e/(e+1)),i[1]=Q(t/(t+1)),i[2]=Q(n/(n+1))}function wo(e,t,n,r,i){e=Math.max(e*r-.004,0),t=Math.max(t*r-.004,0),n=Math.max(n*r-.004,0);let a=e=>(e*(6.2*e+.5)/(e*(6.2*e+1.7)+.06))**2.2;i[0]=a(e),i[1]=a(t),i[2]=a(n)}function To(e,t,n,r,i){e=e*r/.6,t=t*r/.6,n=n*r/.6;let a=.59719*e+.35458*t+.04823*n,o=.076*e+.90834*t+.01566*n,s=.0284*e+.13383*t+.83777*n,c=e=>(e*(e+.0245786)-90537e-9)/(e*(.983729*e+.432951)+.238081);a=c(a),o=c(o),s=c(s),i[0]=Q(1.60475*a-.53108*o-.07367*s),i[1]=Q(-.10208*a+1.10813*o-.00605*s),i[2]=Q(-.00327*a-.07276*o+1.07602*s)}function Eo(e,t,n,r,i){e*=r,t*=r,n*=r;let a=.6274*e+.3293*t+.0433*n,o=.0691*e+.9195*t+.0113*n,s=.0164*e+.088*t+.8956*n,c=.856627153315983*a+.0951212405381588*o+.0482516061458583*s,l=.137318972929847*a+.761241990602591*o+.101439036467562*s,u=.11189821299995*a+.0767994186031903*o+.811302368396859*s,d=-12.47393,f=4.026069-d;c=Q((Math.log2(Math.max(c,1e-10))-d)/f),l=Q((Math.log2(Math.max(l,1e-10))-d)/f),u=Q((Math.log2(Math.max(u,1e-10))-d)/f);let p=e=>{let t=e*e,n=t*t;return 15.5*n*t-40.14*n*e+31.96*n-6.868*t*e+.4298*t+.1191*e-.00232};c=p(c),l=p(l),u=p(u);let m=1.1271005818144368*c-.11060664309660323*l-.016493938717834573*u,h=-.1413297634984383*c+1.157823702216272*l-.016493938717834257*u,g=-.14132976349843826*c-.11060664309660294*l+1.2519364065950405*u;m=Math.max(0,m)**2.2,h=Math.max(0,h)**2.2,g=Math.max(0,g)**2.2,i[0]=Q(1.6605*m-.5876*h-.0728*g),i[1]=Q(-.1246*m+1.1329*h-.0083*g),i[2]=Q(-.0182*m-.1006*h+1.1187*g)}function Do(e,t,n,r,i){let a=.76;e*=r,t*=r,n*=r;let o=Math.min(e,Math.min(t,n)),s=o<.08?o-6.25*o*o:.04;e-=s,t-=s,n-=s;let c=Math.max(e,Math.max(t,n));if(c<a){i[0]=e,i[1]=t,i[2]=n;return}let l=1-a,u=1-l*l/(c+l-a),d=u/c;e*=d,t*=d,n*=d;let f=1-1/(.15*(c-u)+1);i[0]=e+(u-e)*f,i[1]=t+(u-t)*f,i[2]=n+(u-n)*f}var Oo=new Map([[r.NoToneMapping,xo],[r.LinearToneMapping,So],[r.ReinhardToneMapping,Co],[r.CineonToneMapping,wo],[r.ACESFilmicToneMapping,To],[r.AgXToneMapping,Eo],[r.NeutralToneMapping,Do]]),ko=1/2.2;function Ao(e){return e<=.0031308?12.92*e:1.055*e**(1/2.4)-.055}var jo=.2126,Mo=.7152,No=.0722;function Po(e,t){if(t===1)return;let n=e[0]*jo+e[1]*Mo+e[2]*No;e[0]=n+(e[0]-n)*t,e[1]=n+(e[1]-n)*t,e[2]=n+(e[2]-n)*t}var Fo=null,Io=null;async function Lo(){if(!Fo){let[e,t]=await Promise.all([import(`oidn-web`),import(`@tensorflow/tfjs-core`)]);Fo=e.initUNetFromURL,Io=t.engine}return Fo}function Ro(){if(Io)try{let e=Io();e?.registryFactory&&`webgpu-oidn`in e.registryFactory&&e.removeBackend(`webgpu-oidn`)}catch(e){console.warn(`OIDNDenoiser: failed to clear cached TFJS backend`,e)}}var $=new Float32Array(3),zo={QUALITY_MODELS:{fast:`rt_hdr_alb_nrm_small`,balance:`rt_hdr_alb_nrm`,high:`rt_hdr_calb_cnrm_large`},DEFAULT_OPTIONS:{enableOIDN:!0,oidnQuality:`fast`,debugGbufferMaps:!0,tileSize:256}},Bo=class extends r.EventDispatcher{constructor(e,t,n,i,a={}){if(super(),!e||!t||!n||!i)throw Error(`OIDNDenoiser requires output canvas, renderer, scene, and camera`);this.renderer=t,this.scene=n,this.camera=i,this.input=t.domElement,this.output=e,this.extractGBufferData=a.extractGBufferData||null,this.getMRTRenderTarget=a.getMRTRenderTarget||null,this.backendParamsGetter=a.backendParams||null,this.getGPUTextures=a.getGPUTextures||null,this.getExposure=a.getExposure||(()=>1),this.getToneMapping=a.getToneMapping||(()=>r.ACESFilmicToneMapping),this.getSaturation=a.getSaturation||(()=>1),this.getTransparentBackground=a.getTransparentBackground||(()=>!1),this.isGPUMode=!!this.backendParamsGetter,this.gpuDevice=null,this._gpuInputBuffers={color:null,albedo:null,normal:null},this._gpuInputBufferSize={width:0,height:0},this._gpuInputPadBuffer=null,this._gpuInputPaddedRowBytes=0,this._alphaReadbackBuffer=null,this._alphaReadbackMapped=!1,this._cachedAlpha=null,this._cachedAlphaWidth=0,this.config={...zo.DEFAULT_OPTIONS,...a},this.enabled=this.config.enableOIDN,this.quality=this.config.oidnQuality,this.debugGbufferMaps=this.config.debugGbufferMaps,this.tileSize=this.config.tileSize,this.state={isDenoising:!1,isLoading:!1,abortController:null},this._pendingStagingBuffers=new Set,this.currentTZAUrl=null,this.unet=null,this._initialize().catch(e=>{console.error(`Failed to initialize OIDNDenoiser:`,e),this.dispatchEvent({type:`error`,error:e})})}async _initialize(){try{this._setupCanvas(),await this._setupUNetDenoiser()}catch(e){throw Error(`Initialization failed: ${e.message}`)}}_setupCanvas(){if(!this.output.getContext)throw Error(`Output must be a valid Canvas element`);this.output.willReadFrequently=!0,this.output.width=this.input.width,this.output.height=this.input.height,Object.assign(this.output.style,{position:`absolute`,top:`0`,left:`0`,width:`100%`,height:`100%`,borderRadius:`5px`,background:`repeating-conic-gradient(#808080 0% 25%, transparent 0% 50%) 50% / 20px 20px`}),this.ctx=this.output.getContext(`2d`,{willReadFrequently:!0,alpha:!0})}async _setupUNetDenoiser(){if(this.state.isLoading)return;this.state.isLoading=!0;let e=this._generateTzaUrl();if(this.currentTZAUrl===e&&this.unet){this.state.isLoading=!1;return}try{this.dispatchEvent({type:`loading`,message:`Loading UNet denoiser...`}),this.unet&&=(this.unet.dispose(),null);let t;if(this.isGPUMode&&this.backendParamsGetter){let e=this.backendParamsGetter();this.gpuDevice=e?.device??null,t=e?.device?e:void 0}this.unet=await(await Lo())(e,t,{aux:!0,hdr:!0,maxTileSize:this.tileSize}),this.currentTZAUrl=e,this.dispatchEvent({type:`loaded`}),console.log(`UNet denoiser loaded successfully:`,e)}catch(e){console.error(`Failed to load UNet denoiser:`,e),this.dispatchEvent({type:`error`,error:Error(`Denoiser loading failed: ${e.message}`)})}finally{this.state.isLoading=!1}}_generateTzaUrl(){let{oidnWeightsBaseUrl:e}=La(),{QUALITY_MODELS:t}=zo;return`${e}${t[this.quality]||t.balance}.tza`}async updateConfiguration(e){Object.keys(e).some(t=>this.config[t]!==e[t])&&(Object.assign(this.config,e),this.quality=this.config.oidnQuality,this.debugGbufferMaps=this.config.debugGbufferMaps,this.tileSize=this.config.tileSize,await this._setupUNetDenoiser())}async updateQuality(e){if(!Object.prototype.hasOwnProperty.call(zo.QUALITY_MODELS,e))throw Error(`Invalid quality setting: ${e}. Must be one of: ${Object.keys(zo.QUALITY_MODELS).join(`, `)}`);await this.updateConfiguration({oidnQuality:e})}async start(){if(!this.enabled||this.state.isDenoising||this.state.isLoading)return!1;this.dispatchEvent({type:`start`});let e=performance.now(),t=await this.execute();if(t){this.renderer?.resetState?.(),this.input.style.opacity=`0`;let t=performance.now()-e;console.log(`Denoising completed in ${t.toFixed(1)}ms (quality: ${this.quality})`)}return t}async execute(){if(!this.enabled||!this.unet)return!1;this.state.abortController=new AbortController,this.state.isDenoising=!0,this.input.style.opacity=`0`,this.output.style.display=`block`;try{return await this._executeUNet(),!0}catch(e){return e.name===`AbortError`?console.log(`Denoising was aborted`):console.error(`Denoising error:`,e),this.input.style.opacity=`1`,!1}finally{this.state.isDenoising=!1,this.state.abortController=null,this.dispatchEvent({type:`end`})}}async _executeUNet(){return this._executeUNetGPU()}async _executeUNetGPU(){let{width:e,height:t}=this.output;if(!this.getGPUTextures)return console.warn(`OIDNDenoiser: GPU mode enabled but getGPUTextures not provided`),!1;let n=this.getGPUTextures();if(!n?.color)return console.warn(`OIDNDenoiser: GPU textures not ready yet`),!1;let r=this.gpuDevice;if(!r)return console.warn(`OIDNDenoiser: gpuDevice not available`),!1;this._ensureGPUInputBuffers(e,t);let i=r.createCommandEncoder({label:`oidn-tex-to-buf`}),a=e*16,o=this._gpuInputPaddedRowBytes,s=o>a,c=this._gpuInputPadBuffer,l=(n,r)=>{if(!s)i.copyTextureToBuffer({texture:n,mipLevel:0},{buffer:r,offset:0,bytesPerRow:a,rowsPerImage:t},{width:e,height:t,depthOrArrayLayers:1});else{i.copyTextureToBuffer({texture:n,mipLevel:0},{buffer:c,offset:0,bytesPerRow:o,rowsPerImage:t},{width:e,height:t,depthOrArrayLayers:1});for(let e=0;e<t;e++)i.copyBufferToBuffer(c,e*o,r,e*a,a)}};l(n.color,this._gpuInputBuffers.color),l(n.albedo,this._gpuInputBuffers.albedo),l(n.normal,this._gpuInputBuffers.normal),r.queue.submit([i.finish()]),this.getTransparentBackground()?await this._cacheInputAlpha(r,e,t):this._cachedAlpha=null,this.ctx.drawImage(this.input,0,0,e,t);let u={color:{data:this._gpuInputBuffers.color,width:e,height:t},albedo:{data:this._gpuInputBuffers.albedo,width:e,height:t},normal:{data:this._gpuInputBuffers.normal,width:e,height:t}};return this._executeWithAbortGPU(u)}_ensureGPUInputBuffers(e,t){let{width:n,height:r}=this._gpuInputBufferSize;if(n===e&&r===t&&this._gpuInputBuffers.color)return;this._destroyGPUInputBuffers();let i=this.gpuDevice,a=e*t*16,o=GPUBufferUsage.COPY_DST|GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_SRC;this._gpuInputBuffers.color=i.createBuffer({label:`oidn-in-color`,size:a,usage:o}),this._gpuInputBuffers.albedo=i.createBuffer({label:`oidn-in-albedo`,size:a,usage:o}),this._gpuInputBuffers.normal=i.createBuffer({label:`oidn-in-normal`,size:a,usage:o}),this._gpuInputBufferSize={width:e,height:t};let s=e*16,c=Math.ceil(s/256)*256;c===s?this._gpuInputPaddedRowBytes=s:(this._gpuInputPadBuffer=i.createBuffer({label:`oidn-in-pad`,size:c*t,usage:GPUBufferUsage.COPY_DST|GPUBufferUsage.COPY_SRC}),this._gpuInputPaddedRowBytes=c)}_destroyGPUInputBuffers(){if(this._gpuInputBuffers.color?.destroy(),this._gpuInputBuffers.albedo?.destroy(),this._gpuInputBuffers.normal?.destroy(),this._gpuInputPadBuffer?.destroy(),this._alphaReadbackMapped&&this._alphaReadbackBuffer)try{this._alphaReadbackBuffer.unmap()}catch{}this._alphaReadbackBuffer?.destroy(),this._alphaReadbackMapped=!1,this._gpuInputBuffers={color:null,albedo:null,normal:null},this._gpuInputPadBuffer=null,this._gpuInputPaddedRowBytes=0,this._alphaReadbackBuffer=null,this._gpuInputBufferSize={width:0,height:0}}async _cacheInputAlpha(e,t,n){let r=t*n*16;this._alphaReadbackBuffer===null&&(this._alphaReadbackBuffer=e.createBuffer({label:`oidn-alpha-readback`,size:r,usage:GPUBufferUsage.MAP_READ|GPUBufferUsage.COPY_DST}));let i=this._alphaReadbackBuffer,a=e.createCommandEncoder();a.copyBufferToBuffer(this._gpuInputBuffers.color,0,i,0,r),e.queue.submit([a.finish()]),this._alphaReadbackMapped=!0;try{await i.mapAsync(GPUMapMode.READ)}catch{this._alphaReadbackMapped=!1;return}let o=new Float32Array(i.getMappedRange()),s=t*n,c=new Uint8Array(s);for(let e=0;e<s;e++)c[e]=Math.min(Math.max(o[e*4+3]*255,0),255)|0;i.unmap(),this._alphaReadbackMapped=!1,this._cachedAlpha=c,this._cachedAlphaWidth=t}_executeWithAbortGPU(e){return new Promise((t,n)=>{if(this.state.abortController?.signal.aborted){n(new DOMException(`Aborted`,`AbortError`));return}let i=null,a=()=>{i&&=(i(),null),n(new DOMException(`Aborted`,`AbortError`))};this.state.abortController.signal.addEventListener(`abort`,a,{once:!0}),i=this.unet.tileExecute({...e,done:async e=>{this.state.abortController.signal.removeEventListener(`abort`,a),i=null;try{await this._displayGPUOutput(e),t()}catch(e){n(e)}},progress:(e,t,n)=>{if(!e?.data||!n)return;let i=this.gpuDevice,a=e.width,o=e.height,s=Math.min(n.width,a-n.x),c=Math.min(n.height,o-n.y);if(s<=0||c<=0)return;let l=s*16,u=s*c*16,d=i.createBuffer({size:u,usage:GPUBufferUsage.MAP_READ|GPUBufferUsage.COPY_DST});this._pendingStagingBuffers.add(d);let f=i.createCommandEncoder();for(let t=0;t<c;t++){let r=((n.y+t)*a+n.x)*16,i=t*l;f.copyBufferToBuffer(e.data,r,d,i,l)}i.queue.submit([f.finish()]),d.mapAsync(GPUMapMode.READ).then(()=>{let e=new Float32Array(d.getMappedRange()),t=new ImageData(s,c),i=this.getExposure(),l=this.getSaturation(),u=Oo.get(this.getToneMapping())||Oo.get(r.ACESFilmicToneMapping),f=this._cachedAlpha,p=this._cachedAlphaWidth;for(let r=0,a=e.length;r<a;r+=4){let a=e[r]*i,o=e[r+1]*i,c=e[r+2]*i;if(l!==1&&($[0]=a,$[1]=o,$[2]=c,Po($,l),a=$[0],o=$[1],c=$[2]),u(a,o,c,1,$),t.data[r]=Ao($[0])*255+.5|0,t.data[r+1]=Ao($[1])*255+.5|0,t.data[r+2]=Ao($[2])*255+.5|0,f){let e=(r>>2)%s,i=(r>>2)/s|0;t.data[r+3]=f[(n.y+i)*p+n.x+e]}else t.data[r+3]=255}d.unmap(),d.destroy(),this._pendingStagingBuffers.delete(d),this.ctx.putImageData(t,n.x,n.y),this.dispatchEvent({type:`tileProgress`,tile:{x:n.x,y:n.y,width:s,height:c},imageWidth:a,imageHeight:o})}).catch(()=>{d.destroy(),this._pendingStagingBuffers.delete(d)})}})})}async _displayGPUOutput({data:e,width:t,height:n}){let i=this.gpuDevice;if(!i){console.error(`OIDNDenoiser: gpuDevice not available for output readback`);return}let a=t*n*4*4,o=i.createBuffer({label:`oidn-output-staging`,size:a,usage:GPUBufferUsage.MAP_READ|GPUBufferUsage.COPY_DST});try{let s=i.createCommandEncoder({label:`oidn-readback`});s.copyBufferToBuffer(e,0,o,0,a),i.queue.submit([s.finish()]),await o.mapAsync(GPUMapMode.READ);let c=new Float32Array(o.getMappedRange()),l=new ImageData(t,n),u=this.getExposure(),d=this.getSaturation(),f=Oo.get(this.getToneMapping())||Oo.get(r.ACESFilmicToneMapping),p=this._cachedAlpha;for(let e=0,t=c.length;e<t;e+=4){let t=c[e]*u,n=c[e+1]*u,r=c[e+2]*u;d!==1&&($[0]=t,$[1]=n,$[2]=r,Po($,d),t=$[0],n=$[1],r=$[2]),f(t,n,r,1,$),l.data[e]=Ao($[0])*255+.5|0,l.data[e+1]=Ao($[1])*255+.5|0,l.data[e+2]=Ao($[2])*255+.5|0,l.data[e+3]=p?p[e>>2]:255}o.unmap(),this.ctx.putImageData(l,0,0)}finally{o.destroy()}}abort(){!this.enabled||!this.state.isDenoising||(this.state.abortController?.abort(),this._destroyPendingStagingBuffers(),this.input.style.opacity=`1`,this.state.isDenoising=!1,this.dispatchEvent({type:`end`}),console.log(`Denoising aborted`))}setSize(e,t){if(e<=0||t<=0)throw Error(`Invalid dimensions: ${e}x${t}`);this.output.width=e,this.output.height=t,this._setupUNetDenoiser().catch(e=>{console.error(`Failed to reinitialize denoiser after size change:`,e)})}_destroyPendingStagingBuffers(){for(let e of this._pendingStagingBuffers)e.destroy();this._pendingStagingBuffers.clear()}dispose(){this.abort(),this._destroyPendingStagingBuffers(),this.unet?.dispose(),Ro(),this._destroyGPUInputBuffers(),this.output?.parentNode&&this.output.remove(),this.unet=null,this.ctx=null,this.state.abortController=null,this.removeAllListeners?.(),console.log(`OIDNDenoiser disposed`)}},Vo=``+(typeof document>`u`&&typeof location>`u`?require(`url`).pathToFileURL(__dirname+`/assets/AIUpscalerWorker-AXN-lKWN.js`).href:new URL(`assets/AIUpscalerWorker-AXN-lKWN.js`,typeof document>`u`?location.href:document.currentScript&&document.currentScript.tagName.toUpperCase()===`SCRIPT`&&document.currentScript.src||document.baseURI).href),Ho={fast:{2:`2x-spanx2-ch48.onnx`,4:`4xNomos8k_span_otf_strong_fp32_opset17.onnx`},balanced:{2:`2xNomosUni_compact_otf_medium.onnx`,4:`RealESRGAN_x4plus.onnx`},quality:{2:`2x-realesrgan-x2plus.onnx`,4:`4xNomos2_hq_mosr_fp32.onnx`}};function Uo(){let{upscalerModelBaseUrl:e}=La(),t={};for(let n in Ho){t[n]={};for(let r in Ho[n])t[n][r]=e+Ho[n][r]}return t}var Wo={get QUALITY_PRESETS(){return Uo()},TILE_SIZE:512,TILE_OVERLAP:16,SESSION_OPTIONS:{executionProviders:[{name:`webgpu`,preferredLayout:`NCHW`}],graphOptimizationLevel:`all`}},Go=class extends r.EventDispatcher{constructor(e,t,n={}){if(super(),!e||!t)throw Error(`AIUpscaler requires output canvas and renderer`);this.renderer=t,this.input=t.domElement,this.output=e,this.getSourceCanvas=n.getSourceCanvas||null,this.getGPUTextures=n.getGPUTextures||null,this.getExposure=n.getExposure||(()=>1),this.getToneMapping=n.getToneMapping||(()=>r.ACESFilmicToneMapping),this.getSaturation=n.getSaturation||(()=>1),this.enabled=!1,this.hdr=!1,this.scaleFactor=n.scaleFactor||2,this.quality=n.quality||`fast`,this.tileSize=n.tileSize||Wo.TILE_SIZE,this._tileSizeOverride=!!n.tileSize,this.state={isUpscaling:!1,isLoading:!1,abortController:null},this._worker=null,this._currentModelUrl=null,this._tileId=0,this._pendingWorkerHandlers=new Set,this._upscaledAlpha=null,this._upscaledAlphaWidth=0,this._backupCanvas=null,this._baseWidth=e.width,this._baseHeight=e.height,this._hdrStagingBuffer=null,this._hdrStagingWidth=0,this._hdrStagingHeight=0}async _ensureSession(){let e=Wo.QUALITY_PRESETS[this.quality];if(!e)throw Error(`Unknown quality preset: ${this.quality}`);let t=e[this.scaleFactor];if(!t)throw Error(`No model for ${this.quality}/${this.scaleFactor}x`);if(!(this._worker&&this._currentModelUrl===t)){this.state.isLoading=!0,this.dispatchEvent({type:`loading`,message:`Loading ${this.scaleFactor}x upscale model...`});try{if(!this._worker)try{this._worker=new Worker(Vo,{type:`module`})}catch(e){if(e.name!==`SecurityError`)throw e;this._worker=await q(Vo)}await new Promise((e,n)=>{let r=t=>{t.data.type===`loaded`?(this._worker.removeEventListener(`message`,r),t.data.tileSize&&!this._tileSizeOverride&&(this.tileSize=t.data.tileSize),console.log(`AI Upscaler: ${this.scaleFactor}x model loaded, backend: ${t.data.backend}, tileSize: ${this.tileSize}`),e()):t.data.type===`error`&&(this._worker.removeEventListener(`message`,r),n(Error(t.data.message)))},{ortRuntimeUrl:i,ortWasmPaths:a,cacheNamespace:o}=La();this._worker.addEventListener(`message`,r),this._worker.postMessage({type:`load`,url:t,sessionOptions:Wo.SESSION_OPTIONS,ortRuntimeUrl:i,ortWasmPaths:a,cacheNamespace:o})}),this._currentModelUrl=t,this.dispatchEvent({type:`loaded`})}catch(e){throw console.error(`AI Upscaler: Failed to load model:`,e),this.dispatchEvent({type:`error`,error:e}),e}finally{this.state.isLoading=!1}}}async start(){if(!this.enabled||this.state.isUpscaling||this.state.isLoading)return!1;this.dispatchEvent({type:`start`});let e=performance.now(),t=await this.execute();if(t){this.renderer?.resetState?.();let t=performance.now()-e;console.log(`AI Upscaler: ${this.scaleFactor}x upscale completed in ${t.toFixed(1)}ms`)}return t}async execute(){if(!this.enabled)return!1;this.state.abortController=new AbortController,this.state.isUpscaling=!0,this.input.style.opacity=`0`,this.output.style.display=`block`,this.hdr&&this.getGPUTextures?this._capturedSource=await this._captureSourceHDR():this._capturedSource=this._captureSource(),this._createBackup(this._capturedSource);let e=this._capturedSource.width*this.scaleFactor,t=this._capturedSource.height*this.scaleFactor;this.output.width=e,this.output.height=t;let n=this.output.getContext(`2d`,{willReadFrequently:!0,alpha:!0});n.imageSmoothingEnabled=!0,n.imageSmoothingQuality=`high`,n.drawImage(this._backupCanvas,0,0,e,t);try{return await this._ensureSession(),await this._runUpscale(),this.dispatchEvent({type:`resolution_changed`,width:this.output.width,height:this.output.height}),!0}catch(e){return e.name===`AbortError`?console.log(`AI Upscaler: Upscaling was aborted`):(console.error(`AI Upscaler: Upscaling error:`,e),this.dispatchEvent({type:`error`,error:e}),this._restoreBackup(),this.input.style.opacity=`1`,this.dispatchEvent({type:`resolution_changed`,width:this._baseWidth,height:this._baseHeight})),!1}finally{this._capturedSource=null,this._upscaledAlpha=null,this._backupCanvas=null,this.state.isUpscaling&&(this.state.isUpscaling=!1,this.state.abortController=null,this.dispatchEvent({type:`end`}))}}abort(){this.state.isUpscaling&&(this.state.abortController?.abort(),this._cleanupPendingWorkerHandlers(),this.input.style.opacity=`1`,this._restoreBackup(),this.dispatchEvent({type:`resolution_changed`,width:this._baseWidth,height:this._baseHeight}),this.state.isUpscaling=!1,this.dispatchEvent({type:`end`}),console.log(`AI Upscaler: Aborted`))}async _runUpscale(){let e=this.state.abortController.signal,t=this._capturedSource;this._capturedSource=null;let{width:n,height:i}=t,a=this.scaleFactor,o=this.output.getContext(`2d`,{willReadFrequently:!0,alpha:!0});this._cacheUpscaledAlpha(t,n*a,i*a),t.isHDR&&(this._hdrToneMapFn=Oo.get(this.getToneMapping())||Oo.get(r.ACESFilmicToneMapping),this._hdrExposure=this.getExposure(),this._hdrSaturation=this.getSaturation(),this._tmOut=new Float32Array(3));let s=Wo.TILE_OVERLAP,c=this.tileSize,l=c-s*2,u=Math.ceil(n/l),d=Math.ceil(i/l),f=u*d,p=0;for(let r=0;r<d;r++)for(let s=0;s<u;s++){if(e.aborted)throw new DOMException(`Aborted`,`AbortError`);let u=Math.min(s*l,Math.max(0,n-c)),d=Math.min(r*l,Math.max(0,i-c)),m=Math.min(c,n-u),h=Math.min(c,i-d),g=this._extractTile(t,u,d,m,h),_=await this._inferTile(g,m,h),v=u*a,y=d*a,b=m*a,x=h*a,S=this._tensorToImageData(_,b,x,v,y);o.putImageData(S,v,y),p++,this.dispatchEvent({type:`progress`,progress:p/f,tile:{x:s,y:r,total:f,completed:p}}),this.dispatchEvent({type:`tileProgress`,tile:{x:v,y,width:b,height:x},imageWidth:n*a,imageHeight:i*a})}}_captureSource(){let e=this.getSourceCanvas?this.getSourceCanvas():null;if(e&&e!==this.output){let t=document.createElement(`canvas`);t.width=e.width,t.height=e.height;let n=t.getContext(`2d`);return n.drawImage(e,0,0),n.getImageData(0,0,t.width,t.height)}return this.output.getContext(`2d`,{willReadFrequently:!0}).getImageData(0,0,this.output.width,this.output.height)}async _captureSourceHDR(){let e=this.getGPUTextures();if(!e?.color)throw Error(`No GPU color texture available for HDR capture`);let t=this.renderer.backend.device,n=e.color,r=n.width,i=n.height,a=Math.ceil(r*16/256)*256,o=a*i;(this._hdrStagingWidth!==r||this._hdrStagingHeight!==i)&&(this._hdrStagingBuffer?.destroy(),this._hdrStagingBuffer=t.createBuffer({label:`aiupscaler-hdr-readback`,size:o,usage:GPUBufferUsage.MAP_READ|GPUBufferUsage.COPY_DST}),this._hdrStagingWidth=r,this._hdrStagingHeight=i);let s=this._hdrStagingBuffer,c=t.createCommandEncoder();c.copyTextureToBuffer({texture:n},{buffer:s,bytesPerRow:a,rowsPerImage:i},{width:r,height:i,depthOrArrayLayers:1}),t.queue.submit([c.finish()]),await s.mapAsync(GPUMapMode.READ);let l=new Float32Array(s.getMappedRange()),u=r*4,d=a/4,f=new Float32Array(r*i*4);for(let e=0;e<i;e++){let t=e*d,n=e*u;f.set(l.subarray(t,t+u),n)}return s.unmap(),{data:f,width:r,height:i,isHDR:!0}}_extractTile(e,t,n,r,i){let{data:a,width:o}=e,s=e.isHDR,c=r*i,l=new Float32Array(3*c);for(let e=0;e<i;e++)for(let i=0;i<r;i++){let u=((n+e)*o+(t+i))*4,d=e*r+i;if(s){let e=this._hdrToneMapFn,t=this._hdrExposure,n=this._hdrSaturation,r=a[u]*t,i=a[u+1]*t,o=a[u+2]*t;n!==1&&(this._tmOut[0]=r,this._tmOut[1]=i,this._tmOut[2]=o,Po(this._tmOut,n),r=this._tmOut[0],i=this._tmOut[1],o=this._tmOut[2]),e(r,i,o,1,this._tmOut),l[d]=this._tmOut[0]**+ko,l[c+d]=this._tmOut[1]**+ko,l[2*c+d]=this._tmOut[2]**+ko}else l[d]=a[u]/255,l[c+d]=a[u+1]/255,l[2*c+d]=a[u+2]/255}return l}async _inferTile(e,t,n){let r=++this._tileId;return new Promise((i,a)=>{let o=e=>{e.data.id===r&&(this._worker.removeEventListener(`message`,o),this._pendingWorkerHandlers.delete(o),e.data.type===`inferred`?i(e.data.outputData):e.data.type===`error`&&a(Error(e.data.message)))};this._pendingWorkerHandlers.add(o),this._worker.addEventListener(`message`,o),this._worker.postMessage({type:`infer`,tileData:e,width:t,height:n,id:r},[e.buffer])})}_tensorToImageData(e,t,n,r,i){let a=new ImageData(t,n),o=a.data,s=t*n,c=this._upscaledAlpha,l=this._upscaledAlphaWidth;for(let n=0;n<s;n++)if(o[n*4]=Math.min(255,Math.max(0,e[n]*255+.5))|0,o[n*4+1]=Math.min(255,Math.max(0,e[s+n]*255+.5))|0,o[n*4+2]=Math.min(255,Math.max(0,e[2*s+n]*255+.5))|0,c){let e=n/t|0,a=n%t;o[n*4+3]=c[(i+e)*l+(r+a)]}else o[n*4+3]=255;return a}_cacheUpscaledAlpha(e,t,n){let{data:r,width:i,height:a}=e,o=e.isHDR,s=o?1:255,c=!1;for(let e=3;e<r.length;e+=4)if(r[e]<s){c=!0;break}if(!c){this._upscaledAlpha=null,this._upscaledAlphaWidth=0;return}let l=document.createElement(`canvas`);l.width=i,l.height=a;let u=l.getContext(`2d`),d=u.createImageData(i,a);for(let e=0,t=i*a;e<t;e++){let t=o?Math.min(Math.max(r[e*4+3]*255,0),255)|0:r[e*4+3];d.data[e*4]=t,d.data[e*4+1]=t,d.data[e*4+2]=t,d.data[e*4+3]=255}u.putImageData(d,0,0);let f=document.createElement(`canvas`);f.width=t,f.height=n;let p=f.getContext(`2d`);p.imageSmoothingEnabled=!0,p.imageSmoothingQuality=`high`,p.drawImage(l,0,0,t,n);let m=p.getImageData(0,0,t,n).data,h=new Uint8Array(t*n);for(let e=0,r=t*n;e<r;e++)h[e]=m[e*4];this._upscaledAlpha=h,this._upscaledAlphaWidth=t}_createBackup(e){this._backupCanvas=document.createElement(`canvas`),this._backupCanvas.width=e.width,this._backupCanvas.height=e.height;let t=this._backupCanvas.getContext(`2d`);if(e.isHDR){let{data:n,width:i,height:a}=e,o=t.createImageData(i,a),s=o.data,c=Oo.get(this.getToneMapping())||Oo.get(r.ACESFilmicToneMapping),l=this.getExposure(),u=this.getSaturation(),d=new Float32Array(3);for(let e=0,t=i*a;e<t;e++){let t=e*4,r=n[t]*l,i=n[t+1]*l,a=n[t+2]*l;u!==1&&(d[0]=r,d[1]=i,d[2]=a,Po(d,u),r=d[0],i=d[1],a=d[2]),c(r,i,a,1,d),s[t]=d[0]**+ko*255+.5|0,s[t+1]=d[1]**+ko*255+.5|0,s[t+2]=d[2]**+ko*255+.5|0,s[t+3]=255}t.putImageData(o,0,0)}else t.putImageData(e,0,0)}_restoreBackup(){this._backupCanvas&&=(this.output.width=this._backupCanvas.width,this.output.height=this._backupCanvas.height,this.output.getContext(`2d`).drawImage(this._backupCanvas,0,0),null)}toggleHDR(e){this.hdr=!!e}setQuality(e){if(!Wo.QUALITY_PRESETS[e]){console.warn(`AIUpscaler: Invalid quality "${e}", must be fast/balanced/quality`);return}this.quality=e}setScaleFactor(e){if(e=Number(e),e!==2&&e!==4){console.warn(`AIUpscaler: Invalid scale factor ${e}, must be 2 or 4`);return}this.scaleFactor=e}setBaseSize(e,t){this._baseWidth=e,this._baseHeight=t}_cleanupPendingWorkerHandlers(){if(this._worker)for(let e of this._pendingWorkerHandlers)this._worker.removeEventListener(`message`,e);this._pendingWorkerHandlers.clear()}async dispose(){this.abort(),this._cleanupPendingWorkerHandlers(),this._worker&&=(this._worker.postMessage({type:`dispose`}),this._worker.terminate(),null),this._currentModelUrl=null,this._backupCanvas=null,this._upscaledAlpha=null,this.state.abortController=null,this._hdrStagingBuffer?.destroy(),this._hdrStagingBuffer=null,this._hdrStagingWidth=0,this._hdrStagingHeight=0,console.log(`AIUpscaler disposed`)}},Ko=class extends r.EventDispatcher{constructor({renderer:e,mainCanvas:t,scene:n,camera:r,stages:i,pipeline:a,getExposure:o,getSaturation:s,getTransparentBg:c}){super(),this.renderer=e,this.mainCanvas=t,this.denoiserCanvas=this._createDenoiserCanvas(t),this.scene=n,this.camera=r,this.pipeline=a,this._stages=i,this._getExposure=o,this._getSaturation=s,this._getTransparentBg=c,this.denoiser=null,this.upscaler=null,this._lastRenderWidth=0,this._lastRenderHeight=0,this._pendingStartUpscaler=null,this._denoiserStartHandler=null,this._denoiserEndHandler=null,this._upscalerResChangedHandler=null,this._upscalerStartHandler=null,this._upscalerProgressHandler=null,this._upscalerEndHandler=null}_createDenoiserCanvas(e){let t=e.parentNode;if(!t)return null;let n=document.createElement(`canvas`);return n.width=e.width,n.height=e.height,n.style.position=`absolute`,n.style.inset=`0`,n.style.width=`100%`,n.style.height=`100%`,t.insertBefore(n,e),n}setRenderSize(e,t){this._lastRenderWidth=e,this._lastRenderHeight=t,this.denoiser?.setSize(e,t),this.upscaler?.setBaseSize(e,t)}restoreBaseResolution(){if(!this.denoiserCanvas||!this._lastRenderWidth||!this._lastRenderHeight)return!1;let e=this.denoiserCanvas.width!==this._lastRenderWidth||this.denoiserCanvas.height!==this._lastRenderHeight;return this.denoiserCanvas.width=this._lastRenderWidth,this.denoiserCanvas.height=this._lastRenderHeight,e}setupDenoiser(){if(!this.denoiserCanvas)return;let e=this._stages.pathTracer;this.denoiser=new Bo(this.denoiserCanvas,this.renderer,this.scene,this.camera,{...V,backendParams:()=>({device:this.renderer.backend.device,adapterInfo:null}),getGPUTextures:()=>{if(!e?.storageTextures?.readTarget)return null;let t=e.storageTextures.getReadTextures(),{backend:n}=this.renderer;return{color:n.get(t.color).texture,normal:n.get(t.normalDepth).texture,albedo:n.get(t.albedo).texture}},getExposure:()=>this._getEffectiveExposure(),getToneMapping:()=>this._getToneMapping(),getSaturation:()=>this._getSaturation(),getTransparentBackground:()=>this._getTransparentBg(),getMRTRenderTarget:()=>e?.storageTextures?.readTarget??null}),this.denoiser.enabled=V.enableOIDN,this._denoiserStartHandler=()=>this.dispatchEvent({type:z.DENOISING_START}),this._denoiserEndHandler=()=>this.dispatchEvent({type:z.DENOISING_END}),this.denoiser.addEventListener(`start`,this._denoiserStartHandler),this.denoiser.addEventListener(`end`,this._denoiserEndHandler)}setupUpscaler(){if(!this.denoiserCanvas)return;let e=this._stages.pathTracer;this.upscaler=new Go(this.denoiserCanvas,this.renderer,{scaleFactor:V.upscalerScale||2,quality:V.upscalerQuality||`fast`,getSourceCanvas:()=>this.denoiser?.enabled?null:this.renderer.domElement,getGPUTextures:()=>{if(!e?.storageTextures?.readTarget)return null;let t=e.storageTextures.getReadTextures();return{color:this.renderer.backend.get(t.color).texture}},getExposure:()=>this._getEffectiveExposure(),getToneMapping:()=>this._getToneMapping(),getSaturation:()=>this._getSaturation()}),this.upscaler.enabled=V.enableUpscaler||!1,this._upscalerResChangedHandler=e=>this.dispatchEvent({type:`resolution_changed`,width:e.width,height:e.height}),this._upscalerStartHandler=()=>this.dispatchEvent({type:z.UPSCALING_START}),this._upscalerProgressHandler=e=>this.dispatchEvent({type:z.UPSCALING_PROGRESS,progress:e.progress}),this._upscalerEndHandler=()=>this.dispatchEvent({type:z.UPSCALING_END}),this.upscaler.addEventListener(`resolution_changed`,this._upscalerResChangedHandler),this.upscaler.addEventListener(`start`,this._upscalerStartHandler),this.upscaler.addEventListener(`progress`,this._upscalerProgressHandler),this.upscaler.addEventListener(`end`,this._upscalerEndHandler)}setDenoiserStrategy(e,t){let n=this._stages;switch(n.asvgf&&(n.asvgf.enabled=!1),n.variance&&!this._isAdaptiveSamplingActive()&&(n.variance.enabled=!1),n.bilateralFilter&&(n.bilateralFilter.enabled=!1),n.edgeFilter&&n.edgeFilter.setFilteringEnabled(!1),n.ssrc&&(n.ssrc.enabled=!1),this._clearDenoiserTextures(),e){case`asvgf`:n.asvgf.enabled=!0,n.variance&&(n.variance.enabled=!0),n.bilateralFilter&&(n.bilateralFilter.enabled=!0),n.asvgf.setTemporalEnabled?.(!0),this._applyASVGFPreset(t||`medium`);break;case`ssrc`:n.ssrc&&(n.ssrc.enabled=!0);break;case`edgeaware`:n.edgeFilter&&n.edgeFilter.setFilteringEnabled(!0);break}}setASVGFEnabled(e,t){let n=this._stages;n.asvgf&&(n.asvgf.enabled=e),n.variance&&(n.variance.enabled=e),n.bilateralFilter&&(n.bilateralFilter.enabled=e),e&&(n.asvgf?.setTemporalEnabled?.(!0),this._applyASVGFPreset(t||`medium`)),n.edgeFilter&&n.edgeFilter.setFilteringEnabled(!e)}applyASVGFPreset(e){this._applyASVGFPreset(e)}setAutoExposureEnabled(e,t){let n=this._stages;n.autoExposure&&(n.autoExposure.enabled=e,!e&&this.renderer&&(this.renderer.toneMappingExposure=t))}setAdaptiveSamplingEnabled(e){let t=this._stages;t.adaptiveSampling&&(t.adaptiveSampling.enabled=e,t.adaptiveSampling.setHeatmapEnabled(!1)),e?t.variance&&(t.variance.enabled=!0):t.asvgf?.enabled||t.variance&&(t.variance.enabled=!1),!e&&this.pipeline?.context&&!t.asvgf?.enabled&&this.pipeline.context.removeTexture(`variance:output`)}_cleanupCompletionListener(){this._pendingStartUpscaler&&this.denoiser&&this.denoiser.removeEventListener(`end`,this._pendingStartUpscaler),this._pendingStartUpscaler=null}onRenderComplete({isStillComplete:e,context:t}){this._cleanupCompletionListener(),(this.denoiser?.enabled||this.upscaler?.enabled)&&this.denoiserCanvas&&(this.denoiserCanvas.style.display=`block`);let n=()=>{this._pendingStartUpscaler=null,e()&&this.upscaler?.enabled&&this.upscaler.start()};this.denoiser?.enabled?(this._pendingStartUpscaler=n,this.denoiser.addEventListener(`end`,n,{once:!0}),this.denoiser.start()):(this.upscaler?.enabled&&this._stages.compositor&&t&&this._stages.compositor.render(t),n())}abort(e){this._cleanupCompletionListener(),e&&(e.style.opacity=`1`),this.upscaler&&this.upscaler.abort(),this.denoiser&&(this.denoiser.enabled&&this.denoiser.abort(),this.denoiser.output&&(this.denoiser.output.style.display=`none`))}dispose(){this._cleanupCompletionListener(),this.denoiser&&=(this._denoiserStartHandler&&this.denoiser.removeEventListener(`start`,this._denoiserStartHandler),this._denoiserEndHandler&&this.denoiser.removeEventListener(`end`,this._denoiserEndHandler),this.denoiser.dispose(),null),this.upscaler&&=(this._upscalerResChangedHandler&&this.upscaler.removeEventListener(`resolution_changed`,this._upscalerResChangedHandler),this._upscalerStartHandler&&this.upscaler.removeEventListener(`start`,this._upscalerStartHandler),this._upscalerProgressHandler&&this.upscaler.removeEventListener(`progress`,this._upscalerProgressHandler),this._upscalerEndHandler&&this.upscaler.removeEventListener(`end`,this._upscalerEndHandler),this.upscaler.dispose(),null),this._denoiserStartHandler=null,this._denoiserEndHandler=null,this._upscalerResChangedHandler=null,this._upscalerStartHandler=null,this._upscalerProgressHandler=null,this._upscalerEndHandler=null,this.denoiserCanvas?.parentNode&&(this.denoiserCanvas.parentNode.removeChild(this.denoiserCanvas),this.denoiserCanvas=null)}setOverlayManager(e){this._overlayManager=e}setResetCallback(e){this._onReset=e}setSettings(e){this._settings=e}setASVGFParams(e){this._stages.asvgf?.updateParameters(e)}toggleASVGFHeatmap(e){this._stages.asvgf?.setHeatmapEnabled?.(e)}configureASVGFForMode(e){this._stages.asvgf&&(this._stages.asvgf.enabled=e.enabled,this._stages.variance&&(this._stages.variance.enabled=e.enabled),this._stages.bilateralFilter&&(this._stages.bilateralFilter.enabled=e.enabled),e.enabled&&this._stages.asvgf.updateParameters(e))}setSSRCParams(e){this._stages.ssrc?.updateParameters(e)}setEdgeAwareParams(e){this._stages.edgeFilter?.updateUniforms(e)}setAutoExposureParams(e){this._stages.autoExposure?.updateParameters(e)}setAdaptiveSamplingParams(e){e.min!==void 0&&this._stages.pathTracer?.setAdaptiveSamplingMin(e.min),e.adaptiveSamplingMax!==void 0&&this._settings?.set(`adaptiveSamplingMax`,e.adaptiveSamplingMax),this._stages.adaptiveSampling?.setAdaptiveSamplingParameters(e)}toggleAdaptiveSamplingHelper(e){this._stages.adaptiveSampling?.setHeatmapEnabled(e)}setOIDNEnabled(e){this.denoiser&&(this.denoiser.enabled=e)}setOIDNQuality(e){this.denoiser?.updateQuality(e)}setOIDNTileHelper(e){this._setTileHelper(e)}setTileHelperEnabled(e){this._setTileHelper(e)}setTileHighlightEnabled(e){this._setTileHelper(e)}setUpscalerEnabled(e){this.upscaler&&(this.upscaler.enabled=e)}setUpscalerScaleFactor(e){this.upscaler?.setScaleFactor(e)}setUpscalerQuality(e){this.upscaler?.setQuality(e)}setAutoExposure(e){this.setAutoExposureEnabled(e,this._getExposure()),this._onReset?.()}setAdaptiveSampling(e){this._settings?.set(`useAdaptiveSampling`,e),this.setAdaptiveSamplingEnabled(e)}setStrategy(e,t){this.setDenoiserStrategy(e,t),this._onReset?.()}_setTileHelper(e){let t=this._overlayManager?.getHelper(`tiles`);t&&(t.enabled=e,e||t.hide())}_getEffectiveExposure(){return this._stages.autoExposure?.enabled?this.renderer.toneMappingExposure:this._getExposure()}_getToneMapping(){return this.renderer.toneMapping}_isAdaptiveSamplingActive(){return this._stages.adaptiveSampling?.enabled??!1}_clearDenoiserTextures(){let e=this.pipeline?.context;e&&[`asvgf:output`,`asvgf:temporalColor`,`asvgf:variance`,`variance:output`,`bilateralFiltering:output`,`edgeFiltering:output`,`ssrc:output`].forEach(t=>e.removeTexture(t))}_applyASVGFPreset(e){let t=Ce[e];t&&this._stages.asvgf?.updateParameters(t)}},qo=class{constructor(){this.layer=`hud`,this.visible=!1,this._tileBounds=null,this._imageWidth=1,this._imageHeight=1,this.enabled=!0,this._borderColor=`rgba(255, 0, 0, 0.6)`,this._borderWidthRatio=1/540,this._borderWidthMin=1.5,this._borderWidthMax=4}setActiveTile(e){this._tileBounds=e}setRenderSize(e,t){this._imageWidth=e,this._imageHeight=t}render(e,t,n){if(!this._tileBounds)return;let r=this._tileBounds,i=t/this._imageWidth,a=n/this._imageHeight,o=r.x*i,s=r.y*a,c=r.width*i,l=r.height*a,u=Math.min(this._borderWidthMax,Math.max(this._borderWidthMin,Math.min(t,n)*this._borderWidthRatio));e.strokeStyle=this._borderColor,e.lineWidth=u,e.strokeRect(o,s,c,l)}show(){this.enabled&&(this.visible=!0)}hide(){this.visible=!1,this._tileBounds=null}dispose(){this.visible=!1}},Jo=class{constructor(e,i,a){this.layer=`scene`,this.visible=!0,this._outlineNode=(0,h.outline)(i,a,{selectedObjects:[],edgeThickness:(0,n.uniform)(1),edgeGlow:(0,n.uniform)(0)}),this._displayWidth=1,this._displayHeight=1;let o=this._outlineNode.setSize.bind(this._outlineNode);this._outlineNode.setSize=()=>{o(this._displayWidth,this._displayHeight)};let s=(0,n.uniform)(3),c=(0,n.uniform)(new r.Color(16777215)),l=(0,n.uniform)(new r.Color(1640965)),{visibleEdge:u,hiddenEdge:d}=this._outlineNode,f=u.mul(c).add(d.mul(l)).mul(s);this._material=new t.MeshBasicNodeMaterial,this._material.colorNode=(0,n.vec4)(f,1),this._material.blending=r.AdditiveBlending,this._material.toneMapped=!1,this._material.depthTest=!1,this._material.depthWrite=!1,this._quad=new t.QuadMesh(this._material)}setSelectedObjects(e){this._outlineNode.selectedObjects=e}render(e){if(this._outlineNode.selectedObjects.length===0)return;let t=e.autoClear;e.autoClear=!1,e.setRenderTarget(null),this._quad.render(e),e.autoClear=t}setSize(e,t){this._displayWidth=e,this._displayHeight=t,this._outlineNode.setSize(e,t)}show(){this.visible=!0}hide(){this.visible=!1}dispose(){this.visible=!1,this._outlineNode?.dispose(),this._material?.dispose(),this._quad=null}},Yo=class{constructor(e,t){this.renderer=e,this.camera=t,this._helpers=new Map,this._hudCanvas=document.createElement(`canvas`),this._hudCanvas.style.cssText=`position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;`,this._hudCtx=this._hudCanvas.getContext(`2d`),this._helperScene=null}setHelperScene(e){this._helperScene=e}getHUDCanvas(){return this._hudCanvas}mount(e){!e||this._hudCanvas.parentElement===e||e.appendChild(this._hudCanvas)}setupDefaultHelpers({helperScene:e,meshScene:t,pipeline:n,denoisingManager:r,app:i,renderWidth:a,renderHeight:o}){this.setHelperScene(e);let s=new qo;this.register(`tiles`,s),s.setRenderSize(a||1,o||1),i.addEventListener(`resolution_changed`,e=>{s.setRenderSize(e.width,e.height)}),n.eventBus.on(`tile:changed`,e=>{e.renderMode===1&&e.tileBounds&&(s.setActiveTile(e.tileBounds),s.show())}),n.eventBus.on(`pipeline:reset`,()=>s.hide()),i.addEventListener(z.RENDER_COMPLETE,()=>s.hide()),this._wireDenoiserTileEvents(s,r);let c=new Jo(this.renderer,t,this.camera);this.register(`outline`,c)}_wireDenoiserTileEvents(e,t){let n=[t?.denoiser,t?.upscaler];for(let t of n)t&&(t.addEventListener(`tileProgress`,t=>{t.tile&&(e.setRenderSize(t.imageWidth,t.imageHeight),e.setActiveTile(t.tile),e.show(),this.refreshHUD())}),t.addEventListener(`end`,()=>{e.hide(),this.refreshHUD()}))}register(e,t){this._helpers.has(e)&&(console.warn(`OverlayManager: helper "${e}" already registered — replacing.`),this._helpers.get(e).dispose?.()),this._helpers.set(e,t)}unregister(e){let t=this._helpers.get(e);t&&(t.dispose?.(),this._helpers.delete(e))}show(e){this._helpers.get(e)?.show()}hide(e){this._helpers.get(e)?.hide()}toggle(e){let t=this._helpers.get(e);t&&(t.visible?t.hide():t.show())}getHelper(e){return this._helpers.get(e)??null}isVisible(e){return this._helpers.get(e)?.visible??!1}showAll(){for(let e of this._helpers.values())e.show()}hideAll(){for(let e of this._helpers.values())e.hide()}render(){this._helperScene&&this._helperScene.render(this.renderer,this.camera);for(let e of this._helpers.values())e.visible&&e.layer===`scene`&&e.render&&e.render(this.renderer,this.camera);this.refreshHUD()}setSize(e,t){for(let n of this._helpers.values())n.setSize?.(e,t)}refreshHUD(){let e=this._hudCanvas,t=this._hudCtx,n=!1;for(let e of this._helpers.values())if(e.visible&&e.layer===`hud`&&e.render){n=!0;break}if(!n){e.style.display!==`none`&&(e.style.display=`none`);return}let r=window.devicePixelRatio||1,i=e.clientWidth,a=e.clientHeight,o=Math.round(i*r),s=Math.round(a*r);(e.width!==o||e.height!==s)&&(e.width=o,e.height=s),t.clearRect(0,0,o,s),t.save(),t.scale(r,r);for(let e of this._helpers.values())e.visible&&e.layer===`hud`&&e.render&&e.render(t,i,a);t.restore(),e.style.display!==``&&(e.style.display=``)}dispose(){for(let e of this._helpers.values())e.dispose?.();this._helpers.clear(),this._hudCanvas.parentElement&&this._hudCanvas.parentElement.removeChild(this._hudCanvas)}},Xo=class extends r.EventDispatcher{constructor(){super(),this.mixer=null,this.timer=new r.Timer,this.actions=[],this.isPlaying=!1,this._scene=null,this._mixerRoot=null,this._meshes=null,this._meshTriRanges=null,this._posBuffer=null,this._tempVec=new r.Vector3,this._skinnedCache=null,this._totalTriangleCount=0,this._clipsCache=null,this._savedTimeScale=1,this.onFinished=null,this.wakeCallback=null}init(e,t,n,i,a){if(this.dispose(),!i||i.length===0)return;this._scene=e,this._mixerRoot=t,this._meshes=n,this._totalTriangleCount=a,this.mixer=new r.AnimationMixer(t);let o=i.map(e=>this.mixer.clipAction(e)),s=(e,t)=>e.name===t||e.getObjectByName(t)!==void 0;!o.some(e=>e.getClip().tracks.some(e=>{let n=e.name.split(`.`)[0];return s(t,n)}))&&t!==e&&(console.log(`[AnimationManager] Tracks did not resolve from model root, retrying with scene root`),this.mixer=new r.AnimationMixer(e),this._mixerRoot=e,o=i.map(e=>this.mixer.clipAction(e))),this.actions=o,this.mixer.addEventListener(`finished`,()=>{this.isPlaying=!1,this.timer.reset(),this.onFinished&&this.onFinished()}),this._meshTriRanges=[],this._skinnedCache=[];let c=0;for(let e of n){let t=e.geometry,n=t.attributes.position,r=t.index?t.index.array:null,i=r?r.length/3:n.count/3,a=n.count;this._meshTriRanges.push({start:c,count:i,uniqueVerts:a,indices:r}),this._skinnedCache.push(new Float32Array(a*3)),c+=i}this._posBuffer=new Float32Array(a*9);let l=n.filter(e=>e.isSkinnedMesh).length;console.debug(`[AnimationManager] Init: ${i.length} clips, ${n.length} meshes (${l} skinned), ${a} triangles`)}play(e=0){if(!(!this.mixer||this.actions.length===0)){if(this.mixer.stopAllAction(),e===-1)for(let e of this.actions)e.play();else e>=0&&e<this.actions.length&&this.actions[e].play();this.timer.reset(),this.isPlaying=!0,this.wakeCallback?.(),this.dispatchEvent({type:z.ANIMATION_STARTED})}}pause(){this.mixer&&(this.mixer.timeScale=0,this.timer.reset(),this.isPlaying=!1,this.dispatchEvent({type:z.ANIMATION_PAUSED}))}resume(){this.mixer&&(this.mixer.timeScale=this._savedTimeScale||1,this.timer.reset(),this.isPlaying=!0,this.wakeCallback?.(),this.dispatchEvent({type:z.ANIMATION_STARTED}))}stop(){this.mixer&&(this.mixer.stopAllAction(),this.mixer.timeScale=this._savedTimeScale||1,this.timer.reset(),this.isPlaying=!1,this.dispatchEvent({type:z.ANIMATION_STOPPED}))}setSpeed(e){this._savedTimeScale=e,this.mixer&&this.isPlaying&&(this.mixer.timeScale=e)}setLoop(e){let t=e?r.LoopRepeat:r.LoopOnce;for(let n of this.actions)n.setLoop(t),n.clampWhenFinished=!e}seekTo(e,t=0){if(!this.mixer||this.actions.length===0)return null;if(this.mixer.stopAllAction(),t===-1)for(let e of this.actions)e.play();else t>=0&&t<this.actions.length&&this.actions[t].play();this.mixer.setTime(e);for(let e of this.actions)e.isRunning()&&(e.paused=!0);return this._computePositions(),this._posBuffer}get currentTime(){return this.mixer?.time||0}update(){if(!this.isPlaying||!this.mixer)return null;this.timer.update();let e=this.timer.getDelta();return this.mixer.update(e),this._computePositions(),this._posBuffer}_computePositions(){let e=this._tempVec,t=this._posBuffer;this._mixerRoot.updateMatrixWorld(!0);for(let n=0;n<this._meshes.length;n++){let r=this._meshes[n],{start:i,count:a,uniqueVerts:o,indices:s}=this._meshTriRanges[n],c=this._skinnedCache[n],l=r.matrixWorld;for(let t=0;t<o;t++)r.getVertexPosition(t,e),e.applyMatrix4(l),c[t*3]=e.x,c[t*3+1]=e.y,c[t*3+2]=e.z;if(s)for(let e=0;e<a;e++){let n=e*3,r=s[n]*3,a=s[n+1]*3,o=s[n+2]*3,l=(i+e)*9;t[l]=c[r],t[l+1]=c[r+1],t[l+2]=c[r+2],t[l+3]=c[a],t[l+4]=c[a+1],t[l+5]=c[a+2],t[l+6]=c[o],t[l+7]=c[o+1],t[l+8]=c[o+2]}else for(let e=0;e<a;e++){let n=e*3*3,r=(e*3+1)*3,a=(e*3+2)*3,o=(i+e)*9;t[o]=c[n],t[o+1]=c[n+1],t[o+2]=c[n+2],t[o+3]=c[r],t[o+4]=c[r+1],t[o+5]=c[r+2],t[o+6]=c[a],t[o+7]=c[a+1],t[o+8]=c[a+2]}}}get hasAnimations(){return this.actions.length>0}get clips(){return this._clipsCache||=this.actions.map((e,t)=>{let n=e.getClip();return{index:t,name:n.name||`Clip ${t}`,duration:n.duration}}),this._clipsCache}dispose(){this.mixer&&=(this.mixer.stopAllAction(),this.mixer.uncacheRoot(this._mixerRoot),null),this.actions=[],this.isPlaying=!1,this.timer.reset(),this._scene=null,this._mixerRoot=null,this._meshes=null,this._meshTriRanges=null,this._posBuffer=null,this._skinnedCache=null,this._clipsCache=null}},Zo=class{constructor({camera:e,canvas:t,orbitControls:n,app:i}){this._app=i,this._orbitControls=n,this._camera=e,this._controls=new g.TransformControls(e,t),this._gizmoScene=new r.Scene,this._gizmoScene.add(this._controls.getHelper()),this._attached=null,this._isDragging=!1,this._meshes=null,this._meshTriRanges=null,this._posBuffer=null,this._normalBuffer=null,this._skinnedCache=null,this._normalCache=null,this._tempVec=new r.Vector3,this._normalMatrix=new r.Matrix3,this._refitInFlight=!1,this._baselineComputed=!1,this._onDraggingChanged=this._onDraggingChanged.bind(this),this._onObjectChange=this._onObjectChange.bind(this),this._controls.addEventListener(`dragging-changed`,this._onDraggingChanged),this._controls.addEventListener(`objectChange`,this._onObjectChange)}setMeshData(e,t){this._meshes=e,this._meshTriRanges=[],this._skinnedCache=[],this._normalCache=[];let n=0;for(let t of e){let e=t.geometry,r=e.attributes.position,i=e.index?e.index.array:null,a=i?i.length/3:r.count/3,o=r.count;this._meshTriRanges.push({start:n,count:a,uniqueVerts:o,indices:i}),this._skinnedCache.push(new Float32Array(o*3)),this._normalCache.push(new Float32Array(o*3)),n+=a}this._posBuffer=new Float32Array(t*9),this._normalBuffer=new Float32Array(t*9)}attach(e){this._attached!==e&&(this._controls.attach(e),this._attached=e)}detach(){this._attached&&=(this._controls.detach(),null)}setMode(e){this._controls.setMode(e),this._app?.dispatchEvent({type:z.TRANSFORM_MODE_CHANGED,mode:e})}setSpace(e){this._controls.setSpace(e)}get isDragging(){return this._isDragging}get attachedObject(){return this._attached}get controls(){return this._controls}render(e){if(!this._attached)return;let t=e.autoClear;e.autoClear=!1,e.clearDepth(),e.setRenderTarget(null),e.render(this._gizmoScene,this._camera),e.autoClear=t}_onDraggingChanged(e){this._isDragging=e.value,this._orbitControls&&(this._orbitControls.enabled=!e.value),e.value?this._app.dispatchEvent({type:z.OBJECT_TRANSFORM_START}):(this._recomputeAndRefit(),this._app.dispatchEvent({type:z.OBJECT_TRANSFORM_END}))}_onObjectChange(){this._app.needsReset=!0,this._app.wake()}_recomputeAndRefit(){if(!this._meshes||!this._posBuffer||this._refitInFlight||!this._attached)return;this._attached.updateMatrixWorld(!0);let e=this._findAffectedMeshIndices(this._attached);if(e.length!==0){if(!this._baselineComputed)this._computeAllPositions(),this._baselineComputed=!0;else for(let t of e)this._computeMeshPositions(t);this._refitInFlight=!0;try{this._app.refitBLASes(e,this._posBuffer,this._normalBuffer)}catch(e){console.error(`Transform refit error:`,e)}finally{this._refitInFlight=!1}}}_findAffectedMeshIndices(e){let t=[];for(let n=0;n<this._meshes.length;n++){let r=this._meshes[n];(r===e||this._isDescendantOf(r,e))&&t.push(n)}return t}_isDescendantOf(e,t){let n=e.parent;for(;n;){if(n===t)return!0;n=n.parent}return!1}_computeAllPositions(){for(let e=0;e<this._meshes.length;e++)this._computeMeshPositions(e)}_computeMeshPositions(e){let t=this._meshes[e],{start:n,count:r,uniqueVerts:i,indices:a}=this._meshTriRanges[e],o=this._skinnedCache[e],s=this._normalCache[e],c=this._tempVec,l=this._posBuffer,u=this._normalBuffer;t.updateMatrixWorld(!0);let d=t.matrixWorld;this._normalMatrix.getNormalMatrix(d);let f=this._normalMatrix.elements,p=t.geometry.attributes.normal;for(let e=0;e<i;e++)if(t.getVertexPosition(e,c),c.applyMatrix4(d),o[e*3]=c.x,o[e*3+1]=c.y,o[e*3+2]=c.z,p){let t=p.getX(e),n=p.getY(e),r=p.getZ(e);s[e*3]=f[0]*t+f[3]*n+f[6]*r,s[e*3+1]=f[1]*t+f[4]*n+f[7]*r,s[e*3+2]=f[2]*t+f[5]*n+f[8]*r}if(a)for(let e=0;e<r;e++){let t=e*3,r=a[t]*3,i=a[t+1]*3,c=a[t+2]*3,d=(n+e)*9;l[d]=o[r],l[d+1]=o[r+1],l[d+2]=o[r+2],l[d+3]=o[i],l[d+4]=o[i+1],l[d+5]=o[i+2],l[d+6]=o[c],l[d+7]=o[c+1],l[d+8]=o[c+2],u[d]=s[r],u[d+1]=s[r+1],u[d+2]=s[r+2],u[d+3]=s[i],u[d+4]=s[i+1],u[d+5]=s[i+2],u[d+6]=s[c],u[d+7]=s[c+1],u[d+8]=s[c+2]}else for(let e=0;e<r;e++){let t=e*3*3,r=(e*3+1)*3,i=(e*3+2)*3,a=(n+e)*9;l[a]=o[t],l[a+1]=o[t+1],l[a+2]=o[t+2],l[a+3]=o[r],l[a+4]=o[r+1],l[a+5]=o[r+2],l[a+6]=o[i],l[a+7]=o[i+1],l[a+8]=o[i+2],u[a]=s[t],u[a+1]=s[t+1],u[a+2]=s[t+2],u[a+3]=s[r],u[a+4]=s[r+1],u[a+5]=s[r+2],u[a+6]=s[i],u[a+7]=s[i+1],u[a+8]=s[i+2]}}dispose(){this._controls.removeEventListener(`dragging-changed`,this._onDraggingChanged),this._controls.removeEventListener(`objectChange`,this._onObjectChange),this.detach(),this._gizmoScene.remove(this._controls.getHelper()),this._controls.dispose(),this._meshes=null,this._meshTriRanges=null,this._posBuffer=null,this._normalBuffer=null,this._skinnedCache=null,this._normalCache=null,this._baselineComputed=!1,this._app=null,this._orbitControls=null,this._camera=null,this._controls=null,this._gizmoScene=null}},Qo=new WeakMap,$o=class extends r.EventDispatcher{constructor(e,t={}){super();try{Qo.get(e)?.dispose()}catch(e){console.warn(`PathTracerApp: prior canvas owner dispose failed`,e)}Qo.set(e,this),this.canvas=e,this._autoResize=t.autoResize!==!1,this._container=t.container||null,this.settings=new vo(V),this.renderer=null,this.scene=null,this.meshScene=null,this._sceneHelpers=null,this.assetLoader=null,this._sdf=null,this._animRefitInFlight=!1,this.pipeline=null,this.stages={},this.cameraManager=null,this.lightManager=null,this.denoisingManager=null,this.overlayManager=null,this.interactionManager=null,this.transformManager=null,this.animationManager=new Xo,this.environmentManager=null,this.isInitialized=!1,this.pauseRendering=!1,this.pathTracerEnabled=!0,this.animationManagerId=null,this.needsReset=!1,this._loadingInProgress=!1,this._needsDisplayRefresh=!1,this._paused=!1,this.completion=new fo,this._resizeDebounceTimer=null,this._trackedListeners=[],this._disposed=!1}_addTrackedListener(e,t,n){e&&(e.addEventListener(t,n),this._trackedListeners.push({target:e,type:t,handler:n}))}_removeTrackedListeners(){for(let{target:e,type:t,handler:n}of this._trackedListeners)try{e.removeEventListener(t,n)}catch(e){console.warn(`PathTracerApp: failed to remove listener`,t,e)}this._trackedListeners.length=0}async init(){return await this._initRenderer(),this._initCameraManager(),this._initScenes(),this._initAssetPipeline(),this._initPipeline(),this._initManagers(),this._wireEvents(),this.stages.pathTracer.setTriangleData(new Float32Array(32),0),this.stages.pathTracer.setBVHData(new Float32Array(16)),this.stages.pathTracer.materialData.setMaterialData(new Float32Array(16)),this.stages.pathTracer.setupMaterial(),this.isInitialized=!0,console.log(`WebGPU Path Tracer App initialized`),this}animate(){if(this.animationManagerId=requestAnimationFrame(()=>this.animate()),this._loadingInProgress||this._sdf?.isProcessing){this.dispatchEvent({type:z.FRAME});return}if(this.cameraManager.controls&&this.cameraManager.controls.update(),this.animationManager?.isPlaying&&!this._animRefitInFlight){let e=this.animationManager.update();e&&(this._animRefitInFlight=!0,this.refitBVH(e).catch(e=>console.error(`Animation refit error:`,e)).finally(()=>{this._animRefitInFlight=!1}))}if(this.needsReset&&=(this.reset(!0),!1),this.cameraManager.camera.updateMatrixWorld(),!this.pathTracerEnabled){this.renderer.render(this.meshScene,this.cameraManager.camera),this._renderHelperOverlay();return}if(!this.pauseRendering){if(this.cameraManager.updateAutoFocus(),this.stages.pathTracer?.isReady){if(this.stages.pathTracer.isComplete&&this.completion.renderCompleteDispatched){this._needsDisplayRefresh&&(this._needsDisplayRefresh=!1,this.stages.compositor.render(this.pipeline.context),this._renderHelperOverlay()),this.stopAnimation();return}this.pipeline.render(),this.stages.pathTracer.isComplete||this.completion.updateTime(),fe({timeElapsed:this.completion.timeElapsed,samples:pe(this.stages.pathTracer)}),this.completion.isTimeLimitReached(this.settings.get(`renderLimitMode`),this.settings.get(`renderTimeLimit`))&&(this.stages.pathTracer.isComplete=!0),this.stages.pathTracer.isComplete&&this.completion.markComplete()&&(this.denoisingManager.onRenderComplete({isStillComplete:()=>this.completion.renderCompleteDispatched,context:this.pipeline?.context}),this.dispatchEvent({type:`RenderComplete`}),this.dispatchEvent({type:z.RENDER_COMPLETE}))}this._renderHelperOverlay(),this.dispatchEvent({type:z.FRAME}),this.renderer.resolveTimestampsAsync?.(r.TimestampQuery.RENDER),this.renderer.resolveTimestampsAsync?.(r.TimestampQuery.COMPUTE)}}stopAnimation(){this.animationManagerId&&=(cancelAnimationFrame(this.animationManagerId),null)}wake(){!this.animationManagerId&&this.isInitialized&&!this._paused&&this.animate()}pause(){this._paused=!0,this.stopAnimation()}resume(){this._paused=!1,this.animationManagerId||this.animate()}reset(e=!1){if(this.pipeline&&(this.pipeline.reset(),e||this.pipeline.eventBus.emit(`asvgf:reset`)),this.denoisingManager?.abort(this.canvas),this.denoisingManager?.restoreBaseResolution()){let e=this.denoisingManager._lastRenderWidth,t=this.denoisingManager._lastRenderHeight;this.dispatchEvent({type:`resolution_changed`,width:e,height:t})}this.completion.reset(),this.wake(),this.dispatchEvent({type:`RenderReset`}),this.dispatchEvent({type:z.RENDER_RESET})}dispose(){if(!this._disposed){if(this._disposed=!0,this.dispatchEvent({type:z.DISPOSE}),this.stopAnimation(),clearTimeout(this._resizeDebounceTimer),this._resizeDebounceTimer=null,this._removeTrackedListeners(),ue(null),this.interactionManager?.deselect?.(),this.transformManager?.detach?.(),this.animationManager?.dispose(),this.transformManager?.dispose(),this.overlayManager?.dispose(),this.lightManager?.dispose(),this.denoisingManager?.dispose(),this.interactionManager?.dispose(),this.cameraManager?.dispose(),this.pipeline?.dispose(),this._sdf?.dispose(),this._sdf=null,this.assetLoader?.dispose(),this.assetLoader=null,this.meshScene){this.meshScene.environment?.dispose(),this.meshScene.environment=null;for(let e of[...this.meshScene.children])_e(e);this.meshScene.clear(),this.meshScene=null}this._sceneHelpers?.clear(),this._sceneHelpers=null,this.scene?.clear(),this.scene=null,this.renderer?._canvasTarget&&this.renderer._onCanvasTargetResize&&this.renderer._canvasTarget.removeEventListener(`resize`,this.renderer._onCanvasTargetResize);try{let e=(0,n.texture)().value,t=(0,n.cubeTexture)().value;e?._listeners?.dispose&&(e._listeners.dispose.length=0),t?._listeners?.dispose&&(t._listeners.dispose.length=0)}catch(e){console.warn(`PathTracerApp: failed to clear TSL texture singleton listeners`,e)}this.renderer?.dispose(),this.renderer&&(this.renderer._canvasTarget=null),this.renderer=null,this.stages={},this.isInitialized=!1}}unloadScene(){if(this.isInitialized){if(this._loadingInProgress)throw Error(`PathTracerApp.unloadScene: cannot unload while a load is in progress`);this._disposed||(this.animationManager?.dispose(),this._animRefitInFlight=!1,this.interactionManager?.deselect(),this.transformManager?.detach?.(),this.assetLoader?.releaseTargetModel(),this.lightManager?.clearLights?.(),this.stages.pathTracer&&(this.stages.pathTracer.setTriangleData(new Float32Array(32),0),this.stages.pathTracer.setBVHData(new Float32Array(16)),this.stages.pathTracer.materialData.setMaterialData(new Float32Array(16)),this.stages.pathTracer.setEmissiveTriangleData?.(new Float32Array,0,0),this.stages.pathTracer.setupMaterial()),this.reset(),this.dispatchEvent({type:`SceneUnloaded`}))}}async loadModel(e){await this._loadWithSceneRebuild(()=>this.assetLoader.loadModel(e),{type:`ModelLoaded`,url:e})}async loadObject3D(e,t=`object3d`){await this._loadWithSceneRebuild(()=>this.assetLoader.loadObject3D(e,t),{type:`Object3DLoaded`,name:t})}async loadEnvironment(e){if(this._loadingInProgress)throw Error(`PathTracerApp.loadEnvironment: another load is already in progress`);this._loadingInProgress=!0;try{await this.assetLoader.loadEnvironment(e);let t=this.meshScene.environment;t&&this.stages.pathTracer&&await this.stages.pathTracer.environment.setEnvironmentMap(t),this.pipeline?.eventBus.emit(`autoexposure:resetHistory`),this.reset(),this.dispatchEvent({type:`EnvironmentLoaded`,url:e})}finally{this._loadingInProgress=!1}}async loadExampleModels(e,t){await this._loadWithSceneRebuild(()=>this.assetLoader.loadExampleModels(e,t),{type:`ModelLoaded`,index:e})}async _loadWithSceneRebuild(e,t){if(this._loadingInProgress)throw Error(`PathTracerApp: another load is already in progress`);this._loadingInProgress=!0;try{await e(),this._syncControlsAfterLoad(),await this.loadSceneData(),this.pipeline?.eventBus.emit(`autoexposure:resetHistory`),this.reset(),this.cameraManager.currentCameraIndex=0,this.dispatchEvent(t),this.dispatchEvent({type:`CamerasUpdated`,cameras:this.cameraManager.cameras,cameraNames:this.cameraManager.getCameraNames()})}finally{this._loadingInProgress=!1}}async loadSceneData(){this.interactionManager?.deselect(),this.animationManager.dispose(),this._animRefitInFlight=!1;let e=new Ji(`loadSceneData`),t=this.meshScene.environment,n=null;if(t?.image?.data&&(e.start(`Environment CDF build (worker)`),this.stages.pathTracer.scene.environment=t,n=this.stages.pathTracer.environment.buildEnvironmentCDF().then(()=>e.end(`Environment CDF build (worker)`))),e.start(`BVH build (SceneProcessor)`),await this._sdf.buildBVH(this.meshScene),e.end(`BVH build (SceneProcessor)`),B({status:`Transferring data to GPU...`,progress:86}),await new Promise(e=>setTimeout(e,0)),e.start(`GPU data transfer`),!this._sdf.uploadToPathTracer(this.stages.pathTracer,this.lightManager,this.meshScene,t))return!1;this.stages.pathTracer._meshRefs=this.stages.pathTracer._collectMeshRefs(this.meshScene),this.stages.pathTracer.setMeshVisibilityData(this.stages.pathTracer._meshRefs),e.end(`GPU data transfer`),B({status:`Compiling shaders...`,progress:90}),await new Promise(e=>setTimeout(e,0)),e.start(`Material setup (TSL compile)`),this.stages.pathTracer.setupMaterial(),e.end(`Material setup (TSL compile)`),e.start(`Pipeline precompile`),this.stages.pathTracer.shaderBuilder.forceCompile(this.renderer);try{await this.renderer.compileAsync(this.meshScene,this.cameraManager.camera)}catch(e){console.warn(`PathTracerApp: raster fallback precompile failed`,e)}return e.end(`Pipeline precompile`),n&&(B({status:`Finalizing environment map...`,progress:95}),await n,this.stages.pathTracer.environment.applyCDFResults()),e.start(`Apply settings`),this.settings.applyAll(),this.stages.compositor.setTransparentBackground(this.settings.get(`transparentBackground`)),e.end(`Apply settings`),e.print(),de(),this._initAnimationAndTransforms(),this.dispatchEvent({type:`SceneRebuild`}),!0}async refitBVH(e,t){let n=await this._sdf.refitBVH(e,t);return this.stages.pathTracer.updateTriangleData(this._sdf.triangleData),this.stages.pathTracer.updateBVHData(this._sdf.bvhData),this.reset(),n}refitBLASes(e,t,n){let r=this._sdf.refitBLASes(e,t,n),{triRanges:i,bvhRanges:a}=this._sdf.computeBLASDirtyRanges(e);return this.stages.pathTracer.updateBufferRanges(i,a),this.reset(),this._sdf.scheduleBackgroundRebuild(e,()=>{this.stages.pathTracer.updateTriangleData(this._sdf.triangleData),this.stages.pathTracer.updateBVHData(this._sdf.bvhData),this.reset()}),r}onResize(){let e=this.canvas.clientWidth,t=this.canvas.clientHeight;if(e===0||t===0)return;this.renderer.setPixelRatio(1),this.renderer.setSize(e,t,!1),this.cameraManager.camera.aspect=e/t,this.cameraManager.camera.updateProjectionMatrix();let n=window.devicePixelRatio||1;this.overlayManager?.setSize(Math.round(e*n),Math.round(t*n));let r=this.denoisingManager?._lastRenderWidth??0,i=this.denoisingManager?._lastRenderHeight??0;e===r&&t===i||(clearTimeout(this._resizeDebounceTimer),this._resizeDebounceTimer=setTimeout(()=>{this._applyRenderResize(e,t)},300))}_applyRenderResize(e,t){this.pipeline?.setSize(e,t),this.denoisingManager?.setRenderSize(e,t),this.needsReset=!0,this.dispatchEvent({type:`resolution_changed`,width:e,height:t})}setCanvasSize(e,t){e===0||t===0||(this.renderer.setPixelRatio(1),this.renderer.setSize(e,t,!1),this.cameraManager.camera.aspect=e/t,this.cameraManager.camera.updateProjectionMatrix(),clearTimeout(this._resizeDebounceTimer),this._applyRenderResize(e,t))}configureForMode(e,t={}){let n=e===`production`,r=n?je:Me;this.cameraManager.controls.enabled=!n,this.settings.setMany({maxSamples:r.maxSamples,maxBounces:r.bounces,samplesPerPixel:r.samplesPerPixel,transmissiveBounces:r.transmissiveBounces},{silent:!0}),this.stages.pathTracer?.setUniform(`renderMode`,parseInt(r.renderMode)),this.stages.pathTracer?.setUniform(`enableAlphaShadows`,r.enableAlphaShadows??!1),this.stages.pathTracer?.tileManager?.setTileCount(r.tiles);let i=this.overlayManager?.getHelper(`tiles`);i&&(i.enabled=r.tilesHelper,r.tilesHelper||i.hide()),this.stages.pathTracer?.updateCompletionThreshold?.();let a=this.denoisingManager?.denoiser;a&&(a.abort(),a.enabled=r.enableOIDN,a.updateQuality(r.oidnQuality)),this.denoisingManager?.upscaler?.abort(),t.canvasWidth&&t.canvasHeight&&this.setCanvasSize(t.canvasWidth,t.canvasHeight),this.needsReset=!1,this.pauseRendering=!1,this.reset()}refreshFrame(){this._needsDisplayRefresh=!0,this.wake()}getCanvas(){if(!this.renderer?.domElement)return null;let e=this.denoisingManager;return(e?.denoiser?.enabled||e?.upscaler?.enabled)&&e?.denoiserCanvas&&this.stages.pathTracer?.isComplete?e.denoiserCanvas:(this.stages.compositor&&this.pipeline?.context&&this.stages.compositor.render(this.pipeline.context),this.renderer.domElement)}screenshot({type:e=`image/png`,quality:t}={}){let n=this.getCanvas();return n?new Promise(r=>n.toBlob(r,e,t)):Promise.resolve(null)}getStatistics(){try{return this._sdf?.getStatistics?.()??null}catch{return null}}get isLoading(){return this._loadingInProgress}isComplete(){return this.stages.pathTracer?.isComplete??!1}getFrameCount(){return this.stages.pathTracer?.frameCount||0}setMaterialProperty(e,t,n){if(this.stages.pathTracer?.materialData.updateMaterialProperty(e,t,n),[`emissive`,`emissiveIntensity`].includes(t)&&this.stages.pathTracer?.enableEmissiveTriangleSampling?.value){let r=this._sdf.updateMaterialEmissive(e,t,n);r&&this.stages.pathTracer.setEmissiveTriangleData(r.rawData,r.emissiveCount,r.totalPower)}this.reset()}setMeshVisibility(e,t){this.stages.pathTracer?.updateMeshVisibility(e,t),this.reset()}updateAllMeshVisibility(){this.stages.pathTracer?.updateAllMeshVisibility(),this.reset()}getScene(){return this.meshScene||this.scene}setMeshVisibilityByUuid(e,t){let n=this.getScene()?.getObjectByProperty(`uuid`,e);if(!n)return null;let r=typeof t==`function`?!!t(n.visible):!!t;return n.visible=r,this.updateAllMeshVisibility(),r}setTextureTransform(e,t,n){this.stages.pathTracer?.materialData.updateTextureTransform(e,t,n),this.reset()}async rebuildMaterials(e){await this.stages.pathTracer?.rebuildMaterials(e||this.meshScene),this.reset()}async _initRenderer(){if(ue(e=>this.dispatchEvent(e)),!navigator.gpu)throw Error(`WebGPU is not supported in this browser`);let e=await navigator.gpu.requestAdapter({powerPreference:`high-performance`});if(!e)throw Error(`Failed to get WebGPU adapter`);let n=e.limits;this.renderer=new t.WebGPURenderer({canvas:this.canvas,alpha:!0,powerPreference:`high-performance`,requiredLimits:{maxBufferSize:n.maxBufferSize,maxStorageBufferBindingSize:n.maxStorageBufferBindingSize,maxColorAttachmentBytesPerSample:128}}),await this.renderer.init(),t.RectAreaLightNode.setLTC(i.RectAreaLightTexturesLib.init()),this.renderer.workingColorSpace=t.SRGBColorSpace,this.renderer.outputColorSpace=t.SRGBColorSpace,this.renderer.toneMapping=r.ACESFilmicToneMapping,this.renderer.toneMappingExposure=1,this.renderer.setPixelRatio(1)}_initCameraManager(){this.cameraManager=new yo(this.canvas)}_initScenes(){this.scene=new r.Scene,this.meshScene=new r.Scene,this._sceneHelpers=new b}_initAssetPipeline(){this._sdf=new Na,this.assetLoader=new ho(this.meshScene,this.cameraManager.camera,this.cameraManager.controls),this.assetLoader.setRenderer(this.renderer),this.assetLoader.createFloorPlane(),this._addTrackedListener(this.cameraManager.controls,`change`,()=>{this.needsReset=!0,this.wake()})}_initPipeline(){this._createStages();let{clientWidth:e,clientHeight:t}=this.canvas;this.pipeline=new uo(this.renderer,e||1,t||1),this.pipeline.addStage(this.stages.pathTracer),this.pipeline.addStage(this.stages.normalDepth),this.pipeline.addStage(this.stages.motionVector),this.pipeline.addStage(this.stages.ssrc),this.pipeline.addStage(this.stages.asvgf),this.pipeline.addStage(this.stages.variance),this.pipeline.addStage(this.stages.bilateralFilter),this.pipeline.addStage(this.stages.adaptiveSampling),this.pipeline.addStage(this.stages.edgeFilter),this.pipeline.addStage(this.stages.autoExposure),this.pipeline.addStage(this.stages.compositor);let n=this.canvas.clientWidth||1,r=this.canvas.clientHeight||1;this.pipeline.setSize(n,r)}_initManagers(){this.interactionManager=new po({scene:this.meshScene,camera:this.cameraManager.camera,canvas:this.canvas,assetLoader:this.assetLoader,pathTracer:null,floorPlane:this.assetLoader.floorPlane}),this.interactionManager.wireAppEvents(this),this.cameraManager.setInteractionManager(this.interactionManager),this.lightManager=new bo(this.scene,this._sceneHelpers,this.stages.pathTracer,{onReset:()=>this.reset()}),this._setupDenoisingManager(),this._setupOverlayManager(),this.transformManager=new Zo({camera:this.cameraManager.camera,canvas:this.canvas,orbitControls:this.cameraManager.controls,app:this}),this.interactionManager.setDependencies({overlayManager:this.overlayManager,transformManager:this.transformManager,appDispatch:e=>this.dispatchEvent(e),orbitControls:this.cameraManager.controls}),this.denoisingManager.setOverlayManager(this.overlayManager),this.denoisingManager.setResetCallback(()=>this.reset()),this.denoisingManager.setSettings(this.settings),this.environmentManager=this.stages.pathTracer.environment,this.environmentManager.callbacks.onAutoExposureReset=()=>this.pipeline.eventBus.emit(`autoexposure:resetHistory`)}_wireEvents(){this._addTrackedListener(this.cameraManager,`CameraSwitched`,e=>this.dispatchEvent(e)),this._addTrackedListener(this.cameraManager,z.AUTO_FOCUS_UPDATED,e=>this.dispatchEvent(e)),this._forwardEvents(this.denoisingManager,[z.DENOISING_START,z.DENOISING_END,z.UPSCALING_START,z.UPSCALING_PROGRESS,z.UPSCALING_END,`resolution_changed`]),this._setupAutoExposureListener(),this.animationManager.wakeCallback=()=>this.wake(),this._forwardEvents(this.animationManager,[z.ANIMATION_STARTED,z.ANIMATION_PAUSED,z.ANIMATION_STOPPED]),this._addTrackedListener(this.animationManager,z.ANIMATION_PAUSED,()=>{this._animRefitInFlight=!1}),this._addTrackedListener(this.animationManager,z.ANIMATION_STOPPED,()=>{this._animRefitInFlight=!1}),this.cameraManager.initCallbacks({onResize:()=>this.onResize(),onReset:()=>this.reset(),getSettings:e=>this.settings.get(e)}),this.cameraManager.initAutoFocus({meshScene:this.meshScene,assetLoader:this.assetLoader,floorPlane:this.assetLoader.floorPlane,pathTracer:this.stages.pathTracer,settings:this.settings,softReset:()=>this.reset(!0),hardReset:()=>this.reset()}),this.settings.bind({stages:this.stages,renderer:this.renderer,resetCallback:()=>this.reset(),reconcileCompletion:()=>this._reconcileCompletion()}),this.renderer.toneMappingExposure=this.settings.get(`exposure`)??1,this.onResize(),this.resizeHandler=()=>this.onResize(),this._autoResize&&this._addTrackedListener(window,`resize`,this.resizeHandler),this._onAssetLoaded=async e=>{if(!this._loadingInProgress){if(e.model)await this.loadSceneData();else if(e.texture){let e=this.meshScene.environment;e&&this.stages.pathTracer&&await this.stages.pathTracer.environment.setEnvironmentMap(e),de()}this.pauseRendering=!1,this.reset()}},this._addTrackedListener(this.assetLoader,`load`,this._onAssetLoaded),this._addTrackedListener(this.assetLoader,`modelProcessed`,e=>{let t=[this.cameraManager.camera,...e.cameras||[]];this.cameraManager.setCameras(t),this.interactionManager&&(this.interactionManager.floorPlane=this.assetLoader.floorPlane)})}_initAnimationAndTransforms(){let e=this.assetLoader?.animations||[];if(e.length>0){let t=this.assetLoader?.targetModel||this.meshScene;this.animationManager.init(this.meshScene,t,this._sdf.meshes,e,this._sdf.triangleCount),this.animationManager.onFinished=()=>{this._animRefitInFlight=!1,this.dispatchEvent({type:z.ANIMATION_FINISHED})}}this.transformManager?.setMeshData(this._sdf.meshes,this._sdf.triangleCount)}_createStages(){let e=this.settings.get(`adaptiveSamplingMax`),t=this.settings.get(`useAdaptiveSampling`);this.stages.pathTracer=new za(this.renderer,this.scene,this.cameraManager.camera),this.stages.normalDepth=new Ba(this.renderer,{pathTracer:this.stages.pathTracer}),this.stages.motionVector=new Va(this.renderer,this.cameraManager.camera,{pathTracer:this.stages.pathTracer}),this.stages.ssrc=new oo(this.renderer,{enabled:!1}),this.stages.asvgf=new Ha(this.renderer,{enabled:!1}),this.stages.variance=new Wa(this.renderer,{enabled:!1}),this.stages.bilateralFilter=new Ka(this.renderer,{enabled:!1}),this.stages.adaptiveSampling=new Ya(this.renderer,{adaptiveSamplingMax:e,enabled:t}),this.stages.edgeFilter=new Xa(this.renderer,{enabled:!1}),this.stages.autoExposure=new ro(this.renderer,{enabled:V.autoExposure??!1}),this.stages.compositor=new so(this.renderer,{saturation:this.settings.get(`saturation`)??V.saturation})}_setupDenoisingManager(){this.denoisingManager=new Ko({renderer:this.renderer,mainCanvas:this.canvas,scene:this.scene,camera:this.cameraManager.camera,stages:{pathTracer:this.stages.pathTracer,asvgf:this.stages.asvgf,variance:this.stages.variance,bilateralFilter:this.stages.bilateralFilter,adaptiveSampling:this.stages.adaptiveSampling,edgeFilter:this.stages.edgeFilter,ssrc:this.stages.ssrc,autoExposure:this.stages.autoExposure,compositor:this.stages.compositor},pipeline:this.pipeline,getExposure:()=>this.settings.get(`exposure`)??1,getSaturation:()=>this.settings.get(`saturation`)??1,getTransparentBg:()=>this.settings.get(`transparentBackground`)??!1}),this.denoisingManager.setupDenoiser(),this.denoisingManager.setupUpscaler();let e=this.canvas.clientWidth||1,t=this.canvas.clientHeight||1;this.denoisingManager.setRenderSize(e,t)}_reconcileCompletion(){let e=this.stages.pathTracer;if(!e)return;let t=this.completion.isLimitReached(e,this.settings.get(`renderLimitMode`),this.settings.get(`renderTimeLimit`));t&&!e.isComplete?e.isComplete=!0:!t&&e.isComplete&&(e.isComplete=!1,this.completion.resumeFromPause(),this.denoisingManager?.abort(this.canvas),this.dispatchEvent({type:z.RENDER_RESET}),this.wake())}_setupAutoExposureListener(){this.stages.autoExposure&&this.stages.autoExposure.on(`autoexposure:updated`,e=>{this.dispatchEvent({type:z.AUTO_EXPOSURE_UPDATED,exposure:e.exposure,luminance:e.luminance})})}_renderHelperOverlay(){this.scene.updateMatrixWorld(),this.overlayManager?.render(),this.transformManager?.render(this.renderer)}_setupOverlayManager(){this.overlayManager=new Yo(this.renderer,this.cameraManager.camera),this.overlayManager.setupDefaultHelpers({helperScene:this._sceneHelpers,meshScene:this.meshScene,pipeline:this.pipeline,denoisingManager:this.denoisingManager,app:this,renderWidth:this.denoisingManager?._lastRenderWidth||this.canvas.clientWidth||1,renderHeight:this.denoisingManager?._lastRenderHeight||this.canvas.clientHeight||1}),this._container=this._container||this.canvas.parentNode||null,this.overlayManager.mount(this._container)}_syncControlsAfterLoad(){this.cameraManager.controls.saveState(),this.cameraManager.controls.update()}_forwardEvents(e,t){if(e)for(let n of t)this._addTrackedListener(e,n,e=>this.dispatchEvent(e))}},es=class{constructor(e){this._app=e,this._cancelled=!1,this._rendering=!1}async renderAnimation(e={}){let{clipIndex:t=0,fps:n=30,speed:r=1,samplesPerFrame:i=je.maxSamples,enableOIDN:a=!0,onFrame:o,onProgress:s,onComplete:c}=e,l=this._app;if(!l.animationManager?.hasAnimations){console.warn(`VideoRenderManager: No animation clips available`),c?.(!1);return}let u=l.animationManager.clips[t];if(!u){console.warn(`VideoRenderManager: Invalid clip index ${t}`),c?.(!1);return}let d=u.duration/(r||1),f=e.totalFrames||Math.ceil(d*n),p=1/n;this._cancelled=!1,this._rendering=!0;let m=this._saveState();l.stopAnimation(),l.configureForMode(`production`),l.settings.setMany({maxSamples:i},{silent:!0}),l.stages.pathTracer?.updateCompletionThreshold?.(),l.cameraManager.controls&&(l.cameraManager.controls.enabled=!1);try{for(let e=0;e<f&&!this._cancelled;e++){let n=e*p*r,i=l.animationManager.seekTo(n,t);if(i?await l.refitBVH(i):l.reset(),l.stopAnimation(),await this._accumulateFrame(l),this._cancelled||(a&&l.denoisingManager?.denoiser?.enabled&&await this._waitForDenoise(l),this._cancelled))break;let c=l.getCanvas();if(c&&o){let t=await createImageBitmap(c);await o(t,e,f),t.close()}let u={frame:e+1,totalFrames:f,percent:(e+1)/f*100};s?.(u),l.dispatchEvent({type:z.VIDEO_RENDER_PROGRESS,...u})}}catch(e){console.error(`VideoRenderManager: Render error:`,e),this._cancelled=!0}finally{this._restoreState(m),this._rendering=!1;let e=!this._cancelled;c?.(e),l.dispatchEvent({type:z.VIDEO_RENDER_COMPLETE,success:e})}}cancel(){this._cancelled=!0}get isRendering(){return this._rendering}async _accumulateFrame(e){let t=e.stages.pathTracer;if(t?.isReady)for(;!t.isComplete&&!this._cancelled;)e.cameraManager.camera.updateMatrixWorld(),e.pipeline.render(),t.frameCount%4==0&&(fe({samples:pe(t)}),await new Promise(e=>setTimeout(e,0)))}_waitForDenoise(e){return new Promise(t=>{let n,r=()=>{e.removeEventListener(z.DENOISING_END,i),clearTimeout(n)},i=()=>{r(),t()};n=setTimeout(()=>{console.warn(`VideoRenderManager: Denoise timed out, skipping`),r(),t()},3e4),e.addEventListener(z.DENOISING_END,i),e.denoisingManager.onRenderComplete({isStillComplete:()=>!this._cancelled,context:e.pipeline?.context})})}_saveState(){let e=this._app;return{maxSamples:e.settings.get(`maxSamples`),maxBounces:e.settings.get(`maxBounces`),samplesPerPixel:e.settings.get(`samplesPerPixel`),transmissiveBounces:e.settings.get(`transmissiveBounces`),renderMode:e.stages.pathTracer?.renderMode?.value,controlsEnabled:e.cameraManager.controls?.enabled,oidnEnabled:e.denoisingManager?.denoiser?.enabled,oidnQuality:e.denoisingManager?.denoiser?.quality,wasPlaying:e.animationManager?.isPlaying,pauseRendering:e.pauseRendering}}_restoreState(e){let t=this._app;t.settings.setMany({maxSamples:e.maxSamples,maxBounces:e.maxBounces,samplesPerPixel:e.samplesPerPixel,transmissiveBounces:e.transmissiveBounces},{silent:!0}),t.stages.pathTracer&&e.renderMode!==void 0&&t.stages.pathTracer?.setUniform(`renderMode`,parseInt(e.renderMode)),t.stages.pathTracer?.updateCompletionThreshold?.(),t.cameraManager.controls&&(t.cameraManager.controls.enabled=e.controlsEnabled??!0),t.denoisingManager?.denoiser&&(t.denoisingManager.denoiser.enabled=e.oidnEnabled??!1,e.oidnQuality&&t.denoisingManager.denoiser.updateQuality(e.oidnQuality)),t.pauseRendering=e.pauseRendering??!1,t.animationManager?.stop(),t.reset(),t.wake()}};e.AF_DEFAULTS=Oe,e.ASVGF_QUALITY_PRESETS=Ce,e.AUTO_FOCUS_MODES=De,e.AnimationManager=Xo,e.BVH_LEAF_MARKERS=ke,e.CAMERA_PRESETS=Ee,e.CAMERA_RANGES=we,e.CameraManager=yo,e.DEFAULT_TEXTURE_MATRIX=W,e.DenoisingManager=Ko,e.ENGINE_DEFAULTS=V,e.EngineEvents=z,e.INTERACTIVE_RENDER_CONFIG=Me,e.InteractionManager=po,e.LightManager=bo,e.MEMORY_CONSTANTS=Ne,e.OverlayManager=Yo,e.PRODUCTION_RENDER_CONFIG=je,e.PathTracerApp=$o,e.PipelineContext=co,e.RenderPipeline=uo,e.RenderSettings=vo,e.RenderStage=R,e.SKY_PRESETS=Te,e.StageExecutionMode=L,e.TEXTURE_CONSTANTS=Ae,e.TRIANGLE_DATA_LAYOUT=H,e.TransformManager=Zo,e.VideoRenderManager=es,e.configureAssets=Ia,e.getAssetConfig=La});
691
667
  //# sourceMappingURL=rayzee.umd.js.map