rayzee 6.3.0 → 6.4.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.
@@ -59,7 +59,7 @@
59
59
  return s;
60
60
 
61
61
  }
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)))},F=(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))},I=(e,t,n,r)=>{let i=F(e,t,n,r);return E.load(i).xy},ee=(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)))},F=(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))},ee=(e,t,n,r)=>{let i=F(e,t,n,r);return E.load(i).xy},te=(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
- `),te=(0,n.wgslFn)(`
91
+ `),ne=(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
- `),L=(0,n.wgslFn)(`
106
+ `),I=(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
- `,[k,te]),ne=(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(ee({index:t,base:(0,n.int)(2),scramble:i})),(0,n.If)(a.greaterThan((0,n.int)(1)),()=>{u.y.assign(ee({index:t,base:(0,n.int)(3),scramble:i}))}),(0,n.If)(a.greaterThan((0,n.int)(2)),()=>{u.z.assign(ee({index:t,base:(0,n.int)(5),scramble:i}))}),(0,n.If)(a.greaterThan((0,n.int)(3)),()=>{u.w.assign(ee({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(L({index:(0,n.uint)(t),dimension:(0,n.uint)(0),seed:i})),(0,n.If)(a.greaterThan((0,n.int)(1)),()=>{u.y.assign(L({index:(0,n.uint)(t),dimension:(0,n.uint)(1),seed:i}))}),(0,n.If)(a.greaterThan((0,n.int)(2)),()=>{u.z.assign(L({index:(0,n.uint)(t),dimension:(0,n.uint)(2),seed:i}))}),(0,n.If)(a.greaterThan((0,n.int)(3)),()=>{u.w.assign(L({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=I(e,t,i,c);u.x.assign(n.x),u.y.assign(n.y)}).Else(()=>{let r=I(e,t,i,c),a=I(e,t,i.add((0,n.int)(1)),c);u.assign((0,n.vec4)(r,a))})}),u},re=(e,t,r,i,a,o,s)=>ne(e,t,r,i,(0,n.int)(2),a,o,s).xy,ie=(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(re(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(I(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=I(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},ae=(0,n.wgslFn)(`
128
+ `,[k,ne]),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(te({index:t,base:(0,n.int)(2),scramble:i})),(0,n.If)(a.greaterThan((0,n.int)(1)),()=>{u.y.assign(te({index:t,base:(0,n.int)(3),scramble:i}))}),(0,n.If)(a.greaterThan((0,n.int)(2)),()=>{u.z.assign(te({index:t,base:(0,n.int)(5),scramble:i}))}),(0,n.If)(a.greaterThan((0,n.int)(3)),()=>{u.w.assign(te({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(I({index:(0,n.uint)(t),dimension:(0,n.uint)(0),seed:i})),(0,n.If)(a.greaterThan((0,n.int)(1)),()=>{u.y.assign(I({index:(0,n.uint)(t),dimension:(0,n.uint)(1),seed:i}))}),(0,n.If)(a.greaterThan((0,n.int)(2)),()=>{u.z.assign(I({index:(0,n.uint)(t),dimension:(0,n.uint)(2),seed:i}))}),(0,n.If)(a.greaterThan((0,n.int)(3)),()=>{u.w.assign(I({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=ee(e,t,i,c);u.x.assign(n.x),u.y.assign(n.y)}).Else(()=>{let r=ee(e,t,i,c),a=ee(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(ee(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=ee(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
- `,[j,A]),R={ALWAYS:`always`,PER_CYCLE:`per_cycle`,PER_TILE:`per_tile`,CONDITIONAL:`conditional`},z=class{constructor(e,t={}){this.name=e,this.enabled=t.enabled!==!1,this.executionMode=t.executionMode||R.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 R.ALWAYS:return!0;case R.PER_CYCLE:return t===0?!0:n===!0;case R.PER_TILE:return!0;case R.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)}},oe=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}},se=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}},B={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`},ce=null;function le(e){ce=e}var ue=()=>ce?.({type:B.LOADING_RESET}),V=e=>{ce?.({type:B.LOADING_UPDATE,...e})},de=e=>{ce?.({type:B.STATS_UPDATE,...e})};function fe(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 pe(e){if(Array.isArray(e))e.forEach(e=>{e.userData&&e.userData.isFallback||(me(e),e.dispose())});else{if(e.userData&&e.userData.isFallback)return;me(e),e.dispose()}}function me(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 he({material:e,geometry:t,children:n}){if(e&&pe(e),t&&t.dispose(),n.length>0)for(let e of n)he(e)}function ge(e,t=[]){if(e&&!(t.includes(e.name)||e.isScene)){if(e.isMaterial){pe(e);return}for(;e.children.length>0;)for(let t of e.children)ge(t);he(e),e.removeFromParent(),e.clear()}}function _e(e,t,n){return e===1?n*t:t}function ve(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 ye(){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 be(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 xe=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=be(e,n),this.writeNormalDepth=be(e,n),this.writeAlbedo=be(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}},H={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,groundProjectionEnabled:!1,groundProjectionRadius:100,groundProjectionHeight:15,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},Se=.01,Ce={low:{temporalAlpha:.1,gradientStrength:0,atrousIterations:3,phiColor:1,phiNormal:64,phiDepth:.1,phiLuminance:6,maxAccumFrames:16,varianceBoost:.5},medium:{temporalAlpha:.03,gradientStrength:0,atrousIterations:4,phiColor:.5,phiNormal:128,phiDepth:.05,phiLuminance:4,maxAccumFrames:64,varianceBoost:1},high:{temporalAlpha:0,gradientStrength:0,atrousIterations:6,phiColor:.3,phiNormal:256,phiDepth:.02,phiLuminance:2,maxAccumFrames:128,varianceBoost:1.5}},we={fov:{min:10,max:90,default:H.fov},focusDistance:{min:.3,max:100,default:H.focusDistance},aperture:{options:[1.4,2,2.8,4,5.6,8,11,16],default:H.aperture},focalLength:{min:0,max:200,default:H.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},U={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},W={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},je=[0,0,1,1,0,0,0,1],Me={maxSamples:30,bounces:20,transmissiveBounces:8,samplesPerPixel:1,renderMode:1,enableAlphaShadows:!0,tiles:3,tilesHelper:!0,enableOIDN:!0,oidnQuality:`balance`,interactionModeEnabled:!1},Ne={maxSamples:H.maxSamples,bounces:H.bounces,samplesPerPixel:H.samplesPerPixel,renderMode:H.renderMode,enableAlphaShadows:H.enableAlphaShadows,transmissiveBounces:H.transmissiveBounces,tiles:H.tiles,tilesHelper:H.tilesHelper,enableOIDN:!1,oidnQuality:`fast`,interactionModeEnabled:!0},Pe={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},Fe={cameraViewMatrix:`ptCameraViewMatrix`,cameraProjectionMatrix:`ptCameraProjectionMatrix`},Ie=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`,H.bounces,`int`),i(`samplesPerPixel`,H.samplesPerPixel,`int`),i(`maxSamples`,H.maxSamples,`int`),i(`transmissiveBounces`,H.transmissiveBounces,`int`),i(`visMode`,H.debugMode,`int`),i(`debugVisScale`,H.debugVisScale,`float`),a(`enableAccumulation`,!0),i(`accumulationAlpha`,0,`float`),a(`cameraIsMoving`,!1),a(`hasPreviousAccumulated`,!1),i(`environmentIntensity`,H.environmentIntensity,`float`),i(`backgroundIntensity`,H.backgroundIntensity,`float`),a(`showBackground`,H.showBackground),a(`transparentBackground`,H.transparentBackground),a(`enableEnvironment`,H.enableEnvironment),i(`environmentMatrix`,new r.Matrix4,`mat4`),a(`useEnvMapIS`,H.useImportanceSampledEnvironment),i(`envTotalSum`,0,`float`),i(`envCompensationDelta`,0,`float`),i(`envResolution`,new r.Vector2(1,1),`vec2`),a(`groundProjectionEnabled`,H.groundProjectionEnabled),i(`groundProjectionRadius`,H.groundProjectionRadius,`float`),i(`groundProjectionHeight`,H.groundProjectionHeight,`float`),i(`sunDirection`,new r.Vector3(0,1,0),`vec3`),i(`sunAngularSize`,.0087,`float`),a(`hasSun`,!1),i(`globalIlluminationIntensity`,H.globalIlluminationIntensity,`float`),i(`exposure`,H.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(192),`float`),area:(0,n.uniformArray)(new Float32Array(208),`float`),point:(0,n.uniformArray)(new Float32Array(144),`float`),spot:(0,n.uniformArray)(new Float32Array(320),`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`,H.enableDOF),i(`focusDistance`,H.focusDistance,`float`),i(`focalLength`,H.focalLength,`float`),i(`aperture`,H.aperture,`float`),i(`apertureScale`,1,`float`),i(`anamorphicRatio`,H.anamorphicRatio??1,`float`),i(`sceneScale`,1,`float`),this._uniforms.set(`samplingTechnique`,x),x.value=H.samplingTechnique,a(`useAdaptiveSampling`,H.adaptiveSampling),i(`adaptiveSamplingMin`,H.adaptiveSamplingMin??1,`int`),i(`adaptiveSamplingMax`,H.adaptiveSamplingMax,`int`),i(`fireflyThreshold`,H.fireflyThreshold,`float`),a(`enableEmissiveTriangleSampling`,H.enableEmissiveTriangleSampling),i(`emissiveBoost`,H.emissiveBoost,`float`),i(`emissiveTriangleCount`,0,`int`),i(`emissiveTotalPower`,0,`float`),i(`lightBVHNodeCount`,0,`int`),i(`emissiveVec4Offset`,0,`int`),i(`renderMode`,H.renderMode,`int`),a(`enableAlphaShadows`,H.enableAlphaShadows),i(`resolution`,new r.Vector2(e,t),`vec2`)}_nameAll(){for(let[e,t]of this._uniforms)t.name=Fe[e]||e}dispose(){this._disposed||(this._disposed=!0,this._uniforms.clear(),this._booleans.clear(),this._lightBuffers={})}},Le=W.SLOTS_PER_MATERIAL,Re=U.UV_C_MAT_OFFSET+2,ze=U.NORMAL_C_OFFSET+3,Be=U.NORMAL_A_OFFSET+3,Ve=new Set([`transmission`,`transparent`,`opacity`,`alphaMode`]),He=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/Le),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*W.FLOATS_PER_MATERIAL;switch(t){case`color`:n.r===void 0?Array.isArray(n)&&(r[i+W.COLOR]=n[0],r[i+W.COLOR+1]=n[1],r[i+W.COLOR+2]=n[2]):(r[i+W.COLOR]=n.r,r[i+W.COLOR+1]=n.g,r[i+W.COLOR+2]=n.b);break;case`metalness`:r[i+W.METALNESS]=n;break;case`emissive`:n.r===void 0?Array.isArray(n)&&(r[i+W.EMISSIVE]=n[0],r[i+W.EMISSIVE+1]=n[1],r[i+W.EMISSIVE+2]=n[2]):(r[i+W.EMISSIVE]=n.r,r[i+W.EMISSIVE+1]=n.g,r[i+W.EMISSIVE+2]=n.b);break;case`roughness`:r[i+W.ROUGHNESS]=n;break;case`ior`:r[i+W.IOR]=n;break;case`transmission`:r[i+W.TRANSMISSION]=n;break;case`thickness`:r[i+W.THICKNESS]=n;break;case`emissiveIntensity`:r[i+W.EMISSIVE_INTENSITY]=n;break;case`attenuationColor`:n.r===void 0?Array.isArray(n)&&(r[i+W.ATTENUATION_COLOR]=n[0],r[i+W.ATTENUATION_COLOR+1]=n[1],r[i+W.ATTENUATION_COLOR+2]=n[2]):(r[i+W.ATTENUATION_COLOR]=n.r,r[i+W.ATTENUATION_COLOR+1]=n.g,r[i+W.ATTENUATION_COLOR+2]=n.b);break;case`attenuationDistance`:r[i+W.ATTENUATION_DISTANCE]=n;break;case`dispersion`:r[i+W.DISPERSION]=n;break;case`sheen`:r[i+W.SHEEN]=n;break;case`sheenRoughness`:r[i+W.SHEEN_ROUGHNESS]=n;break;case`sheenColor`:n.r===void 0?Array.isArray(n)&&(r[i+W.SHEEN_COLOR]=n[0],r[i+W.SHEEN_COLOR+1]=n[1],r[i+W.SHEEN_COLOR+2]=n[2]):(r[i+W.SHEEN_COLOR]=n.r,r[i+W.SHEEN_COLOR+1]=n.g,r[i+W.SHEEN_COLOR+2]=n.b);break;case`specularIntensity`:r[i+W.SPECULAR_INTENSITY]=n;break;case`specularColor`:n.r===void 0?Array.isArray(n)&&(r[i+W.SPECULAR_COLOR]=n[0],r[i+W.SPECULAR_COLOR+1]=n[1],r[i+W.SPECULAR_COLOR+2]=n[2]):(r[i+W.SPECULAR_COLOR]=n.r,r[i+W.SPECULAR_COLOR+1]=n.g,r[i+W.SPECULAR_COLOR+2]=n.b);break;case`iridescence`:r[i+W.IRIDESCENCE]=n;break;case`iridescenceIOR`:r[i+W.IRIDESCENCE_IOR]=n;break;case`iridescenceThicknessRange`:Array.isArray(n)&&(r[i+W.IRIDESCENCE_THICKNESS_RANGE]=n[0],r[i+W.IRIDESCENCE_THICKNESS_RANGE+1]=n[1]);break;case`clearcoat`:r[i+W.CLEARCOAT]=n;break;case`clearcoatRoughness`:r[i+W.CLEARCOAT_ROUGHNESS]=n;break;case`opacity`:r[i+W.OPACITY]=n;break;case`side`:r[i+W.SIDE]=n,this._patchTriangleSideForMaterial(e,n);break;case`transparent`:r[i+W.TRANSPARENT]=n;break;case`alphaTest`:r[i+W.ALPHA_TEST]=n;break;case`alphaMode`:r[i+W.ALPHA_MODE]=n;break;case`depthWrite`:r[i+W.DEPTH_WRITE]=n;break;case`normalScale`:n.x===void 0?typeof n==`number`&&(r[i+W.NORMAL_SCALE]=n,r[i+W.NORMAL_SCALE+1]=n):(r[i+W.NORMAL_SCALE]=n.x,r[i+W.NORMAL_SCALE+1]=n.y);break;case`bumpScale`:r[i+W.BUMP_SCALE]=n;break;case`displacementScale`:r[i+W.DISPLACEMENT_SCALE]=n;break;default:console.warn(`Unknown material property: ${t}`);return}this.materialStorageAttr.needsUpdate=!0,Ve.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*W.FLOATS_PER_MATERIAL;t.color&&(n[r+W.COLOR]=t.color.r??t.color[0]??1,n[r+W.COLOR+1]=t.color.g??t.color[1]??1,n[r+W.COLOR+2]=t.color.b??t.color[2]??1),n[r+W.METALNESS]=t.metalness??0,t.emissive&&(n[r+W.EMISSIVE]=t.emissive.r??t.emissive[0]??0,n[r+W.EMISSIVE+1]=t.emissive.g??t.emissive[1]??0,n[r+W.EMISSIVE+2]=t.emissive.b??t.emissive[2]??0),n[r+W.ROUGHNESS]=t.roughness??1,n[r+W.IOR]=t.ior??1.5,n[r+W.TRANSMISSION]=t.transmission??0,n[r+W.THICKNESS]=t.thickness??.1,n[r+W.EMISSIVE_INTENSITY]=t.emissiveIntensity??1,t.attenuationColor&&(n[r+W.ATTENUATION_COLOR]=t.attenuationColor.r??t.attenuationColor[0]??1,n[r+W.ATTENUATION_COLOR+1]=t.attenuationColor.g??t.attenuationColor[1]??1,n[r+W.ATTENUATION_COLOR+2]=t.attenuationColor.b??t.attenuationColor[2]??1),n[r+W.ATTENUATION_DISTANCE]=t.attenuationDistance??1/0,n[r+W.DISPERSION]=t.dispersion??0,n[r+W.VISIBLE]=1,n[r+W.SHEEN]=t.sheen??0,n[r+W.SHEEN_ROUGHNESS]=t.sheenRoughness??1,t.sheenColor&&(n[r+W.SHEEN_COLOR]=t.sheenColor.r??t.sheenColor[0]??0,n[r+W.SHEEN_COLOR+1]=t.sheenColor.g??t.sheenColor[1]??0,n[r+W.SHEEN_COLOR+2]=t.sheenColor.b??t.sheenColor[2]??0),n[r+W.SPECULAR_INTENSITY]=t.specularIntensity??1,t.specularColor&&(n[r+W.SPECULAR_COLOR]=t.specularColor.r??t.specularColor[0]??1,n[r+W.SPECULAR_COLOR+1]=t.specularColor.g??t.specularColor[1]??1,n[r+W.SPECULAR_COLOR+2]=t.specularColor.b??t.specularColor[2]??1),n[r+W.IRIDESCENCE]=t.iridescence??0,n[r+W.IRIDESCENCE_IOR]=t.iridescenceIOR??1.3,t.iridescenceThicknessRange&&(n[r+W.IRIDESCENCE_THICKNESS_RANGE]=t.iridescenceThicknessRange[0]??100,n[r+W.IRIDESCENCE_THICKNESS_RANGE+1]=t.iridescenceThicknessRange[1]??400),n[r+W.ALBEDO_MAP_INDEX]=t.map??-1,n[r+W.NORMAL_MAP_INDEX]=t.normalMap??-1,n[r+W.ROUGHNESS_MAP_INDEX]=t.roughnessMap??-1,n[r+W.METALNESS_MAP_INDEX]=t.metalnessMap??-1,n[r+W.EMISSIVE_MAP_INDEX]=t.emissiveMap??-1,n[r+W.BUMP_MAP_INDEX]=t.bumpMap??-1,n[r+W.CLEARCOAT]=t.clearcoat??0,n[r+W.CLEARCOAT_ROUGHNESS]=t.clearcoatRoughness??0,n[r+W.OPACITY]=t.opacity??1,n[r+W.SIDE]=t.side??0,this._patchTriangleSideForMaterial(e,t.side??0),this._recomputeOpaqueBlockerForMaterial(e),n[r+W.TRANSPARENT]=t.transparent??0,n[r+W.ALPHA_TEST]=t.alphaTest??0,n[r+W.ALPHA_MODE]=t.alphaMode??0,n[r+W.DEPTH_WRITE]=t.depthWrite??1,n[r+W.NORMAL_SCALE]=t.normalScale?.x??(typeof t.normalScale==`number`?t.normalScale:1),n[r+W.NORMAL_SCALE+1]=t.normalScale?.y??(typeof t.normalScale==`number`?t.normalScale:1),n[r+W.BUMP_SCALE]=t.bumpScale??1,n[r+W.DISPLACEMENT_SCALE]=t.displacementScale??1,n[r+W.DISPLACEMENT_MAP_INDEX]=t.displacementMap??-1;let i=[1,0,0,0,1,0,0,0,1],a=[{key:`mapMatrix`,offset:W.ALBEDO_TRANSFORM},{key:`normalMapMatrices`,offset:W.NORMAL_TRANSFORM},{key:`roughnessMapMatrices`,offset:W.ROUGHNESS_TRANSFORM},{key:`metalnessMapMatrices`,offset:W.METALNESS_TRANSFORM},{key:`emissiveMapMatrices`,offset:W.EMISSIVE_TRANSFORM},{key:`bumpMapMatrices`,offset:W.BUMP_TRANSFORM},{key:`displacementMapMatrices`,offset:W.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*W.FLOATS_PER_MATERIAL,a={map:W.ALBEDO_TRANSFORM,normalMap:W.NORMAL_TRANSFORM,roughnessMap:W.ROUGHNESS_TRANSFORM,metalnessMap:W.METALNESS_TRANSFORM,emissiveMap:W.EMISSIVE_TRANSFORM,bumpMap:W.BUMP_TRANSFORM,displacementMap:W.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*W.FLOATS_PER_MATERIAL,i=e[t+W.TRANSMISSION],a=e[t+W.DISPERSION],o=e[t+W.SHEEN],s=e[t+W.IRIDESCENCE],c=e[t+W.CLEARCOAT],l=e[t+W.OPACITY],u=e[t+W.TRANSPARENT],d=e[t+W.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*W.FLOATS_PER_MATERIAL,r=t[n+W.ALPHA_MODE]|0,i=t[n+W.TRANSPARENT]|0,a=t[n+W.TRANSMISSION]||0,o=t[n+W.OPACITY]??1,s=+(r===0&&i===0&&a===0&&o>=1);this._patchTriangleFlagForMaterial(e,Be,s)}_patchTriangleFlagForMaterial(e,t,n){let r=this.callbacks.getTriangleData?.(),i=r?.array,a=r?.count|0;if(!i||a===0)return;let o=U.FLOATS_PER_TRIANGLE,s=0;for(let r=0;r<a;r++){let a=r*o;i[a+Re]===e&&(i[a+t]=n,s++)}s>0&&this.callbacks.onTriangleDataChanged&&this.callbacks.onTriangleDataChanged()}_patchTriangleSideForMaterial(e,t){this._patchTriangleFlagForMaterial(e,ze,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 Ue(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 We=``+(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 Ge(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 Ke(e,t,n){return .2126*e+.7152*t+.0722*n}function qe(e){return e<=.04045?e/12.92:((e+.055)/1.055)**2.4}function G(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]=qe(o[e]),o[e+1]=qe(o[e+1]),o[e+2]=qe(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 K=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}=G(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}=G(e);try{this._worker=new Worker(We,{type:`module`})}catch(e){if(e.name!==`SecurityError`)throw e;this._worker=await Ue(We)}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=Ke(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]=Ke(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]=(Ge(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]=(Ge(d,(n+1)/t,e*t,t)+.5)/t}return{marginalData:m,conditionalData:h,totalSum:l,compensationDelta:u}}},Je=Math.PI,Ye=Math.PI*2,Xe=Math.E,q=[5804542996261093e-21,13562911419845635e-21,30265902468824876e-21],Ze=[183999185144339.78,277980239196605.28,407904795438610.94],Qe=1.6110731556870734,$e=1.5,et=1e3,tt=8400,nt=1250,rt=.9999566769464484,it=.05968310365946075,at=.07957747154594767;function ot(e){return et*Math.max(0,1-Xe**+(-(Qe-Math.acos(Math.max(-1,Math.min(1,e))))/$e))}function st(e){let t=.2*e*1e-17;return[.434*t*Ze[0],.434*t*Ze[1],.434*t*Ze[2]]}function ct(e){return it*(1+e**2)}function lt(e,t){let n=t*t;return at*((1-n)/(1-2*t*e+n)**1.5)}function ut(e,t){return e[0]*t[0]+e[1]*t[1]+e[2]*t[2]}function dt(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 ft(e,t,n,r,i,a,o,s){let c=(1-t)*Je,l=(e-.5)*Ye,u=Math.sin(c),d=dt([u*Math.sin(l),Math.cos(c),u*Math.cos(l)]),f=dt(n),p=ot(f[1])*r,m=i-1*(1-(1-Math.max(0,Math.min(1,1-Math.exp(f[1]/45e4))))),h=[q[0]*m,q[1]*m,q[2]*m],g=st(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/Je*v)**-1.253,b=tt/y,x=nt/y,S=[Math.exp(-(h[0]*b+_[0]*x)),Math.exp(-(h[1]*b+_[1]*x)),Math.exp(-(h[2]*b+_[2]*x))],C=ut(d,f),w=ct(C*.5+.5),T=[h[0]*w,h[1]*w,h[2]*w],E=lt(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]],F=pt(rt,rt+2e-5,C);for(let e=0;e<3;e++)P[e]+=p*19e3*S[e]*F;let I=65504;return[Math.min((A[0]+P[0])*.04,I),Math.min((A[1]+P[1])*.04+3e-4,I),Math.min((A[2]+P[2])*.04+75e-5,I),1]}function pt(e,t,n){let r=Math.max(0,Math.min(1,(n-e)/(t-e)));return r*r*(3-2*r)}var 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}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=ft((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()}},ht=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()}},gt=class{constructor(e,t){this.scene=e,this.uniforms=t,this.equirectHdrInfo=new K,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(H.gradientZenithColor),gradientHorizonColor:new r.Color(H.gradientHorizonColor),gradientGroundColor:new r.Color(H.gradientGroundColor),solidSkyColor:new r.Color(H.solidSkyColor),skySunDirection:this._calculateInitialSunDirection(),skySunIntensity:H.skySunIntensity,skyRayleighDensity:H.skyRayleighDensity,skyTurbidity:H.skyTurbidity,skyMieAnisotropy:H.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 ht(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 ht(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 mt(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=H.skySunAzimuth*(Math.PI/180),t=H.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}},_t=y({origin:`vec3`,direction:`vec3`}),vt=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`}),yt=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:vt});var bt=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:vt,materialIndex:`int`,meshIndex:`int`}),y({color:`vec4`,samples:`int`});var xt=y({direction:`vec3`,value:`vec3`,pdf:`float`}),St=y({specular:`float`,diffuse:`float`,sheen:`float`,clearcoat:`float`,transmission:`float`,iridescence:`float`}),Ct=y({diffuseImportance:`float`,specularImportance:`float`,transmissionImportance:`float`,clearcoatImportance:`float`}),wt=y({NoL:`float`,NoV:`float`,NoH:`float`,VoH:`float`,LoH:`float`}),Tt=y({compensation:`vec3`,E_total:`vec3`}),Et=y({albedo:`vec4`,emissive:`vec3`,metalness:`float`,roughness:`float`,normal:`vec3`,hasTextures:`bool`}),Dt=y({isMetallic:`bool`,isRough:`bool`,isSmooth:`bool`,isTransmissive:`bool`,hasClearcoat:`bool`,isEmissive:`bool`,complexityScore:`float`}),Ot=y({albedoUV:`vec2`,normalUV:`vec2`,metalnessUV:`vec2`,emissiveUV:`vec2`,bumpUV:`vec2`,roughnessUV:`vec2`,normalBumpSameUV:`bool`,metalRoughSameUV:`bool`,albedoEmissiveSameUV:`bool`,allSameUV:`bool`}),kt=y({F0:`vec3`,NoV:`float`,diffuseColor:`vec3`,isPurelyDiffuse:`bool`,alpha:`float`,k:`float`,alpha2:`float`,invRoughness:`float`,metalFactor:`float`,iorFactor:`float`,maxSheenColor:`float`}),At=y({envWeight:`float`,specularWeight:`float`,diffuseWeight:`float`,transmissionWeight:`float`,clearcoatWeight:`float`,totalWeight:`float`,useEnv:`bool`,useSpecular:`bool`,useDiffuse:`bool`,useTransmission:`bool`,useClearcoat:`bool`}),jt=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 Mt=3.14159,Nt=1/Mt,Pt=2*Mt,Ft=1e-6,It=.05,Lt=.089,Rt=.001,zt=(0,n.vec3)(.2126,.7152,.0722),J=W.SLOTS_PER_MATERIAL,Bt=W.SLOT,Y=Bt,Vt=(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,groundProjectionEnabled:!1,groundProjectionRadius:100,groundProjectionHeight:15,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=.01,we={low:{temporalAlpha:.1,gradientStrength:0,atrousIterations:3,phiColor:1,phiNormal:64,phiDepth:.1,phiLuminance:6,maxAccumFrames:16,varianceBoost:.5},medium:{temporalAlpha:.03,gradientStrength:0,atrousIterations:4,phiColor:.5,phiNormal:128,phiDepth:.05,phiLuminance:4,maxAccumFrames:64,varianceBoost:1},high:{temporalAlpha:0,gradientStrength:0,atrousIterations:6,phiColor:.3,phiNormal:256,phiDepth:.02,phiLuminance:2,maxAccumFrames:128,varianceBoost:1.5}},Te={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}},Ee={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}},De={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}},Oe={MANUAL:`manual`,AUTO:`auto`},ke={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}},Ae={TRIANGLE_LEAF:-1,BLAS_POINTER_LEAF:-2},je={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},Me=[0,0,1,1,0,0,0,1],Ne={maxSamples:30,bounces:20,transmissiveBounces:8,samplesPerPixel:1,renderMode:1,enableAlphaShadows:!0,tiles:3,tilesHelper:!0,enableOIDN:!0,oidnQuality:`balance`,interactionModeEnabled:!1},Pe={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},Fe={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},Ie={cameraViewMatrix:`ptCameraViewMatrix`,cameraProjectionMatrix:`ptCameraProjectionMatrix`},Le=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`),a(`groundProjectionEnabled`,V.groundProjectionEnabled),i(`groundProjectionRadius`,V.groundProjectionRadius,`float`),i(`groundProjectionHeight`,V.groundProjectionHeight,`float`),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(192),`float`),area:(0,n.uniformArray)(new Float32Array(208),`float`),point:(0,n.uniformArray)(new Float32Array(144),`float`),spot:(0,n.uniformArray)(new Float32Array(320),`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`)}_nameAll(){for(let[e,t]of this._uniforms)t.name=Ie[e]||e}dispose(){this._disposed||(this._disposed=!0,this._uniforms.clear(),this._booleans.clear(),this._lightBuffers={})}},Re=U.SLOTS_PER_MATERIAL,ze=H.UV_C_MAT_OFFSET+2,Be=H.NORMAL_C_OFFSET+3,Ve=H.NORMAL_A_OFFSET+3,He=new Set([`transmission`,`transparent`,`opacity`,`alphaMode`]),Ue=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/Re),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,He.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,Ve,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+ze]===e&&(i[a+t]=n,s++)}s>0&&this.callbacks.onTriangleDataChanged&&this.callbacks.onTriangleDataChanged()}_patchTriangleSideForMaterial(e,t){this._patchTriangleFlagForMaterial(e,Be,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 We(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 Ge=``+(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 Ke(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 qe(e,t,n){return .2126*e+.7152*t+.0722*n}function Je(e){return e<=.04045?e/12.92:((e+.055)/1.055)**2.4}function W(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]=Je(o[e]),o[e+1]=Je(o[e+1]),o[e+2]=Je(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 G=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}=W(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}=W(e);try{this._worker=new Worker(Ge,{type:`module`})}catch(e){if(e.name!==`SecurityError`)throw e;this._worker=await We(Ge)}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=qe(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]=qe(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]=(Ke(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]=(Ke(d,(n+1)/t,e*t,t)+.5)/t}return{marginalData:m,conditionalData:h,totalSum:l,compensationDelta:u}}},Ye=Math.PI,Xe=Math.PI*2,Ze=Math.E,K=[5804542996261093e-21,13562911419845635e-21,30265902468824876e-21],Qe=[183999185144339.78,277980239196605.28,407904795438610.94],$e=1.6110731556870734,et=1.5,tt=1e3,nt=8400,rt=1250,it=.9999566769464484,at=.05968310365946075,ot=.07957747154594767;function st(e){return tt*Math.max(0,1-Ze**+(-($e-Math.acos(Math.max(-1,Math.min(1,e))))/et))}function ct(e){let t=.2*e*1e-17;return[.434*t*Qe[0],.434*t*Qe[1],.434*t*Qe[2]]}function lt(e){return at*(1+e**2)}function ut(e,t){let n=t*t;return ot*((1-n)/(1-2*t*e+n)**1.5)}function dt(e,t){return e[0]*t[0]+e[1]*t[1]+e[2]*t[2]}function ft(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 pt(e,t,n,r,i,a,o,s){let c=(1-t)*Ye,l=(e-.5)*Xe,u=Math.sin(c),d=ft([u*Math.sin(l),Math.cos(c),u*Math.cos(l)]),f=ft(n),p=st(f[1])*r,m=i-1*(1-(1-Math.max(0,Math.min(1,1-Math.exp(f[1]/45e4))))),h=[K[0]*m,K[1]*m,K[2]*m],g=ct(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/Ye*v)**-1.253,b=nt/y,x=rt/y,S=[Math.exp(-(h[0]*b+_[0]*x)),Math.exp(-(h[1]*b+_[1]*x)),Math.exp(-(h[2]*b+_[2]*x))],C=dt(d,f),w=lt(C*.5+.5),T=[h[0]*w,h[1]*w,h[2]*w],E=ut(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]],F=mt(it,it+2e-5,C);for(let e=0;e<3;e++)P[e]+=p*19e3*S[e]*F;let ee=65504;return[Math.min((A[0]+P[0])*.04,ee),Math.min((A[1]+P[1])*.04+3e-4,ee),Math.min((A[2]+P[2])*.04+75e-5,ee),1]}function mt(e,t,n){let r=Math.max(0,Math.min(1,(n-e)/(t-e)));return r*r*(3-2*r)}var ht=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=pt((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()}},gt=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()}},_t=class{constructor(e,t){this.scene=e,this.uniforms=t,this.equirectHdrInfo=new G,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 gt(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 gt(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 ht(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}},vt=y({origin:`vec3`,direction:`vec3`}),yt=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`}),bt=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:yt});var xt=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:yt,materialIndex:`int`,meshIndex:`int`}),y({color:`vec4`,samples:`int`});var St=y({direction:`vec3`,value:`vec3`,pdf:`float`}),Ct=y({specular:`float`,diffuse:`float`,sheen:`float`,clearcoat:`float`,transmission:`float`,iridescence:`float`}),wt=y({diffuseImportance:`float`,specularImportance:`float`,transmissionImportance:`float`,clearcoatImportance:`float`}),Tt=y({NoL:`float`,NoV:`float`,NoH:`float`,VoH:`float`,LoH:`float`}),Et=y({compensation:`vec3`,E_total:`vec3`}),Dt=y({albedo:`vec4`,emissive:`vec3`,metalness:`float`,roughness:`float`,normal:`vec3`,hasTextures:`bool`}),Ot=y({isMetallic:`bool`,isRough:`bool`,isSmooth:`bool`,isTransmissive:`bool`,hasClearcoat:`bool`,isEmissive:`bool`,complexityScore:`float`}),kt=y({albedoUV:`vec2`,normalUV:`vec2`,metalnessUV:`vec2`,emissiveUV:`vec2`,bumpUV:`vec2`,roughnessUV:`vec2`,normalBumpSameUV:`bool`,metalRoughSameUV:`bool`,albedoEmissiveSameUV:`bool`,allSameUV:`bool`}),At=y({F0:`vec3`,NoV:`float`,diffuseColor:`vec3`,isPurelyDiffuse:`bool`,alpha:`float`,k:`float`,alpha2:`float`,invRoughness:`float`,metalFactor:`float`,iorFactor:`float`,maxSheenColor:`float`}),jt=y({envWeight:`float`,specularWeight:`float`,diffuseWeight:`float`,transmissionWeight:`float`,clearcoatWeight:`float`,totalWeight:`float`,useEnv:`bool`,useSpecular:`bool`,useDiffuse:`bool`,useTransmission:`bool`,useClearcoat:`bool`}),Mt=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 Nt=3.14159,Pt=1/Nt,Ft=2*Nt,It=1e-6,Lt=.05,Rt=.089,zt=.001,Bt=(0,n.vec3)(.2126,.7152,.0722),q=U.SLOTS_PER_MATERIAL,Vt=U.SLOT,J=Vt,Ht=(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 Ht=(0,n.wgslFn)(`
155
+ `);var Ut=(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 Ut=(0,n.wgslFn)(`
167
+ `);var Wt=(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 Wt=(0,n.wgslFn)(`
179
+ `);var Gt=(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
- `),Gt=(0,n.wgslFn)(`
185
+ `),Kt=(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, ${Rt} );
190
+ return p1 / max( p1 + p2, ${zt} );
191
191
 
192
192
  }
193
- `),Kt=(0,n.wgslFn)(`
193
+ `),qt=(0,n.wgslFn)(`
194
194
  fn balanceHeuristic( pdf1: f32, pdf2: f32 ) -> f32 {
195
195
 
196
- return pdf1 / max( pdf1 + pdf2, ${Rt} );
196
+ return pdf1 / max( pdf1 + pdf2, ${zt} );
197
197
 
198
198
  }
199
199
  `);(0,n.wgslFn)(`
@@ -211,7 +211,7 @@
211
211
  return color + ( dither - 0.5 ) * ditheringAmount / 255.0;
212
212
 
213
213
  }
214
- `);var qt=(0,n.wgslFn)(`
214
+ `);var Jt=(0,n.wgslFn)(`
215
215
  fn constructTBN( N: vec3f ) -> mat3x3f {
216
216
 
217
217
  var majorAxis: vec3f;
@@ -225,7 +225,7 @@
225
225
  return mat3x3f( T, B, N );
226
226
 
227
227
  }
228
- `),Jt=(0,n.Fn)(([e,t,r])=>{let i=t.add(r).toVar(),a=(0,n.dot)(i,i).toVar();return i.assign(a.greaterThan(Ft).select(i.div(a.sqrt()),(0,n.vec3)(0,0,1))),wt({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)})}),Yt=(0,n.wgslFn)(`
228
+ `),Yt=(0,n.Fn)(([e,t,r])=>{let i=t.add(r).toVar(),a=(0,n.dot)(i,i).toVar();return i.assign(a.greaterThan(It).select(i.div(a.sqrt()),(0,n.vec3)(0,0,1))),Tt({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)})}),Xt=(0,n.wgslFn)(`
229
229
  fn calculateFireflyThreshold( baseThreshold: f32, bounceIndex: i32, frame: i32 ) -> f32 {
230
230
 
231
231
  let depthFactor = 1.0 / ( 1.0 + f32( bounceIndex ) * 0.1 );
@@ -233,7 +233,7 @@
233
233
  return baseThreshold * depthFactor * relaxation;
234
234
 
235
235
  }
236
- `),Xt=(0,n.wgslFn)(`
236
+ `),Zt=(0,n.wgslFn)(`
237
237
  fn applySoftSuppression( value: f32, threshold: f32, dampingFactor: f32 ) -> f32 {
238
238
 
239
239
  if ( value <= threshold ) {
@@ -244,7 +244,7 @@
244
244
  return value * suppressionFactor;
245
245
 
246
246
  }
247
- `),Zt=(0,n.wgslFn)(`
247
+ `),Qt=(0,n.wgslFn)(`
248
248
  fn applySoftSuppressionRGB( color: vec3f, threshold: f32, dampingFactor: f32 ) -> vec3f {
249
249
 
250
250
  let lum = dot( color, vec3f( 0.2126, 0.7152, 0.0722 ) );
@@ -252,13 +252,13 @@
252
252
  return color;
253
253
  }
254
254
  let suppressedLum = applySoftSuppression( lum, threshold, dampingFactor );
255
- if ( lum > ${Ft} ) {
255
+ if ( lum > ${It} ) {
256
256
  return color * ( suppressedLum / lum );
257
257
  }
258
258
  return color;
259
259
 
260
260
  }
261
- `,[Xt]),Qt=(0,n.Fn)(([e,t,r,i,a])=>{let o=e.greaterThan(.7).toVar(),s=t.greaterThan(.8),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))),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)}),Dt({isMetallic:o,isRough:s,isSmooth:c,isTransmissive:l,hasClearcoat:u,isEmissive:d,complexityScore:(0,n.clamp)(f.add(p),0,1)})}),$t=(0,n.Fn)(([e,t,r,i])=>{let a=Ut({v:i}).toVar(),o=(0,n.float)(.5).toVar(),s=(0,n.float)(.5).toVar(),c=(0,n.bool)(!0),l=a.greaterThan(.01);return(0,n.If)(e.lessThan(.1).and(t.greaterThan(.8)),()=>{o.assign(.7),s.assign(.3)}).ElseIf(e.greaterThan(.7),()=>{o.assign(.4),s.assign(.6)}),(0,n.If)(r.greaterThan((0,n.int)(5)),()=>{o.assign(.6),s.assign(.4)}),jt({brdfWeight:o,lightWeight:s,envWeight:(0,n.float)(0),useBRDFSampling:c,useLightSampling:l,useEnvSampling:(0,n.bool)(!1)})}),X=(0,n.Fn)(([e,t,n,r])=>{let i=t.mul(r).add(n);return e.element(i)}),en=(0,n.wgslFn)(`
261
+ `,[Zt]),$t=(0,n.Fn)(([e,t,r,i,a])=>{let o=e.greaterThan(.7).toVar(),s=t.greaterThan(.8),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))),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)}),Ot({isMetallic:o,isRough:s,isSmooth:c,isTransmissive:l,hasClearcoat:u,isEmissive:d,complexityScore:(0,n.clamp)(f.add(p),0,1)})}),en=(0,n.Fn)(([e,t,r,i])=>{let a=Wt({v:i}).toVar(),o=(0,n.float)(.5).toVar(),s=(0,n.float)(.5).toVar(),c=(0,n.bool)(!0),l=a.greaterThan(.01);return(0,n.If)(e.lessThan(.1).and(t.greaterThan(.8)),()=>{o.assign(.7),s.assign(.3)}).ElseIf(e.greaterThan(.7),()=>{o.assign(.4),s.assign(.6)}),(0,n.If)(r.greaterThan((0,n.int)(5)),()=>{o.assign(.6),s.assign(.4)}),Mt({brdfWeight:o,lightWeight:s,envWeight:(0,n.float)(0),useBRDFSampling:c,useLightSampling:l,useEnvSampling:(0,n.bool)(!1)})}),Y=(0,n.Fn)(([e,t,n,r])=>{let i=t.mul(r).add(n);return e.element(i)}),tn=(0,n.wgslFn)(`
262
262
  fn arrayToMat3( data1: vec4f, data2: vec4f ) -> mat3x3f {
263
263
 
264
264
  return mat3x3f(
@@ -268,7 +268,7 @@
268
268
  );
269
269
 
270
270
  }
271
- `),tn=(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 vt({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:en({data1:g,data2:_}),normalTransform:en({data1:v,data2:y}),roughnessTransform:en({data1:b,data2:x}),metalnessTransform:en({data1:S,data2:C}),emissiveTransform:en({data1:w,data2:T}),bumpTransform:en({data1:E,data2:D}),displacementTransform:en({data1:O,data2:k})})}),nn=(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 yt({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:en({data1:c,data2:l})})}),rn=(0,n.wgslFn)(`
271
+ `),nn=(0,n.Fn)(([e,t])=>{let r=Y(t,e,(0,n.int)(J.COLOR_METALNESS),(0,n.int)(q)).toVar(),i=Y(t,e,(0,n.int)(J.EMISSIVE_ROUGHNESS),(0,n.int)(q)).toVar(),a=Y(t,e,(0,n.int)(J.IOR_TRANSMISSION),(0,n.int)(q)).toVar(),o=Y(t,e,(0,n.int)(J.ATTENUATION),(0,n.int)(q)).toVar(),s=Y(t,e,(0,n.int)(J.DISPERSION_SHEEN),(0,n.int)(q)).toVar(),c=Y(t,e,(0,n.int)(J.SHEEN_COLOR),(0,n.int)(q)).toVar(),l=Y(t,e,(0,n.int)(J.SPECULAR),(0,n.int)(q)).toVar(),u=Y(t,e,(0,n.int)(J.IRIDESCENCE),(0,n.int)(q)).toVar(),d=Y(t,e,(0,n.int)(J.MAP_INDICES_A),(0,n.int)(q)).toVar(),f=Y(t,e,(0,n.int)(J.MAP_INDICES_B),(0,n.int)(q)).toVar(),p=Y(t,e,(0,n.int)(J.OPACITY_ALPHA),(0,n.int)(q)).toVar(),m=Y(t,e,(0,n.int)(J.ALPHA_MODE),(0,n.int)(q)).toVar(),h=Y(t,e,(0,n.int)(J.BUMP_DISPLACEMENT),(0,n.int)(q)).toVar(),g=Y(t,e,(0,n.int)(J.ALBEDO_TRANSFORM_A),(0,n.int)(q)).toVar(),_=Y(t,e,(0,n.int)(J.ALBEDO_TRANSFORM_B),(0,n.int)(q)).toVar(),v=Y(t,e,(0,n.int)(J.NORMAL_TRANSFORM_A),(0,n.int)(q)).toVar(),y=Y(t,e,(0,n.int)(J.NORMAL_TRANSFORM_B),(0,n.int)(q)).toVar(),b=Y(t,e,(0,n.int)(J.ROUGHNESS_TRANSFORM_A),(0,n.int)(q)).toVar(),x=Y(t,e,(0,n.int)(J.ROUGHNESS_TRANSFORM_B),(0,n.int)(q)).toVar(),S=Y(t,e,(0,n.int)(J.METALNESS_TRANSFORM_A),(0,n.int)(q)).toVar(),C=Y(t,e,(0,n.int)(J.METALNESS_TRANSFORM_B),(0,n.int)(q)).toVar(),w=Y(t,e,(0,n.int)(J.EMISSIVE_TRANSFORM_A),(0,n.int)(q)).toVar(),T=Y(t,e,(0,n.int)(J.EMISSIVE_TRANSFORM_B),(0,n.int)(q)).toVar(),E=Y(t,e,(0,n.int)(J.BUMP_TRANSFORM_A),(0,n.int)(q)).toVar(),D=Y(t,e,(0,n.int)(J.BUMP_TRANSFORM_B),(0,n.int)(q)).toVar(),O=Y(t,e,(0,n.int)(J.DISPLACEMENT_TRANSFORM_A),(0,n.int)(q)).toVar(),k=Y(t,e,(0,n.int)(J.DISPLACEMENT_TRANSFORM_B),(0,n.int)(q)).toVar();return yt({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:tn({data1:g,data2:_}),normalTransform:tn({data1:v,data2:y}),roughnessTransform:tn({data1:b,data2:x}),metalnessTransform:tn({data1:S,data2:C}),emissiveTransform:tn({data1:w,data2:T}),bumpTransform:tn({data1:E,data2:D}),displacementTransform:tn({data1:O,data2:k})})}),rn=(0,n.Fn)(([e,t])=>{let r=Y(t,e,(0,n.int)(J.IOR_TRANSMISSION),(0,n.int)(q)).toVar(),i=Y(t,e,(0,n.int)(J.ATTENUATION),(0,n.int)(q)).toVar(),a=Y(t,e,(0,n.int)(J.MAP_INDICES_A),(0,n.int)(q)).toVar(),o=Y(t,e,(0,n.int)(J.OPACITY_ALPHA),(0,n.int)(q)).toVar(),s=Y(t,e,(0,n.int)(J.ALPHA_MODE),(0,n.int)(q)).toVar(),c=Y(t,e,(0,n.int)(J.ALBEDO_TRANSFORM_A),(0,n.int)(q)).toVar(),l=Y(t,e,(0,n.int)(J.ALBEDO_TRANSFORM_B),(0,n.int)(q)).toVar();return bt({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:tn({data1:c,data2:l})})}),an=(0,n.wgslFn)(`
272
272
  fn normalDepthWeight(
273
273
  n1: vec3f, n2: vec3f,
274
274
  d1: f32, d2: f32,
@@ -280,7 +280,7 @@
280
280
  return normalW * depthW;
281
281
 
282
282
  }
283
- `),an=32,on=512,sn=4,cn=8,ln=1e8,un=()=>(0,n.array)(`int`,an).toVar(),dn=(0,n.wgslFn)(`
283
+ `),on=32,sn=512,cn=4,ln=8,un=1e8,dn=()=>(0,n.array)(`int`,on).toVar(),fn=(0,n.wgslFn)(`
284
284
  fn RayTriangleGeometry( rayOrigin: vec3f, rayDir: vec3f, pA: vec3f, pB: vec3f, pC: vec3f, closestHitDst: f32, woopParams: vec4f ) -> vec4f {
285
285
 
286
286
  // Returns vec4(t, u, v, hit) where hit > 0.5 means intersection.
@@ -346,7 +346,7 @@
346
346
  return result;
347
347
 
348
348
  }
349
- `),fn=(0,n.wgslFn)(`
349
+ `),pn=(0,n.wgslFn)(`
350
350
  fn computeWoopRayParams( rayDir: vec3f ) -> vec4f {
351
351
 
352
352
  let absDir = abs( rayDir );
@@ -375,7 +375,7 @@
375
375
  return vec4f( Sx, Sy, Sz, f32( packed ) );
376
376
 
377
377
  }
378
- `),pn=(0,n.wgslFn)(`
378
+ `),mn=(0,n.wgslFn)(`
379
379
  fn fastRayAABBDst( rayOrigin: vec3f, invDir: vec3f, boxMin: vec3f, boxMax: vec3f ) -> f32 {
380
380
 
381
381
  let t1 = ( boxMin - rayOrigin ) * invDir;
@@ -391,7 +391,7 @@
391
391
  return select( 1e20f, max( tNear, 0.0f ), isHit );
392
392
 
393
393
  }
394
- `),mn=(0,n.Fn)(([e,t,r])=>{let i=bt({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(),a=(0,n.int)(-1).toVar(),o=(0,n.float)(0).toVar(),s=(0,n.float)(0).toVar(),c=un(),l=(0,n.int)(1).toVar();c.element((0,n.int)(0)).assign((0,n.int)(0));let u=(0,n.mix)((0,n.vec3)(1),(0,n.sign)(e.direction),(0,n.notEqual)(e.direction,(0,n.vec3)(0))),d=(0,n.mix)((0,n.vec3)(1).div(e.direction),(0,n.vec3)(ln).mul(u),(0,n.lessThan)((0,n.abs)(e.direction),(0,n.vec3)(1e-8))).toVar(),f=e.origin,p=e.direction,m=fn({rayDir:p}).toVar(),h=(0,n.int)(0).toVar();return(0,n.Loop)(l.greaterThan((0,n.int)(0)).and(h.lessThan((0,n.int)(on))),()=>{h.addAssign(1),l.subAssign(1);let e=c.element(l).toVar(),u=X(t,e,(0,n.int)(0),(0,n.int)(sn));i.boxTests.addAssign(1),(0,n.If)(u.w.lessThan(0),()=>{(0,n.If)(u.w.greaterThan((0,n.float)(-1.5)),()=>{let e=(0,n.int)(u.x).toVar(),t=(0,n.int)(u.y).toVar();(0,n.Loop)({start:(0,n.int)(0),end:t},({i:t})=>{i.triTests.addAssign(1);let c=e.add(t).toVar(),l=X(r,c,(0,n.int)(0),(0,n.int)(cn)).xyz,u=X(r,c,(0,n.int)(1),(0,n.int)(cn)).xyz,d=X(r,c,(0,n.int)(2),(0,n.int)(cn)).xyz,h=dn({rayOrigin:f,rayDir:p,pA:l,pB:u,pC:d,closestHitDst:i.dst,woopParams:m});(0,n.If)(h.w.greaterThan(.5),()=>{let e=h.x,t=h.y,l=h.z,u=X(r,c,(0,n.int)(3),(0,n.int)(cn)).xyz,d=X(r,c,(0,n.int)(4),(0,n.int)(cn)).xyz,f=X(r,c,(0,n.int)(5),(0,n.int)(cn)),m=f.xyz,g=(0,n.int)(f.w).toVar(),_=(0,n.float)(1).sub(t).sub(l),v=p.dot((0,n.normalize)(u.mul(_).add(d.mul(t)).add(m.mul(l))));(0,n.If)(g.equal((0,n.int)(2)).or(g.equal((0,n.int)(0)).and(v.lessThan(-1e-4))).or(g.equal((0,n.int)(1)).and(v.greaterThan(1e-4))),()=>{i.didHit.assign(!0),i.dst.assign(e),a.assign(c),o.assign(t),s.assign(l)})})}),(0,n.If)(i.didHit.and(i.dst.lessThan(.001)),()=>{(0,n.Break)()})}).Else(()=>{(0,n.If)(u.z.greaterThan(.5).and(l.lessThan((0,n.int)(an))),()=>{c.element(l).assign((0,n.int)(u.x)),l.addAssign(1)})})}).Else(()=>{let r=X(t,e,(0,n.int)(1),(0,n.int)(sn)),a=X(t,e,(0,n.int)(2),(0,n.int)(sn)),o=X(t,e,(0,n.int)(3),(0,n.int)(sn)),s=(0,n.int)(u.w).toVar(),p=(0,n.int)(r.w).toVar(),m=pn({rayOrigin:f,invDir:d,boxMin:u.xyz,boxMax:r.xyz}).toVar(),h=pn({rayOrigin:f,invDir:d,boxMin:a.xyz,boxMax:o.xyz}).toVar();(0,n.If)((0,n.min)(m,h).lessThan(i.dst),()=>{let e=m.lessThan(h);(0,n.If)((0,n.select)(e,h,m).lessThan(i.dst).and(l.lessThan((0,n.int)(an))),()=>{c.element(l).assign((0,n.select)(e,p,s)),l.addAssign(1)}),(0,n.If)(l.lessThan((0,n.int)(an)),()=>{c.element(l).assign((0,n.select)(e,s,p)),l.addAssign(1)})})})}),(0,n.If)(i.didHit,()=>{i.hitPoint.assign(e.origin.add(e.direction.mul(i.dst)));let t=(0,n.float)(1).sub(o).sub(s),c=X(r,a,(0,n.int)(3),(0,n.int)(cn)).xyz,l=X(r,a,(0,n.int)(4),(0,n.int)(cn)).xyz,u=X(r,a,(0,n.int)(5),(0,n.int)(cn)).xyz;i.normal.assign((0,n.normalize)(c.mul(t).add(l.mul(o)).add(u.mul(s))));let d=X(r,a,(0,n.int)(6),(0,n.int)(cn)),f=X(r,a,(0,n.int)(7),(0,n.int)(cn));i.uv.assign(d.xy.mul(t).add(d.zw.mul(o)).add(f.xy.mul(s))),i.materialIndex.assign((0,n.int)(f.z)),i.meshIndex.assign((0,n.int)(f.w)),i.triangleIndex.assign(a)}),i}),hn=(0,n.Fn)(([e,t,r,i])=>{let a=bt({didHit:!1,dst:i,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=un(),s=(0,n.int)(1).toVar();o.element((0,n.int)(0)).assign((0,n.int)(0));let c=(0,n.mix)((0,n.vec3)(1),(0,n.sign)(e.direction),(0,n.notEqual)(e.direction,(0,n.vec3)(0))),l=(0,n.mix)((0,n.vec3)(1).div(e.direction),(0,n.vec3)(ln).mul(c),(0,n.lessThan)((0,n.abs)(e.direction),(0,n.vec3)(1e-8))).toVar(),u=fn({rayDir:e.direction}).toVar(),d=(0,n.int)(0).toVar();return(0,n.Loop)(s.greaterThan((0,n.int)(0)).and(a.didHit.not()).and(d.lessThan((0,n.int)(on))),()=>{d.addAssign(1),s.subAssign(1);let i=o.element(s).toVar(),c=X(t,i,(0,n.int)(0),(0,n.int)(sn));(0,n.If)(c.w.lessThan(0),()=>{(0,n.If)(c.w.greaterThan((0,n.float)(-1.5)),()=>{let t=(0,n.int)(c.x).toVar(),i=(0,n.int)(c.y).toVar();(0,n.Loop)({start:(0,n.int)(0),end:i},({i})=>{let o=t.add(i).toVar(),s=X(r,o,(0,n.int)(0),(0,n.int)(cn)).xyz,c=X(r,o,(0,n.int)(1),(0,n.int)(cn)).xyz,l=X(r,o,(0,n.int)(2),(0,n.int)(cn)).xyz,d=dn({rayOrigin:e.origin,rayDir:e.direction,pA:s,pB:c,pC:l,closestHitDst:a.dst,woopParams:u});(0,n.If)(d.w.greaterThan(.5),()=>{let t=X(r,o,(0,n.int)(7),(0,n.int)(cn));a.didHit.assign(!0),a.dst.assign(d.x),a.materialIndex.assign((0,n.int)(t.z)),a.meshIndex.assign((0,n.int)(t.w)),a.hitPoint.assign(e.origin.add(e.direction.mul(d.x))),a.uv.assign((0,n.vec2)(d.y,d.z)),a.triangleIndex.assign(o),(0,n.Break)()})})}).Else(()=>{(0,n.If)(c.z.greaterThan(.5).and(s.lessThan((0,n.int)(an))),()=>{o.element(s).assign((0,n.int)(c.x)),s.addAssign(1)})})}).Else(()=>{let r=X(t,i,(0,n.int)(1),(0,n.int)(sn)),u=X(t,i,(0,n.int)(2),(0,n.int)(sn)),d=X(t,i,(0,n.int)(3),(0,n.int)(sn)),f=(0,n.int)(c.w).toVar(),p=(0,n.int)(r.w).toVar(),m=pn({rayOrigin:e.origin,invDir:l,boxMin:c.xyz,boxMax:r.xyz}).toVar(),h=pn({rayOrigin:e.origin,invDir:l,boxMin:u.xyz,boxMax:d.xyz}).toVar();(0,n.If)((0,n.min)(m,h).lessThan(a.dst),()=>{let e=m.lessThan(h);(0,n.If)((0,n.select)(e,h,m).lessThan(a.dst).and(s.lessThan((0,n.int)(an))),()=>{o.element(s).assign((0,n.select)(e,p,f)),s.addAssign(1)}),(0,n.If)(s.lessThan((0,n.int)(an)),()=>{o.element(s).assign((0,n.select)(e,f,p)),s.addAssign(1)})})})}),a}),gn=(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=o.div(s).mul(.001).mul(l).mul(u),i=P(t),a=i.x.mul(d.max(.01)),f=i.y,p=(0,n.normalize)((0,n.vec3)(r[0])),v=(0,n.normalize)((0,n.vec3)(r[1])),y=p.mul(a).add(v.mul(f)).mul(e);g.assign(h.add(y)),_.assign((0,n.normalize)(h.add(m.mul(c)).sub(g)))}),_t({origin:g,direction:_})}),_n=(0,n.wgslFn)(`
394
+ `),hn=(0,n.Fn)(([e,t,r])=>{let i=xt({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(),a=(0,n.int)(-1).toVar(),o=(0,n.float)(0).toVar(),s=(0,n.float)(0).toVar(),c=dn(),l=(0,n.int)(1).toVar();c.element((0,n.int)(0)).assign((0,n.int)(0));let u=(0,n.mix)((0,n.vec3)(1),(0,n.sign)(e.direction),(0,n.notEqual)(e.direction,(0,n.vec3)(0))),d=(0,n.mix)((0,n.vec3)(1).div(e.direction),(0,n.vec3)(un).mul(u),(0,n.lessThan)((0,n.abs)(e.direction),(0,n.vec3)(1e-8))).toVar(),f=e.origin,p=e.direction,m=pn({rayDir:p}).toVar(),h=(0,n.int)(0).toVar();return(0,n.Loop)(l.greaterThan((0,n.int)(0)).and(h.lessThan((0,n.int)(sn))),()=>{h.addAssign(1),l.subAssign(1);let e=c.element(l).toVar(),u=Y(t,e,(0,n.int)(0),(0,n.int)(cn));i.boxTests.addAssign(1),(0,n.If)(u.w.lessThan(0),()=>{(0,n.If)(u.w.greaterThan((0,n.float)(-1.5)),()=>{let e=(0,n.int)(u.x).toVar(),t=(0,n.int)(u.y).toVar();(0,n.Loop)({start:(0,n.int)(0),end:t},({i:t})=>{i.triTests.addAssign(1);let c=e.add(t).toVar(),l=Y(r,c,(0,n.int)(0),(0,n.int)(ln)).xyz,u=Y(r,c,(0,n.int)(1),(0,n.int)(ln)).xyz,d=Y(r,c,(0,n.int)(2),(0,n.int)(ln)).xyz,h=fn({rayOrigin:f,rayDir:p,pA:l,pB:u,pC:d,closestHitDst:i.dst,woopParams:m});(0,n.If)(h.w.greaterThan(.5),()=>{let e=h.x,t=h.y,l=h.z,u=Y(r,c,(0,n.int)(3),(0,n.int)(ln)).xyz,d=Y(r,c,(0,n.int)(4),(0,n.int)(ln)).xyz,f=Y(r,c,(0,n.int)(5),(0,n.int)(ln)),m=f.xyz,g=(0,n.int)(f.w).toVar(),_=(0,n.float)(1).sub(t).sub(l),v=p.dot((0,n.normalize)(u.mul(_).add(d.mul(t)).add(m.mul(l))));(0,n.If)(g.equal((0,n.int)(2)).or(g.equal((0,n.int)(0)).and(v.lessThan(-1e-4))).or(g.equal((0,n.int)(1)).and(v.greaterThan(1e-4))),()=>{i.didHit.assign(!0),i.dst.assign(e),a.assign(c),o.assign(t),s.assign(l)})})}),(0,n.If)(i.didHit.and(i.dst.lessThan(.001)),()=>{(0,n.Break)()})}).Else(()=>{(0,n.If)(u.z.greaterThan(.5).and(l.lessThan((0,n.int)(on))),()=>{c.element(l).assign((0,n.int)(u.x)),l.addAssign(1)})})}).Else(()=>{let r=Y(t,e,(0,n.int)(1),(0,n.int)(cn)),a=Y(t,e,(0,n.int)(2),(0,n.int)(cn)),o=Y(t,e,(0,n.int)(3),(0,n.int)(cn)),s=(0,n.int)(u.w).toVar(),p=(0,n.int)(r.w).toVar(),m=mn({rayOrigin:f,invDir:d,boxMin:u.xyz,boxMax:r.xyz}).toVar(),h=mn({rayOrigin:f,invDir:d,boxMin:a.xyz,boxMax:o.xyz}).toVar();(0,n.If)((0,n.min)(m,h).lessThan(i.dst),()=>{let e=m.lessThan(h);(0,n.If)((0,n.select)(e,h,m).lessThan(i.dst).and(l.lessThan((0,n.int)(on))),()=>{c.element(l).assign((0,n.select)(e,p,s)),l.addAssign(1)}),(0,n.If)(l.lessThan((0,n.int)(on)),()=>{c.element(l).assign((0,n.select)(e,s,p)),l.addAssign(1)})})})}),(0,n.If)(i.didHit,()=>{i.hitPoint.assign(e.origin.add(e.direction.mul(i.dst)));let t=(0,n.float)(1).sub(o).sub(s),c=Y(r,a,(0,n.int)(3),(0,n.int)(ln)).xyz,l=Y(r,a,(0,n.int)(4),(0,n.int)(ln)).xyz,u=Y(r,a,(0,n.int)(5),(0,n.int)(ln)).xyz;i.normal.assign((0,n.normalize)(c.mul(t).add(l.mul(o)).add(u.mul(s))));let d=Y(r,a,(0,n.int)(6),(0,n.int)(ln)),f=Y(r,a,(0,n.int)(7),(0,n.int)(ln));i.uv.assign(d.xy.mul(t).add(d.zw.mul(o)).add(f.xy.mul(s))),i.materialIndex.assign((0,n.int)(f.z)),i.meshIndex.assign((0,n.int)(f.w)),i.triangleIndex.assign(a)}),i}),gn=(0,n.Fn)(([e,t,r,i])=>{let a=xt({didHit:!1,dst:i,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=dn(),s=(0,n.int)(1).toVar();o.element((0,n.int)(0)).assign((0,n.int)(0));let c=(0,n.mix)((0,n.vec3)(1),(0,n.sign)(e.direction),(0,n.notEqual)(e.direction,(0,n.vec3)(0))),l=(0,n.mix)((0,n.vec3)(1).div(e.direction),(0,n.vec3)(un).mul(c),(0,n.lessThan)((0,n.abs)(e.direction),(0,n.vec3)(1e-8))).toVar(),u=pn({rayDir:e.direction}).toVar(),d=(0,n.int)(0).toVar();return(0,n.Loop)(s.greaterThan((0,n.int)(0)).and(a.didHit.not()).and(d.lessThan((0,n.int)(sn))),()=>{d.addAssign(1),s.subAssign(1);let i=o.element(s).toVar(),c=Y(t,i,(0,n.int)(0),(0,n.int)(cn));(0,n.If)(c.w.lessThan(0),()=>{(0,n.If)(c.w.greaterThan((0,n.float)(-1.5)),()=>{let t=(0,n.int)(c.x).toVar(),i=(0,n.int)(c.y).toVar();(0,n.Loop)({start:(0,n.int)(0),end:i},({i})=>{let o=t.add(i).toVar(),s=Y(r,o,(0,n.int)(0),(0,n.int)(ln)).xyz,c=Y(r,o,(0,n.int)(1),(0,n.int)(ln)).xyz,l=Y(r,o,(0,n.int)(2),(0,n.int)(ln)).xyz,d=fn({rayOrigin:e.origin,rayDir:e.direction,pA:s,pB:c,pC:l,closestHitDst:a.dst,woopParams:u});(0,n.If)(d.w.greaterThan(.5),()=>{let t=Y(r,o,(0,n.int)(7),(0,n.int)(ln));a.didHit.assign(!0),a.dst.assign(d.x),a.materialIndex.assign((0,n.int)(t.z)),a.meshIndex.assign((0,n.int)(t.w)),a.hitPoint.assign(e.origin.add(e.direction.mul(d.x))),a.uv.assign((0,n.vec2)(d.y,d.z)),a.triangleIndex.assign(o),(0,n.Break)()})})}).Else(()=>{(0,n.If)(c.z.greaterThan(.5).and(s.lessThan((0,n.int)(on))),()=>{o.element(s).assign((0,n.int)(c.x)),s.addAssign(1)})})}).Else(()=>{let r=Y(t,i,(0,n.int)(1),(0,n.int)(cn)),u=Y(t,i,(0,n.int)(2),(0,n.int)(cn)),d=Y(t,i,(0,n.int)(3),(0,n.int)(cn)),f=(0,n.int)(c.w).toVar(),p=(0,n.int)(r.w).toVar(),m=mn({rayOrigin:e.origin,invDir:l,boxMin:c.xyz,boxMax:r.xyz}).toVar(),h=mn({rayOrigin:e.origin,invDir:l,boxMin:u.xyz,boxMax:d.xyz}).toVar();(0,n.If)((0,n.min)(m,h).lessThan(a.dst),()=>{let e=m.lessThan(h);(0,n.If)((0,n.select)(e,h,m).lessThan(a.dst).and(s.lessThan((0,n.int)(on))),()=>{o.element(s).assign((0,n.select)(e,p,f)),s.addAssign(1)}),(0,n.If)(s.lessThan((0,n.int)(on)),()=>{o.element(s).assign((0,n.select)(e,f,p)),s.addAssign(1)})})})}),a}),_n=(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=o.div(s).mul(.001).mul(l).mul(u),i=P(t),a=i.x.mul(d.max(.01)),f=i.y,p=(0,n.normalize)((0,n.vec3)(r[0])),v=(0,n.normalize)((0,n.vec3)(r[1])),y=p.mul(a).add(v.mul(f)).mul(e);g.assign(h.add(y)),_.assign((0,n.normalize)(h.add(m.mul(c)).sub(g)))}),vt({origin:g,direction:_})}),vn=(0,n.wgslFn)(`
395
395
  fn equirectDirectionToUv( direction: vec3f, environmentMatrix: mat4x4f ) -> vec2f {
396
396
  let d = normalize( ( environmentMatrix * vec4f( direction, 0.0f ) ).xyz );
397
397
  var uv = vec2f( atan2( d.z, d.x ), acos( d.y ) );
@@ -400,7 +400,7 @@
400
400
  uv.y = 1.0f - uv.y;
401
401
  return uv;
402
402
  }
403
- `),vn=(0,n.wgslFn)(`
403
+ `),yn=(0,n.wgslFn)(`
404
404
  fn equirectUvToDirection( uv: vec2f, environmentMatrix: mat4x4f ) -> vec3f {
405
405
  let adjustedUv = vec2f( uv.x - 0.5f, 1.0f - uv.y );
406
406
  let theta = adjustedUv.x * 6.28318530717958647692f;
@@ -409,7 +409,7 @@
409
409
  let localDir = vec3f( sinPhi * cos( theta ), cos( phi ), sinPhi * sin( theta ) );
410
410
  return normalize( ( transpose( environmentMatrix ) * vec4f( localDir, 0.0f ) ).xyz );
411
411
  }
412
- `),yn=(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=_n({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,zt).mul(u),f=(0,n.max)((0,n.float)(0),d.sub(a)).div(i),p=u.greaterThan(0).select((0,n.float)(1).div((0,n.float)(2*Math.PI*Math.PI).mul(u)),(0,n.float)(0)),m=(0,n.float)(o.x).mul((0,n.float)(o.y)).mul(f).mul(p);s.assign((0,n.vec4)(l,m))}),s}),bn=(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=vn({uv:M,environmentMatrix:r}).toVar(),P=(0,n.texture)(e,M,0).rgb.mul(i).toVar();l.assign(P);let F=(0,n.sin)(M.y.mul(Math.PI)).toVar(),I=(0,n.dot)(P.div(i),zt).mul(F),ee=(0,n.max)((0,n.float)(0),I.sub(o)).div(a),te=F.greaterThan(0).select((0,n.float)(1).div((0,n.float)(2*Math.PI*Math.PI).mul(F)),(0,n.float)(0));return(0,n.vec4)(N,(0,n.float)(s.x).mul((0,n.float)(s.y)).mul(ee).mul(te))}),xn=(0,n.wgslFn)(`
412
+ `),bn=(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=vn({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,Bt).mul(u),f=(0,n.max)((0,n.float)(0),d.sub(a)).div(i),p=u.greaterThan(0).select((0,n.float)(1).div((0,n.float)(2*Math.PI*Math.PI).mul(u)),(0,n.float)(0)),m=(0,n.float)(o.x).mul((0,n.float)(o.y)).mul(f).mul(p);s.assign((0,n.vec4)(l,m))}),s}),xn=(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=yn({uv:M,environmentMatrix:r}).toVar(),P=(0,n.texture)(e,M,0).rgb.mul(i).toVar();l.assign(P);let F=(0,n.sin)(M.y.mul(Math.PI)).toVar(),ee=(0,n.dot)(P.div(i),Bt).mul(F),te=(0,n.max)((0,n.float)(0),ee.sub(o)).div(a),ne=F.greaterThan(0).select((0,n.float)(1).div((0,n.float)(2*Math.PI*Math.PI).mul(F)),(0,n.float)(0));return(0,n.vec4)(N,(0,n.float)(s.x).mul((0,n.float)(s.y)).mul(te).mul(ne))}),Sn=(0,n.wgslFn)(`
413
413
  fn sampleEnvironment(
414
414
  tex: texture_2d<f32>,
415
415
  samp: sampler,
@@ -423,7 +423,7 @@
423
423
  let texSample = textureSampleLevel( tex, samp, uv, 0.0 );
424
424
  return texSample * environmentIntensity;
425
425
  }
426
- `,[_n]),Sn=(0,n.Fn)(([e,t,r,i])=>{let a=t.toConst(),o=e.toVar();o.y.subAssign(i);let s=r.mul(r).toConst(),c=o.dot(a).toConst(),l=o.dot(o).sub(s).toConst(),u=c.mul(c).sub(l).toConst(),d=t.toVar();return(0,n.If)(u.greaterThanEqual(0),()=>{let t=(0,n.sqrt)(u).sub(c).toVar(),i=(0,n.float)(1e6).toVar(),l=a.y.toConst();(0,n.If)(l.lessThanEqual(0),()=>{let t=e.y.negate().div(l).toConst(),r=e.add(a.mul(t)).toConst();(0,n.If)(r.dot(r).lessThan(s),()=>{i.assign(t)})}),(0,n.If)(t.greaterThan(0),()=>{d.assign(o.add(a.mul((0,n.min)(t,i))).div(r))})}),d}),Cn=(0,n.wgslFn)(`
426
+ `,[vn]),Cn=(0,n.Fn)(([e,t,r,i])=>{let a=t.toConst(),o=e.toVar();o.y.subAssign(i);let s=r.mul(r).toConst(),c=o.dot(a).toConst(),l=o.dot(o).sub(s).toConst(),u=c.mul(c).sub(l).toConst(),d=t.toVar();return(0,n.If)(u.greaterThanEqual(0),()=>{let t=(0,n.sqrt)(u).sub(c).toVar(),i=(0,n.float)(1e6).toVar(),l=a.y.toConst();(0,n.If)(l.lessThanEqual(0),()=>{let t=e.y.negate().div(l).toConst(),r=e.add(a.mul(t)).toConst();(0,n.If)(r.dot(r).lessThan(s),()=>{i.assign(t)})}),(0,n.If)(t.greaterThan(0),()=>{d.assign(o.add(a.mul((0,n.min)(t,i))).div(r))})}),d}),wn=(0,n.wgslFn)(`
427
427
  fn isIdentityTransform( transform: mat3x3f ) -> bool {
428
428
  return transform[0][0] == 1.0f
429
429
  && transform[1][1] == 1.0f
@@ -432,7 +432,7 @@
432
432
  && transform[2][0] == 0.0f
433
433
  && transform[2][1] == 0.0f;
434
434
  }
435
- `),wn=(0,n.wgslFn)(`
435
+ `),Tn=(0,n.wgslFn)(`
436
436
  fn getTransformedUV( uv: vec2f, transform: mat3x3f ) -> vec2f {
437
437
  if ( !isIdentityTransform( transform ) ) {
438
438
  return fract( vec2f(
@@ -442,11 +442,11 @@
442
442
  }
443
443
  return uv;
444
444
  }
445
- `,[Cn]),Tn=(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)))),En=(0,n.wgslFn)(`
445
+ `,[wn]),En=(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)))),Dn=(0,n.wgslFn)(`
446
446
  fn hashTransform( t: mat3x3f ) -> f32 {
447
447
  return t[0][0] + t[1][1] * 7.0f + t[2][0] * 13.0f + t[2][1] * 17.0f;
448
448
  }
449
- `),Dn=(0,n.Fn)(([e,t])=>{let r=En({t:t.albedoTransform}).toVar(),i=En({t:t.normalTransform}).toVar(),a=En({t:t.metalnessTransform}).toVar(),o=En({t:t.roughnessTransform}).toVar(),s=En({t:t.emissiveTransform}).toVar(),c=En({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),S=f.or(m),C=p.or(m);return(0,n.If)(m,()=>{let n=wn({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(wn({uv:e,transform:t.albedoTransform})),g.assign(u.select(h,wn({uv:e,transform:t.normalTransform}))),y.assign(p.select(h,wn({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(wn({uv:e,transform:t.bumpTransform}))}),(0,n.If)(f,()=>{_.assign(wn({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(wn({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(wn({uv:e,transform:t.roughnessTransform}))})})}),Ot({albedoUV:h,normalUV:g,metalnessUV:_,roughnessUV:v,emissiveUV:y,bumpUV:b,allSameUV:m,normalBumpSameUV:x,metalRoughSameUV:S,albedoEmissiveSameUV:C})}),On=(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}),kn=(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)}),An=(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}),jn=(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}),Mn=(0,n.Fn)(([e,t,r])=>{let i=t.emissive.mul(t.emissiveIntensity).toVar();return(0,n.If)(t.emissiveMapIndex.greaterThanEqual((0,n.int)(0)),()=>{let a=(0,n.texture)(e,r.emissiveUV).depth((0,n.int)(t.emissiveMapIndex)).toVar();i.assign(i.mul(a.rgb))}),i}),Nn=(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=Tn(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=Ot.wrap(Dn(c,s)).toVar();u.assign(On(e,s,n));let h=kn(i,a,s,n);f.assign(h.x),p.assign(h.y);let g=An(t,l,s,n).toVar();m.assign(jn(r,g,s,n)),d.assign(Mn(o,s,n))}),Et({albedo:u,emissive:d,metalness:f,roughness:p,normal:m,hasTextures:h})}),Pn=(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=wn({uv:r,transform:i});a.assign((0,n.texture)(e,o).depth((0,n.int)(t)).r)}),a}),Fn=32,In=16,Ln=5,Rn=1/1024,zn=8,Bn=y({hitPoint:`vec3`,uv:`vec2`,normal:`vec3`,height:`float`}),Vn=(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)(zn)).xyz.toVar(),p=X(r,d,(0,n.int)(1),(0,n.int)(zn)).xyz,m=X(r,d,(0,n.int)(2),(0,n.int)(zn)).xyz,h=X(r,d,(0,n.int)(6),(0,n.int)(zn)).toVar(),g=X(r,d,(0,n.int)(7),(0,n.int)(zn)),_=h.xy.toVar(),v=h.zw,y=g.xy,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),v.mul(b).sub(y.mul(r)).mul(e)).toVar(),S=g.toVar(),C=(0,n.max)((0,n.abs)(S),.001),w=m.div(C).toVar(),D=(0,n.int)(o.equal((0,n.int)(0)).select((0,n.int)(Fn),(0,n.int)(In))).toVar(),O=w.negate().toVar(),k=w.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)),s=r.mul(S),c=Pn(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)(Ln),type:`int`,condition:`<`},()=>{let o=e.add(r).mul(.5).toVar(),s=t.uv.add(x.mul(o)),c=o.mul(S),l=Pn(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)),v=Pn(i,a.displacementMapIndex,g,a.displacementTransform),y=v.sub(.5).mul(m),b=(0,n.float)(Rn),C=v,w=Pn(i,a.displacementMapIndex,g.add((0,n.vec2)(b,0)),a.displacementTransform),T=Pn(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)})})}),Bn({hitPoint:s,uv:c,normal:l,height:u})}),Hn=1e-6,Un=e=>{let t=e.mul(e);return t.mul(t).mul(e)};(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(Un((0,n.float)(1).sub(t))))});var Wn=(0,n.Fn)(([e,t])=>{let r=(0,n.clamp)(e,0,1);return t.add((0,n.float)(1).sub(t).mul(Un((0,n.float)(1).sub(r))))}),Gn=(0,n.Fn)(([e,t])=>{let r=(0,n.clamp)(e,0,1);return t.add((0,n.vec3)(1).sub(t).mul(Un((0,n.float)(1).sub(r))))}),Kn=(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)(Hn)))}),qn=(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)(Hn)),a=r.div(i);return a.mul(a)}),Jn=(0,n.Fn)(([e,t])=>{let r=e.sub(t),i=(0,n.max)(e.add(t),Hn),a=r.div(i);return a.mul(a)}),Yn=e=>(0,n.vec3)(Jn(e,(0,n.float)(1))),Xn=(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)(Mt).mul(a).mul(a),Ft))}),Zn=(0,n.Fn)(([e,t])=>{let r=(0,n.max)(t,It),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)(Mt).mul(o).mul(o),Ft)),100)}),Qn=(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),Ft))}),$n=(0,n.Fn)(([e,t,n])=>{let r=Qn(e,n);return Qn(t,n).mul(r)}),er=(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),f=(0,n.vec3)(1).add(e.mul((0,n.float)(1).div(d).sub(1)));return Tt({compensation:f,E_total:(0,n.clamp)((0,n.max)(e.mul(l).add((0,n.vec3)(u)),(0,n.vec3)(0)).mul(f),(0,n.vec3)(0),(0,n.vec3)(1))})});(0,n.Fn)(([e,t,r])=>Xn(e,r).mul(e).div((0,n.max)((0,n.float)(4).mul(t),Ft)));var tr=(0,n.Fn)(([e,t,r])=>{let i=Xn(e,r),a=Qn(t,r);return i.mul(a).div((0,n.max)(t.mul(4),Ft))}),nr=(0,n.Fn)(([e,t])=>{let r=(0,n.float)(Pt).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)(Pt).mul(o))).mul((0,n.cos)(a.mul(r).add(t))).mul((0,n.exp)(Ht({x:r}).negate().mul(o))).toVar();return s.x.addAssign((0,n.float)(9747e-17).mul((0,n.sqrt)((0,n.float)(Pt).mul(45282e5))).mul((0,n.cos)((0,n.float)(2239900).mul(r).add(t.x))).mul((0,n.exp)((0,n.float)(-45282e5).mul(Ht({x:r}))))),Vt.mul(s.div(1.0685e-7))}),rr=(0,n.Fn)(([e,t,r,i,a])=>{let o=(0,n.mix)(e,t,(0,n.smoothstep)(0,.03,i)).toVar(),s=Ht({x:e.div(o)}).mul((0,n.float)(1).sub(Ht({x:r}))),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=Wn(r,Jn(o,e)).toVar(),u=(0,n.float)(1).sub(s).toVar(),d=o.lessThan(e).select((0,n.float)(Mt),(0,n.float)(0)),f=(0,n.float)(Mt).sub(d),p=Kn((0,n.clamp)(a,0,.9999)).toVar(),m=qn(p,o).toVar(),h=(0,n.vec3)(Wn(t,m.x),Wn(t,m.y),Wn(t,m.z)).toVar(),g=(0,n.vec3)(p.x.lessThan(o).select((0,n.float)(Mt),(0,n.float)(0)),p.y.lessThan(o).select((0,n.float)(Mt),(0,n.float)(0)),p.z.lessThan(o).select((0,n.float)(Mt),(0,n.float)(0))),_=(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(nr((0,n.float)(1).mul(_),(0,n.float)(1).mul(v))))),C.mulAssign(b),S.addAssign(C.mul((0,n.float)(2).mul(nr((0,n.float)(2).mul(_),(0,n.float)(2).mul(v))))),l.assign((0,n.max)(S,(0,n.vec3)(0)))}),l}),ir=(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 St({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)})}),ar=(0,n.Fn)(([e,t,r])=>{let i=(0,n.float)(1).sub(e.roughness),a=(0,n.float)(.5).add((0,n.float)(.5).mul(e.metalness)),o=(0,n.min)((0,n.float)(2).div(e.ior),1),s=(0,n.max)(e.sheenColor.r,(0,n.max)(e.sheenColor.g,e.sheenColor.b)),c=kt({F0:Yn(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:i,metalFactor:a,iorFactor:o,maxSheenColor:s}),l=St.wrap(ir(e,r,c)),u=l.diffuse.toVar(),d=l.specular.toVar(),f=l.transmission.toVar(),p=l.clearcoat.toVar();(0,n.If)(t.greaterThan((0,n.int)(2)),()=>{let e=(0,n.float)(1).div((0,n.float)(t).sub(1));d.mulAssign((0,n.float)(.8).add(e.mul(.2))),p.mulAssign((0,n.float)(.7).add(e.mul(.3))),u.mulAssign((0,n.float)(1).add(e.mul(.2)))}),(0,n.If)(r.isMetallic.and(t.lessThan((0,n.int)(3))),()=>{d.assign((0,n.max)(d,.6)),u.mulAssign(.4)}),(0,n.If)(r.isTransmissive,()=>{f.assign((0,n.max)(f,.8)),u.mulAssign(.2),d.mulAssign(.6)}),(0,n.If)(r.hasClearcoat,()=>{p.assign((0,n.max)(p,.4))});let m=u.add(d).add(f).add(p).toVar();return(0,n.If)(m.greaterThan(.001),()=>{let e=(0,n.float)(1).div(m);u.mulAssign(e),d.mulAssign(e),f.mulAssign(e),p.mulAssign(e)}).Else(()=>{u.assign(1),d.assign(0),f.assign(0),p.assign(0)}),Ct({diffuseImportance:u,specularImportance:d,transmissionImportance:f,clearcoatImportance:p})}),or=(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 kt({F0:(0,n.mix)(Yn(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()})}),sr=(0,n.wgslFn)(`
449
+ `),On=(0,n.Fn)(([e,t])=>{let r=Dn({t:t.albedoTransform}).toVar(),i=Dn({t:t.normalTransform}).toVar(),a=Dn({t:t.metalnessTransform}).toVar(),o=Dn({t:t.roughnessTransform}).toVar(),s=Dn({t:t.emissiveTransform}).toVar(),c=Dn({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),S=f.or(m),C=p.or(m);return(0,n.If)(m,()=>{let n=Tn({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(Tn({uv:e,transform:t.albedoTransform})),g.assign(u.select(h,Tn({uv:e,transform:t.normalTransform}))),y.assign(p.select(h,Tn({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(Tn({uv:e,transform:t.bumpTransform}))}),(0,n.If)(f,()=>{_.assign(Tn({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(Tn({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(Tn({uv:e,transform:t.roughnessTransform}))})})}),kt({albedoUV:h,normalUV:g,metalnessUV:_,roughnessUV:v,emissiveUV:y,bumpUV:b,allSameUV:m,normalBumpSameUV:x,metalRoughSameUV:S,albedoEmissiveSameUV:C})}),kn=(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}),An=(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)}),jn=(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}),Mn=(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}),Nn=(0,n.Fn)(([e,t,r])=>{let i=t.emissive.mul(t.emissiveIntensity).toVar();return(0,n.If)(t.emissiveMapIndex.greaterThanEqual((0,n.int)(0)),()=>{let a=(0,n.texture)(e,r.emissiveUV).depth((0,n.int)(t.emissiveMapIndex)).toVar();i.assign(i.mul(a.rgb))}),i}),Pn=(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=En(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=kt.wrap(On(c,s)).toVar();u.assign(kn(e,s,n));let h=An(i,a,s,n);f.assign(h.x),p.assign(h.y);let g=jn(t,l,s,n).toVar();m.assign(Mn(r,g,s,n)),d.assign(Nn(o,s,n))}),Dt({albedo:u,emissive:d,metalness:f,roughness:p,normal:m,hasTextures:h})}),Fn=(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=Tn({uv:r,transform:i});a.assign((0,n.texture)(e,o).depth((0,n.int)(t)).r)}),a}),In=32,Ln=16,Rn=5,zn=1/1024,Bn=8,Vn=y({hitPoint:`vec3`,uv:`vec2`,normal:`vec3`,height:`float`}),Hn=(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=Y(r,d,(0,n.int)(0),(0,n.int)(Bn)).xyz.toVar(),p=Y(r,d,(0,n.int)(1),(0,n.int)(Bn)).xyz,m=Y(r,d,(0,n.int)(2),(0,n.int)(Bn)).xyz,h=Y(r,d,(0,n.int)(6),(0,n.int)(Bn)).toVar(),g=Y(r,d,(0,n.int)(7),(0,n.int)(Bn)),_=h.xy.toVar(),v=h.zw,y=g.xy,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),v.mul(b).sub(y.mul(r)).mul(e)).toVar(),S=g.toVar(),C=(0,n.max)((0,n.abs)(S),.001),w=m.div(C).toVar(),D=(0,n.int)(o.equal((0,n.int)(0)).select((0,n.int)(In),(0,n.int)(Ln))).toVar(),O=w.negate().toVar(),k=w.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)),s=r.mul(S),c=Fn(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)(Rn),type:`int`,condition:`<`},()=>{let o=e.add(r).mul(.5).toVar(),s=t.uv.add(x.mul(o)),c=o.mul(S),l=Fn(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)),v=Fn(i,a.displacementMapIndex,g,a.displacementTransform),y=v.sub(.5).mul(m),b=(0,n.float)(zn),C=v,w=Fn(i,a.displacementMapIndex,g.add((0,n.vec2)(b,0)),a.displacementTransform),T=Fn(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)})})}),Vn({hitPoint:s,uv:c,normal:l,height:u})}),Un=1e-6,Wn=e=>{let t=e.mul(e);return t.mul(t).mul(e)};(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(Wn((0,n.float)(1).sub(t))))});var Gn=(0,n.Fn)(([e,t])=>{let r=(0,n.clamp)(e,0,1);return t.add((0,n.float)(1).sub(t).mul(Wn((0,n.float)(1).sub(r))))}),Kn=(0,n.Fn)(([e,t])=>{let r=(0,n.clamp)(e,0,1);return t.add((0,n.vec3)(1).sub(t).mul(Wn((0,n.float)(1).sub(r))))}),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)(Un)))}),Jn=(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)(Un)),a=r.div(i);return a.mul(a)}),Yn=(0,n.Fn)(([e,t])=>{let r=e.sub(t),i=(0,n.max)(e.add(t),Un),a=r.div(i);return a.mul(a)}),Xn=e=>(0,n.vec3)(Yn(e,(0,n.float)(1))),Zn=(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)(Nt).mul(a).mul(a),It))}),Qn=(0,n.Fn)(([e,t])=>{let r=(0,n.max)(t,Lt),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)(Nt).mul(o).mul(o),It)),100)}),$n=(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),It))}),er=(0,n.Fn)(([e,t,n])=>{let r=$n(e,n);return $n(t,n).mul(r)}),tr=(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),f=(0,n.vec3)(1).add(e.mul((0,n.float)(1).div(d).sub(1)));return Et({compensation:f,E_total:(0,n.clamp)((0,n.max)(e.mul(l).add((0,n.vec3)(u)),(0,n.vec3)(0)).mul(f),(0,n.vec3)(0),(0,n.vec3)(1))})});(0,n.Fn)(([e,t,r])=>Zn(e,r).mul(e).div((0,n.max)((0,n.float)(4).mul(t),It)));var nr=(0,n.Fn)(([e,t,r])=>{let i=Zn(e,r),a=$n(t,r);return i.mul(a).div((0,n.max)(t.mul(4),It))}),rr=(0,n.Fn)(([e,t])=>{let r=(0,n.float)(Ft).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)(Ft).mul(o))).mul((0,n.cos)(a.mul(r).add(t))).mul((0,n.exp)(Ut({x:r}).negate().mul(o))).toVar();return s.x.addAssign((0,n.float)(9747e-17).mul((0,n.sqrt)((0,n.float)(Ft).mul(45282e5))).mul((0,n.cos)((0,n.float)(2239900).mul(r).add(t.x))).mul((0,n.exp)((0,n.float)(-45282e5).mul(Ut({x:r}))))),Ht.mul(s.div(1.0685e-7))}),ir=(0,n.Fn)(([e,t,r,i,a])=>{let o=(0,n.mix)(e,t,(0,n.smoothstep)(0,.03,i)).toVar(),s=Ut({x:e.div(o)}).mul((0,n.float)(1).sub(Ut({x:r}))),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=Gn(r,Yn(o,e)).toVar(),u=(0,n.float)(1).sub(s).toVar(),d=o.lessThan(e).select((0,n.float)(Nt),(0,n.float)(0)),f=(0,n.float)(Nt).sub(d),p=qn((0,n.clamp)(a,0,.9999)).toVar(),m=Jn(p,o).toVar(),h=(0,n.vec3)(Gn(t,m.x),Gn(t,m.y),Gn(t,m.z)).toVar(),g=(0,n.vec3)(p.x.lessThan(o).select((0,n.float)(Nt),(0,n.float)(0)),p.y.lessThan(o).select((0,n.float)(Nt),(0,n.float)(0)),p.z.lessThan(o).select((0,n.float)(Nt),(0,n.float)(0))),_=(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(rr((0,n.float)(1).mul(_),(0,n.float)(1).mul(v))))),C.mulAssign(b),S.addAssign(C.mul((0,n.float)(2).mul(rr((0,n.float)(2).mul(_),(0,n.float)(2).mul(v))))),l.assign((0,n.max)(S,(0,n.vec3)(0)))}),l}),ar=(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 Ct({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)})}),or=(0,n.Fn)(([e,t,r])=>{let i=(0,n.float)(1).sub(e.roughness),a=(0,n.float)(.5).add((0,n.float)(.5).mul(e.metalness)),o=(0,n.min)((0,n.float)(2).div(e.ior),1),s=(0,n.max)(e.sheenColor.r,(0,n.max)(e.sheenColor.g,e.sheenColor.b)),c=At({F0:Xn(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:i,metalFactor:a,iorFactor:o,maxSheenColor:s}),l=Ct.wrap(ar(e,r,c)),u=l.diffuse.toVar(),d=l.specular.toVar(),f=l.transmission.toVar(),p=l.clearcoat.toVar();(0,n.If)(t.greaterThan((0,n.int)(2)),()=>{let e=(0,n.float)(1).div((0,n.float)(t).sub(1));d.mulAssign((0,n.float)(.8).add(e.mul(.2))),p.mulAssign((0,n.float)(.7).add(e.mul(.3))),u.mulAssign((0,n.float)(1).add(e.mul(.2)))}),(0,n.If)(r.isMetallic.and(t.lessThan((0,n.int)(3))),()=>{d.assign((0,n.max)(d,.6)),u.mulAssign(.4)}),(0,n.If)(r.isTransmissive,()=>{f.assign((0,n.max)(f,.8)),u.mulAssign(.2),d.mulAssign(.6)}),(0,n.If)(r.hasClearcoat,()=>{p.assign((0,n.max)(p,.4))});let m=u.add(d).add(f).add(p).toVar();return(0,n.If)(m.greaterThan(.001),()=>{let e=(0,n.float)(1).div(m);u.mulAssign(e),d.mulAssign(e),f.mulAssign(e),p.mulAssign(e)}).Else(()=>{u.assign(1),d.assign(0),f.assign(0),p.assign(0)}),wt({diffuseImportance:u,specularImportance:d,transmissionImportance:f,clearcoatImportance:p})}),sr=(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 At({F0:(0,n.mix)(Xn(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()})}),cr=(0,n.wgslFn)(`
450
450
  fn ImportanceSampleGGX( N: vec3f, roughness: f32, Xi: vec2f ) -> vec3f {
451
451
  let alpha = roughness * roughness;
452
452
  let phi = 6.28318530717958647692f * Xi.x;
@@ -459,7 +459,7 @@
459
459
  let bitangent = cross( N, tangent );
460
460
  return normalize( tangent * H.x + bitangent * H.y + N * H.z );
461
461
  }
462
- `),cr=(0,n.wgslFn)(`
462
+ `),lr=(0,n.wgslFn)(`
463
463
  fn ImportanceSampleCosine( N: vec3f, xi: vec2f ) -> vec3f {
464
464
  let T = normalize( cross( N, N.yzx + vec3f( 0.1f, 0.2f, 0.3f ) ) );
465
465
  let B = cross( N, T );
@@ -469,7 +469,7 @@
469
469
  let localDir = vec3f( sinTheta * cos( phi ), sinTheta * sin( phi ), cosTheta );
470
470
  return normalize( T * localDir.x + B * localDir.y + N * localDir.z );
471
471
  }
472
- `),lr=(0,n.wgslFn)(`
472
+ `),ur=(0,n.wgslFn)(`
473
473
  fn cosineWeightedSample( N: vec3f, xi: vec2f ) -> vec3f {
474
474
  let T = normalize( cross( N, N.yzx + vec3f( 0.1f, 0.2f, 0.3f ) ) );
475
475
  let B = cross( N, T );
@@ -479,7 +479,7 @@
479
479
  let localDir = vec3f( sinTheta * cos( phi ), sinTheta * sin( phi ), cosTheta );
480
480
  return normalize( T * localDir.x + B * localDir.y + N * localDir.z );
481
481
  }
482
- `),ur=(0,n.wgslFn)(`
482
+ `),dr=(0,n.wgslFn)(`
483
483
  fn sampleGGXVNDF( V: vec3f, roughness: f32, Xi: vec2f ) -> vec3f {
484
484
  let alpha = roughness * roughness;
485
485
  // Transform view direction to local space
@@ -500,7 +500,7 @@
500
500
  // Transform the normal back to the ellipsoid configuration
501
501
  return normalize( vec3f( alpha * Nh.x, alpha * Nh.y, max( 0.0f, Nh.z ) ) );
502
502
  }
503
- `),dr=y({direction:`vec3`,throughput:`vec3`,didReflect:`bool`,pathWavelength:`float`}),fr=y({continueRay:`bool`,isTransmissive:`bool`,isAlphaSkip:`bool`,didReflect:`bool`,entering:`bool`,direction:`vec3`,throughput:`vec3`,alpha:`float`,pathWavelength:`float`});y({ior:`float`,attenuationColor:`vec3`,attenuationDistance:`float`,dispersion:`float`});var pr=y({wavelength:`float`,ior:`float`,colorWeight:`vec3`}),mr=y({direction:`vec3`,halfVector:`vec3`,didReflect:`bool`,pdf:`float`,colorWeight:`vec3`,pathWavelength:`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 hr=(0,n.Fn)(([e,t,n])=>{let r=n.div(1e3);return e.add(t.mul(.03).div(r.mul(r)))}),gr=(0,n.Fn)(([e,t,r,i])=>{let a=(0,n.select)(e.lessThan(t),r,i),o=e.sub(t).mul(a);return(0,n.exp)((0,n.float)(-.5).mul(o).mul(o))}),_r=(0,n.Fn)(([e])=>(0,n.vec3)(gr(e,442,.0624,.0374).mul(.362).add(gr(e,599.8,.0264,.0323).mul(1.056)).sub(gr(e,501.1,.049,.0382).mul(.065)),gr(e,568.8,.0213,.0247).mul(.821).add(gr(e,530.9,.0613,.0322).mul(.286)),gr(e,437,.0845,.0278).mul(1.217).add(gr(e,459,.0385,.0725).mul(.681)))),vr=(0,n.Fn)(([e,t,r])=>{let i=(0,n.mix)((0,n.float)(380),(0,n.float)(700),r).toVar(),a=hr(e,t,i),o=_r(i).toVar();return pr({wavelength:i,ior:a,colorWeight:(0,n.max)((0,n.vec3)(o.x.mul(3.2406).sub(o.y.mul(1.5372)).sub(o.z.mul(.4986)),o.x.mul(-.9689).add(o.y.mul(1.8758)).add(o.z.mul(.0415)),o.x.mul(.0557).sub(o.y.mul(.204)).add(o.z.mul(1.057))),(0,n.vec3)(0)).mul((0,n.vec3)(1.819,2.773,2.928))})}),yr=(0,n.wgslFn)(`
503
+ `),fr=y({direction:`vec3`,throughput:`vec3`,didReflect:`bool`,pathWavelength:`float`}),pr=y({continueRay:`bool`,isTransmissive:`bool`,isAlphaSkip:`bool`,didReflect:`bool`,entering:`bool`,direction:`vec3`,throughput:`vec3`,alpha:`float`,pathWavelength:`float`});y({ior:`float`,attenuationColor:`vec3`,attenuationDistance:`float`,dispersion:`float`});var mr=y({wavelength:`float`,ior:`float`,colorWeight:`vec3`}),hr=y({direction:`vec3`,halfVector:`vec3`,didReflect:`bool`,pdf:`float`,colorWeight:`vec3`,pathWavelength:`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 gr=(0,n.Fn)(([e,t,n])=>{let r=n.div(1e3);return e.add(t.mul(.03).div(r.mul(r)))}),_r=(0,n.Fn)(([e,t,r,i])=>{let a=(0,n.select)(e.lessThan(t),r,i),o=e.sub(t).mul(a);return(0,n.exp)((0,n.float)(-.5).mul(o).mul(o))}),vr=(0,n.Fn)(([e])=>(0,n.vec3)(_r(e,442,.0624,.0374).mul(.362).add(_r(e,599.8,.0264,.0323).mul(1.056)).sub(_r(e,501.1,.049,.0382).mul(.065)),_r(e,568.8,.0213,.0247).mul(.821).add(_r(e,530.9,.0613,.0322).mul(.286)),_r(e,437,.0845,.0278).mul(1.217).add(_r(e,459,.0385,.0725).mul(.681)))),yr=(0,n.Fn)(([e,t,r])=>{let i=(0,n.mix)((0,n.float)(380),(0,n.float)(700),r).toVar(),a=gr(e,t,i),o=vr(i).toVar();return mr({wavelength:i,ior:a,colorWeight:(0,n.max)((0,n.vec3)(o.x.mul(3.2406).sub(o.y.mul(1.5372)).sub(o.z.mul(.4986)),o.x.mul(-.9689).add(o.y.mul(1.8758)).add(o.z.mul(.0415)),o.x.mul(.0557).sub(o.y.mul(.204)).add(o.z.mul(1.057))),(0,n.vec3)(0)).mul((0,n.vec3)(1.819,2.773,2.928))})}),br=(0,n.wgslFn)(`
504
504
  fn calculateBeerLawAbsorption( attenuationColor: vec3f, attenuationDistance: f32, thickness: f32 ) -> vec3f {
505
505
  if ( attenuationDistance <= 0.0f ) { return vec3f( 1.0f ); }
506
506
  // Convert RGB attenuation color to absorption coefficients
@@ -508,11 +508,11 @@
508
508
  // Apply Beer's law
509
509
  return exp( -absorption * thickness );
510
510
  }
511
- `);(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=Wn(s,Jn(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=yr({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 br=(0,n.Fn)(([e,t,r,i,a,o,s,c,l])=>{let u=mr({direction:(0,n.vec3)(0),halfVector:(0,n.vec3)(0),didReflect:!1,pdf:(0,n.float)(0),colorWeight:(0,n.vec3)(1),pathWavelength:l}).toVar();return(0,n.If)(i.lessThanEqual(.05).and(o.greaterThan(0)),()=>{u.halfVector.assign(t),u.didReflect.assign(!1);let i=r,s=(0,n.select)(a,(0,n.float)(1).div(i),i).toVar();(0,n.If)(l.greaterThan(0),()=>{let e=hr(r,o,l);s.assign((0,n.select)(a,(0,n.float)(1).div(e),e))}).Else(()=>{let e=pr.wrap(vr(r,o,N(c)));s.assign((0,n.select)(a,(0,n.float)(1).div(e.ior),e.ior)),u.colorWeight.assign(e.colorWeight),u.pathWavelength.assign(e.wavelength)});let d=(0,n.refract)(e.negate(),t,s).toVar();(0,n.If)((0,n.dot)(d,d).lessThan(.001),()=>{u.direction.assign((0,n.reflect)(e.negate(),t)),u.didReflect.assign(!0),u.pdf.assign(1)}).Else(()=>{u.direction.assign(d),u.pdf.assign(1)})}).Else(()=>{let d=(0,n.max)(It,i),f=sr({N:t,roughness:d,Xi:s}).toVar();u.halfVector.assign(f);let p=(0,n.select)(a,(0,n.float)(1).div(r),r).toVar();(0,n.If)(o.greaterThan(0),()=>{(0,n.If)(l.greaterThan(0),()=>{let e=hr(r,o,l);p.assign((0,n.select)(a,(0,n.float)(1).div(e),e))}).Else(()=>{let e=pr.wrap(vr(r,o,N(c)));p.assign((0,n.select)(a,(0,n.float)(1).div(e.ior),e.ior)),u.colorWeight.assign(e.colorWeight),u.pathWavelength.assign(e.wavelength)})});let m=(0,n.clamp)((0,n.dot)(f,e),.001,1).toVar(),h=(0,n.clamp)((0,n.dot)(t,f),.001,1).toVar(),g=Xn(h,d).toVar(),_=(0,n.refract)(e.negate(),f,p).toVar();(0,n.If)((0,n.dot)(_,_).lessThan(.001),()=>{u.direction.assign((0,n.reflect)(e.negate(),f)),u.didReflect.assign(!0),u.pdf.assign(g.mul(h).div((0,n.max)((0,n.float)(4).mul(m),Rt)))}).Else(()=>{u.direction.assign(_),u.didReflect.assign(!1);let e=(0,n.clamp)((0,n.dot)(f,_),.001,1),t=m.add(p.mul(e)),r=(0,n.abs)(e).div(t.mul(t));u.pdf.assign(g.mul(h).mul(r))})}),u}),xr=(0,n.Fn)(([e,t,r,i,a,o,s,c])=>{let l=dr({direction:(0,n.vec3)(0),throughput:(0,n.vec3)(1),didReflect:!1,pathWavelength:c}).toVar(),u=(0,n.select)(i,t,t.negate()).toVar(),d=e.negate().toVar(),f=(0,n.select)(i,o,r.ior).toVar(),p=(0,n.select)(i,r.ior,s).toVar(),m=(0,n.abs)((0,n.dot)(u,e)),h=f.mul(f).div(p.mul(p)).mul((0,n.float)(1).sub(m.mul(m))).greaterThan(1).toVar(),g=Jn(p,f),_=(0,n.select)(h,(0,n.float)(1),Wn(m,g)).toVar(),v=(0,n.float)(0).toVar();(0,n.If)(h,()=>{v.assign(1)}).Else(()=>{let e=_,t=(0,n.float)(.95);v.assign((0,n.mix)(e,t,r.metalness))}),v.assign((0,n.clamp)(v,.05,.95));let y=h.or(N(a).lessThan(v)).toVar();l.didReflect.assign(y);let b=(0,n.vec2)(N(a).toVar(),N(a).toVar());return(0,n.If)(y,()=>{(0,n.If)(r.roughness.greaterThan(.05),()=>{let e=mr.wrap(br(d,u,r.ior,r.roughness,i,(0,n.float)(0),b,a,(0,n.float)(0)));l.direction.assign(e.direction)}).Else(()=>{l.direction.assign((0,n.reflect)(e,u))}),l.throughput.assign(r.color.xyz.mul(_).div((0,n.max)(v,.05)))}).Else(()=>{(0,n.If)(r.roughness.greaterThan(.05).or(r.dispersion.greaterThan(0)),()=>{let e=mr.wrap(br(d,u,r.ior,r.roughness,i,r.dispersion,b,a,c));l.pathWavelength.assign(e.pathWavelength),(0,n.If)(e.didReflect,()=>{l.direction.assign(e.direction),l.didReflect.assign(!0),l.throughput.assign(r.color.xyz.div((0,n.max)((0,n.float)(1).sub(v),.05)))}).Else(()=>{l.direction.assign(e.direction),l.throughput.assign(e.colorWeight)})}).Else(()=>{l.direction.assign((0,n.refract)(e,u,f.div(p))),l.throughput.assign((0,n.vec3)(1))}),(0,n.If)(l.didReflect.not(),()=>{l.throughput.mulAssign(r.color.xyz),l.throughput.mulAssign(f.mul(f).div((0,n.max)(p.mul(p),Ft))),l.throughput.mulAssign((0,n.float)(1).sub(_).div((0,n.max)((0,n.float)(1).sub(v),.05)))})}),l}),Sr=(0,n.Fn)(([e,t,r,i,a,o,s,c])=>{let l=fr({continueRay:!1,isTransmissive:!1,isAlphaSkip:!1,didReflect:!1,entering:!1,direction:e.direction,throughput:(0,n.vec3)(1),alpha:(0,n.float)(1),pathWavelength:c}).toVar();return(0,n.If)(r.alphaMode.equal((0,n.int)(0)).and(r.transmission.lessThanEqual(0)),()=>{}).Else(()=>{let u=N(i),d=N(i),f=A({state:i}),p=(0,n.bool)(!1).toVar();(0,n.If)(r.alphaMode.equal((0,n.int)(2)),()=>{let t=r.color.a.mul(r.opacity);(0,n.If)(u.greaterThan(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),p.assign(!0)}).Else(()=>{l.alpha.assign(t)})}),(0,n.If)(p.not().and(r.alphaMode.equal((0,n.int)(1))),()=>{let t=(0,n.select)(r.alphaTest.greaterThan(0),r.alphaTest,(0,n.float)(.5));(0,n.If)(r.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),p.assign(!0)}).Else(()=>{l.alpha.assign(1)})}),(0,n.If)(p.not().and(r.transmission.greaterThan(0)).and(a.greaterThan((0,n.int)(0))),()=>{(0,n.If)(d.lessThan(r.transmission),()=>{let i=(0,n.dot)(e.direction,t).lessThan(0),a=dr.wrap(xr(e.direction,t,r,i,f,o,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(i),l.alpha.assign((0,n.float)(1).sub(r.transmission)),l.pathWavelength.assign(a.pathWavelength)})})}),l}),Cr=(0,n.Fn)(([e,t])=>{let r=(0,n.vec3)(0).toVar();return(0,n.If)(e.roughness.greaterThan(.98).and(e.metalness.lessThan(.02)).and(e.transmission.equal(0)).and(e.clearcoat.equal(0)).and(e.iridescence.equal(0)),()=>{r.assign(e.color.rgb.mul((0,n.float)(1).sub(e.metalness)).mul(Nt))}).Else(()=>{let i=(0,n.clamp)((0,n.mix)(Yn(e.ior).mul(e.specularColor),e.color.rgb,e.metalness).mul(e.specularIntensity),(0,n.vec3)(0),(0,n.vec3)(1)).toVar(),a=e.color.rgb.toVar();(0,n.If)(e.dispersion.greaterThan(0).and(e.transmission.greaterThan(.5)),()=>{let t=(0,n.clamp)(e.dispersion.mul(.1),0,.8),r=(0,n.max)((0,n.max)(a.r,a.g),a.b),i=(0,n.min)((0,n.min)(a.r,a.g),a.b);(0,n.If)(r.greaterThan(i),()=>{let e=a.sub(i).div(r.sub(i));a.assign((0,n.mix)(a,e,t.mul(.3)))})}),(0,n.If)(e.iridescence.greaterThan(0),()=>{let r=e.iridescenceThicknessRange.y,a=rr((0,n.float)(1),e.iridescenceIOR,t.VoH,r,i);i.assign((0,n.mix)(i,a,e.iridescence))});let o=Xn(t.NoH,e.roughness),s=$n(t.NoV,t.NoL,e.roughness),c=Gn(t.VoH,i),l=o.mul(s).mul(c).div((0,n.max)((0,n.float)(4).mul(t.NoV).mul(t.NoL),Ft)),u=Tt.wrap(er(i,t.NoV,e.roughness)),d=l.mul(u.compensation),f=(0,n.vec3)(1).sub(u.E_total).mul((0,n.float)(1).sub(e.metalness)).mul(a).mul(Nt).add(d).toVar();(0,n.If)(e.sheen.greaterThan(0),()=>{let i=Zn(t.NoH,e.sheenRoughness),a=e.sheenColor.mul(e.sheen).mul(i).mul(t.NoL),o=(0,n.float)(1).sub(e.sheenRoughness).mul(.5).add(.25),s=(0,n.clamp)(e.sheenColor.mul(e.sheen).mul(o),(0,n.vec3)(0),(0,n.vec3)(1)),c=(0,n.vec3)(1).sub(s);r.assign(f.mul(c).add(a))}).Else(()=>{r.assign(f)})}),r}),wr=(0,n.Fn)(([e,t,n,r])=>Cr(r,wt.wrap(Jt(n,e,t)))),Tr=(0,n.Fn)(([e,t])=>{let r=(0,n.clamp)((0,n.mix)(Yn(t.ior).mul(t.specularColor),t.color.rgb,t.metalness).mul(t.specularIntensity),(0,n.vec3)(0),(0,n.vec3)(1)).toVar(),i=Xn(e.NoH,t.roughness),a=$n(e.NoV,e.NoL,t.roughness),o=Gn(e.VoH,r),s=i.mul(a).mul(o).div((0,n.max)((0,n.float)(4).mul(e.NoV).mul(e.NoL),Ft)),c=Tt.wrap(er(r,e.NoV,t.roughness)),l=s.mul(c.compensation),u=(0,n.vec3)(1).sub(c.E_total).mul((0,n.float)(1).sub(t.metalness)).mul(t.color.rgb).div(Mt).add(l),d=(0,n.max)(t.clearcoatRoughness,Lt),f=Xn(e.NoH,d),p=$n(e.NoV,e.NoL,d),m=Wn(e.VoH,(0,n.float)(.04)),h=f.mul(p).mul(m).div((0,n.max)((0,n.float)(4).mul(e.NoV).mul(e.NoL),Ft)),g=(0,n.float)(1).sub(t.clearcoat.mul(m).mul((0,n.float)(2).sub(m)));return u.mul(g).add((0,n.vec3)(h).mul(t.clearcoat))}),Er=y({brdf:`vec3`,L:`vec3`,pdf:`float`}),Dr=(0,n.Fn)(([e,t,r,i,a])=>{let o=t.normal,s=e.direction.negate(),c=(0,n.max)(r.clearcoatRoughness,Lt),l=(0,n.max)(r.roughness,Lt),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(sr({N:o,roughness:c,Xi:i})),h.assign((0,n.reflect)(s.negate(),g))}).ElseIf(m.lessThan(d.add(u)),()=>{g.assign(sr({N:o,roughness:l,Xi:i})),h.assign((0,n.reflect)(s.negate(),g))}).Else(()=>{h.assign(cr({N:o,xi:i})),g.assign((0,n.normalize)(s.add(h)))});let _=wt.wrap(Jt(o,s,h)),v=Xn(_.NoH,c).mul(_.NoH).div((0,n.float)(4).mul(_.VoH)).mul(d),y=Xn(_.NoH,l).mul(_.NoH).div((0,n.float)(4).mul(_.VoH)).mul(u),b=_.NoL.div(Mt).mul(f),x=(0,n.max)(v.add(y).add(b),.001);return Er({brdf:Tr(_,r),L:h,pdf:x})}),Or=y({direction:`vec3`,color:`vec3`,intensity:`float`,angle:`float`,goboIndex:`int`,goboIntensity:`float`,goboScale:`float`}),kr=y({position:`vec3`,u:`vec3`,v:`vec3`,color:`vec3`,intensity:`float`,normal:`vec3`,area:`float`}),Ar=y({position:`vec3`,color:`vec3`,intensity:`float`,distance:`float`,decay:`float`}),jr=y({position:`vec3`,direction:`vec3`,color:`vec3`,intensity:`float`,angle:`float`,penumbra:`float`,distance:`float`,decay:`float`,goboIndex:`int`,goboIntensity:`float`,iesIndex:`int`,iesIntensity:`float`}),Mr=y({direction:`vec3`,emission:`vec3`,pdf:`float`,distance:`float`,lightType:`int`,valid:`bool`}),Nr=y({direction:`vec3`,throughput:`vec3`,misWeight:`float`,pdf:`float`,combinedPdf:`float`}),Pr=(0,n.Fn)(([e,t])=>{let r=t.mul(12);return Or({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)),goboIndex:(0,n.int)(e.element(r.add(8))),goboIntensity:e.element(r.add(9)),goboScale:e.element(r.add(10))})}),Fr=(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 kr({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)})}),Ir=(0,n.Fn)(([e,t])=>{let r=t.mul(9);return Ar({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))})}),Lr=(0,n.Fn)(([e,t])=>{let r=t.mul(20);return jr({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)),goboIndex:(0,n.int)(e.element(r.add(14))),goboIntensity:e.element(r.add(15)),iesIndex:(0,n.int)(e.element(r.add(16))),iesIntensity:e.element(r.add(17))})}),Rr=(0,n.wgslFn)(`
511
+ `);(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=Gn(s,Yn(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=br({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 xr=(0,n.Fn)(([e,t,r,i,a,o,s,c,l])=>{let u=hr({direction:(0,n.vec3)(0),halfVector:(0,n.vec3)(0),didReflect:!1,pdf:(0,n.float)(0),colorWeight:(0,n.vec3)(1),pathWavelength:l}).toVar();return(0,n.If)(i.lessThanEqual(.05).and(o.greaterThan(0)),()=>{u.halfVector.assign(t),u.didReflect.assign(!1);let i=r,s=(0,n.select)(a,(0,n.float)(1).div(i),i).toVar();(0,n.If)(l.greaterThan(0),()=>{let e=gr(r,o,l);s.assign((0,n.select)(a,(0,n.float)(1).div(e),e))}).Else(()=>{let e=mr.wrap(yr(r,o,N(c)));s.assign((0,n.select)(a,(0,n.float)(1).div(e.ior),e.ior)),u.colorWeight.assign(e.colorWeight),u.pathWavelength.assign(e.wavelength)});let d=(0,n.refract)(e.negate(),t,s).toVar();(0,n.If)((0,n.dot)(d,d).lessThan(.001),()=>{u.direction.assign((0,n.reflect)(e.negate(),t)),u.didReflect.assign(!0),u.pdf.assign(1)}).Else(()=>{u.direction.assign(d),u.pdf.assign(1)})}).Else(()=>{let d=(0,n.max)(Lt,i),f=cr({N:t,roughness:d,Xi:s}).toVar();u.halfVector.assign(f);let p=(0,n.select)(a,(0,n.float)(1).div(r),r).toVar();(0,n.If)(o.greaterThan(0),()=>{(0,n.If)(l.greaterThan(0),()=>{let e=gr(r,o,l);p.assign((0,n.select)(a,(0,n.float)(1).div(e),e))}).Else(()=>{let e=mr.wrap(yr(r,o,N(c)));p.assign((0,n.select)(a,(0,n.float)(1).div(e.ior),e.ior)),u.colorWeight.assign(e.colorWeight),u.pathWavelength.assign(e.wavelength)})});let m=(0,n.clamp)((0,n.dot)(f,e),.001,1).toVar(),h=(0,n.clamp)((0,n.dot)(t,f),.001,1).toVar(),g=Zn(h,d).toVar(),_=(0,n.refract)(e.negate(),f,p).toVar();(0,n.If)((0,n.dot)(_,_).lessThan(.001),()=>{u.direction.assign((0,n.reflect)(e.negate(),f)),u.didReflect.assign(!0),u.pdf.assign(g.mul(h).div((0,n.max)((0,n.float)(4).mul(m),zt)))}).Else(()=>{u.direction.assign(_),u.didReflect.assign(!1);let e=(0,n.clamp)((0,n.dot)(f,_),.001,1),t=m.add(p.mul(e)),r=(0,n.abs)(e).div(t.mul(t));u.pdf.assign(g.mul(h).mul(r))})}),u}),Sr=(0,n.Fn)(([e,t,r,i,a,o,s,c])=>{let l=fr({direction:(0,n.vec3)(0),throughput:(0,n.vec3)(1),didReflect:!1,pathWavelength:c}).toVar(),u=(0,n.select)(i,t,t.negate()).toVar(),d=e.negate().toVar(),f=(0,n.select)(i,o,r.ior).toVar(),p=(0,n.select)(i,r.ior,s).toVar(),m=(0,n.abs)((0,n.dot)(u,e)),h=f.mul(f).div(p.mul(p)).mul((0,n.float)(1).sub(m.mul(m))).greaterThan(1).toVar(),g=Yn(p,f),_=(0,n.select)(h,(0,n.float)(1),Gn(m,g)).toVar(),v=(0,n.float)(0).toVar();(0,n.If)(h,()=>{v.assign(1)}).Else(()=>{let e=_,t=(0,n.float)(.95);v.assign((0,n.mix)(e,t,r.metalness))}),v.assign((0,n.clamp)(v,.05,.95));let y=h.or(N(a).lessThan(v)).toVar();l.didReflect.assign(y);let b=(0,n.vec2)(N(a).toVar(),N(a).toVar());return(0,n.If)(y,()=>{(0,n.If)(r.roughness.greaterThan(.05),()=>{let e=hr.wrap(xr(d,u,r.ior,r.roughness,i,(0,n.float)(0),b,a,(0,n.float)(0)));l.direction.assign(e.direction)}).Else(()=>{l.direction.assign((0,n.reflect)(e,u))}),l.throughput.assign(r.color.xyz.mul(_).div((0,n.max)(v,.05)))}).Else(()=>{(0,n.If)(r.roughness.greaterThan(.05).or(r.dispersion.greaterThan(0)),()=>{let e=hr.wrap(xr(d,u,r.ior,r.roughness,i,r.dispersion,b,a,c));l.pathWavelength.assign(e.pathWavelength),(0,n.If)(e.didReflect,()=>{l.direction.assign(e.direction),l.didReflect.assign(!0),l.throughput.assign(r.color.xyz.div((0,n.max)((0,n.float)(1).sub(v),.05)))}).Else(()=>{l.direction.assign(e.direction),l.throughput.assign(e.colorWeight)})}).Else(()=>{l.direction.assign((0,n.refract)(e,u,f.div(p))),l.throughput.assign((0,n.vec3)(1))}),(0,n.If)(l.didReflect.not(),()=>{l.throughput.mulAssign(r.color.xyz),l.throughput.mulAssign(f.mul(f).div((0,n.max)(p.mul(p),It))),l.throughput.mulAssign((0,n.float)(1).sub(_).div((0,n.max)((0,n.float)(1).sub(v),.05)))})}),l}),Cr=(0,n.Fn)(([e,t,r,i,a,o,s,c])=>{let l=pr({continueRay:!1,isTransmissive:!1,isAlphaSkip:!1,didReflect:!1,entering:!1,direction:e.direction,throughput:(0,n.vec3)(1),alpha:(0,n.float)(1),pathWavelength:c}).toVar();return(0,n.If)(r.alphaMode.equal((0,n.int)(0)).and(r.transmission.lessThanEqual(0)),()=>{}).Else(()=>{let u=N(i),d=N(i),f=A({state:i}),p=(0,n.bool)(!1).toVar();(0,n.If)(r.alphaMode.equal((0,n.int)(2)),()=>{let t=r.color.a.mul(r.opacity);(0,n.If)(u.greaterThan(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),p.assign(!0)}).Else(()=>{l.alpha.assign(t)})}),(0,n.If)(p.not().and(r.alphaMode.equal((0,n.int)(1))),()=>{let t=(0,n.select)(r.alphaTest.greaterThan(0),r.alphaTest,(0,n.float)(.5));(0,n.If)(r.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),p.assign(!0)}).Else(()=>{l.alpha.assign(1)})}),(0,n.If)(p.not().and(r.transmission.greaterThan(0)).and(a.greaterThan((0,n.int)(0))),()=>{(0,n.If)(d.lessThan(r.transmission),()=>{let i=(0,n.dot)(e.direction,t).lessThan(0),a=fr.wrap(Sr(e.direction,t,r,i,f,o,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(i),l.alpha.assign((0,n.float)(1).sub(r.transmission)),l.pathWavelength.assign(a.pathWavelength)})})}),l}),wr=(0,n.Fn)(([e,t])=>{let r=(0,n.vec3)(0).toVar();return(0,n.If)(e.roughness.greaterThan(.98).and(e.metalness.lessThan(.02)).and(e.transmission.equal(0)).and(e.clearcoat.equal(0)).and(e.iridescence.equal(0)),()=>{r.assign(e.color.rgb.mul((0,n.float)(1).sub(e.metalness)).mul(Pt))}).Else(()=>{let i=(0,n.clamp)((0,n.mix)(Xn(e.ior).mul(e.specularColor),e.color.rgb,e.metalness).mul(e.specularIntensity),(0,n.vec3)(0),(0,n.vec3)(1)).toVar(),a=e.color.rgb.toVar();(0,n.If)(e.dispersion.greaterThan(0).and(e.transmission.greaterThan(.5)),()=>{let t=(0,n.clamp)(e.dispersion.mul(.1),0,.8),r=(0,n.max)((0,n.max)(a.r,a.g),a.b),i=(0,n.min)((0,n.min)(a.r,a.g),a.b);(0,n.If)(r.greaterThan(i),()=>{let e=a.sub(i).div(r.sub(i));a.assign((0,n.mix)(a,e,t.mul(.3)))})}),(0,n.If)(e.iridescence.greaterThan(0),()=>{let r=e.iridescenceThicknessRange.y,a=ir((0,n.float)(1),e.iridescenceIOR,t.VoH,r,i);i.assign((0,n.mix)(i,a,e.iridescence))});let o=Zn(t.NoH,e.roughness),s=er(t.NoV,t.NoL,e.roughness),c=Kn(t.VoH,i),l=o.mul(s).mul(c).div((0,n.max)((0,n.float)(4).mul(t.NoV).mul(t.NoL),It)),u=Et.wrap(tr(i,t.NoV,e.roughness)),d=l.mul(u.compensation),f=(0,n.vec3)(1).sub(u.E_total).mul((0,n.float)(1).sub(e.metalness)).mul(a).mul(Pt).add(d).toVar();(0,n.If)(e.sheen.greaterThan(0),()=>{let i=Qn(t.NoH,e.sheenRoughness),a=e.sheenColor.mul(e.sheen).mul(i).mul(t.NoL),o=(0,n.float)(1).sub(e.sheenRoughness).mul(.5).add(.25),s=(0,n.clamp)(e.sheenColor.mul(e.sheen).mul(o),(0,n.vec3)(0),(0,n.vec3)(1)),c=(0,n.vec3)(1).sub(s);r.assign(f.mul(c).add(a))}).Else(()=>{r.assign(f)})}),r}),Tr=(0,n.Fn)(([e,t,n,r])=>wr(r,Tt.wrap(Yt(n,e,t)))),Er=(0,n.Fn)(([e,t])=>{let r=(0,n.clamp)((0,n.mix)(Xn(t.ior).mul(t.specularColor),t.color.rgb,t.metalness).mul(t.specularIntensity),(0,n.vec3)(0),(0,n.vec3)(1)).toVar(),i=Zn(e.NoH,t.roughness),a=er(e.NoV,e.NoL,t.roughness),o=Kn(e.VoH,r),s=i.mul(a).mul(o).div((0,n.max)((0,n.float)(4).mul(e.NoV).mul(e.NoL),It)),c=Et.wrap(tr(r,e.NoV,t.roughness)),l=s.mul(c.compensation),u=(0,n.vec3)(1).sub(c.E_total).mul((0,n.float)(1).sub(t.metalness)).mul(t.color.rgb).div(Nt).add(l),d=(0,n.max)(t.clearcoatRoughness,Rt),f=Zn(e.NoH,d),p=er(e.NoV,e.NoL,d),m=Gn(e.VoH,(0,n.float)(.04)),h=f.mul(p).mul(m).div((0,n.max)((0,n.float)(4).mul(e.NoV).mul(e.NoL),It)),g=(0,n.float)(1).sub(t.clearcoat.mul(m).mul((0,n.float)(2).sub(m)));return u.mul(g).add((0,n.vec3)(h).mul(t.clearcoat))}),Dr=y({brdf:`vec3`,L:`vec3`,pdf:`float`}),Or=(0,n.Fn)(([e,t,r,i,a])=>{let o=t.normal,s=e.direction.negate(),c=(0,n.max)(r.clearcoatRoughness,Rt),l=(0,n.max)(r.roughness,Rt),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(cr({N:o,roughness:c,Xi:i})),h.assign((0,n.reflect)(s.negate(),g))}).ElseIf(m.lessThan(d.add(u)),()=>{g.assign(cr({N:o,roughness:l,Xi:i})),h.assign((0,n.reflect)(s.negate(),g))}).Else(()=>{h.assign(lr({N:o,xi:i})),g.assign((0,n.normalize)(s.add(h)))});let _=Tt.wrap(Yt(o,s,h)),v=Zn(_.NoH,c).mul(_.NoH).div((0,n.float)(4).mul(_.VoH)).mul(d),y=Zn(_.NoH,l).mul(_.NoH).div((0,n.float)(4).mul(_.VoH)).mul(u),b=_.NoL.div(Nt).mul(f),x=(0,n.max)(v.add(y).add(b),.001);return Dr({brdf:Er(_,r),L:h,pdf:x})}),kr=y({direction:`vec3`,color:`vec3`,intensity:`float`,angle:`float`,goboIndex:`int`,goboIntensity:`float`,goboScale:`float`}),Ar=y({position:`vec3`,u:`vec3`,v:`vec3`,color:`vec3`,intensity:`float`,normal:`vec3`,area:`float`}),jr=y({position:`vec3`,color:`vec3`,intensity:`float`,distance:`float`,decay:`float`}),Mr=y({position:`vec3`,direction:`vec3`,color:`vec3`,intensity:`float`,angle:`float`,penumbra:`float`,distance:`float`,decay:`float`,goboIndex:`int`,goboIntensity:`float`,iesIndex:`int`,iesIntensity:`float`}),Nr=y({direction:`vec3`,emission:`vec3`,pdf:`float`,distance:`float`,lightType:`int`,valid:`bool`}),Pr=y({direction:`vec3`,throughput:`vec3`,misWeight:`float`,pdf:`float`,combinedPdf:`float`}),Fr=(0,n.Fn)(([e,t])=>{let r=t.mul(12);return kr({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)),goboIndex:(0,n.int)(e.element(r.add(8))),goboIntensity:e.element(r.add(9)),goboScale:e.element(r.add(10))})}),Ir=(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 Ar({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)})}),Lr=(0,n.Fn)(([e,t])=>{let r=t.mul(9);return jr({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))})}),Rr=(0,n.Fn)(([e,t])=>{let r=t.mul(20);return Mr({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)),goboIndex:(0,n.int)(e.element(r.add(14))),goboIntensity:e.element(r.add(15)),iesIndex:(0,n.int)(e.element(r.add(16))),iesIntensity:e.element(r.add(17))})}),zr=(0,n.wgslFn)(`
512
512
  fn isDirectionValid( direction: vec3f, surfaceNormal: vec3f ) -> bool {
513
513
  return dot( direction, surfaceNormal ) > 0.0f;
514
514
  }
515
- `),zr=(0,n.wgslFn)(`
515
+ `),Br=(0,n.wgslFn)(`
516
516
  fn getDistanceAttenuation( lightDistance: f32, cutoffDistance: f32, decayExponent: f32 ) -> f32 {
517
517
  var distanceFalloff = 1.0f / max( pow( lightDistance, decayExponent ), 0.01f );
518
518
  if ( cutoffDistance > 0.0f ) {
@@ -524,37 +524,37 @@
524
524
  }
525
525
  return distanceFalloff;
526
526
  }
527
- `),Br=(0,n.wgslFn)(`
527
+ `),Vr=(0,n.wgslFn)(`
528
528
  fn getSpotAttenuation( coneCosine: f32, penumbraCosine: f32, angleCosine: f32 ) -> f32 {
529
529
  return smoothstep( coneCosine, penumbraCosine, angleCosine );
530
530
  }
531
- `),Vr=null;function Hr(e){Vr=e}var Ur=(0,n.Fn)(([e,t])=>{let r=(0,n.float)(1).toVar();return(0,n.If)(e.goboIndex.greaterThanEqual((0,n.int)(0)),()=>{let i=e.direction.toVar(),a=t.negate().toVar(),o=(0,n.dot)(a,i).toVar();(0,n.If)(o.greaterThan(0),()=>{let t=(0,n.normalize)((0,n.cross)((0,n.select)((0,n.abs)(i.z).lessThan(.999),(0,n.vec3)(0,0,1),(0,n.vec3)(1,0,0)),i)).toVar(),s=(0,n.cross)(i,t),c=(0,n.float)(1).div(o).toVar(),l=(0,n.dot)(a,t).mul(c),u=(0,n.dot)(a,s).mul(c),d=(0,n.float)(.5).div((0,n.max)((0,n.tan)(e.angle),(0,n.float)(1e-4))).toVar(),f=(0,n.clamp)(l.mul(d).add(.5),(0,n.float)(0),(0,n.float)(1)),p=(0,n.clamp)(u.mul(d).add(.5),(0,n.float)(0),(0,n.float)(1));if(Vr){let t=(0,n.texture)(Vr,(0,n.vec2)(f,p)).depth(e.goboIndex),i=(0,n.min)(t.r,t.a),a=(0,n.select)(e.goboIntensity.lessThan(0),(0,n.float)(1).sub(i),i),o=(0,n.clamp)((0,n.abs)(e.goboIntensity),(0,n.float)(0),(0,n.float)(1));r.assign((0,n.mix)((0,n.float)(1),a,o))}}).Else(()=>{r.assign(0)})}),r}),Wr=(0,n.Fn)(([e,t])=>{let r=(0,n.float)(1).toVar();return(0,n.If)(e.goboIndex.greaterThanEqual((0,n.int)(0)),()=>{let i=e.direction.toVar(),a=(0,n.normalize)((0,n.cross)((0,n.select)((0,n.abs)(i.z).lessThan(.999),(0,n.vec3)(0,0,1),(0,n.vec3)(1,0,0)),i)).toVar(),o=(0,n.cross)(i,a),s=(0,n.float)(1).div((0,n.max)(e.goboScale,(0,n.float)(1e-4))).toVar(),c=(0,n.dot)(t,a).mul(s).add(.5).toVar(),l=(0,n.dot)(t,o).mul(s).add(.5).toVar(),u=c.sub(c.floor()),d=l.sub(l.floor());if(Vr){let t=(0,n.texture)(Vr,(0,n.vec2)(u,d)).depth(e.goboIndex),i=(0,n.min)(t.r,t.a),a=(0,n.select)(e.goboIntensity.lessThan(0),(0,n.float)(1).sub(i),i),o=(0,n.clamp)((0,n.abs)(e.goboIntensity),(0,n.float)(0),(0,n.float)(1));r.assign((0,n.mix)((0,n.float)(1),a,o))}}),r}),Gr=null;function Kr(e){Gr=e}var qr=(0,n.Fn)(([e,t])=>{let r=(0,n.float)(1).toVar();return(0,n.If)(e.iesIndex.greaterThanEqual((0,n.int)(0)),()=>{let i=e.direction.toVar(),a=t.negate().toVar(),o=(0,n.clamp)((0,n.acos)((0,n.clamp)((0,n.dot)(a,i),(0,n.float)(-1),(0,n.float)(1))).div((0,n.float)(Math.PI)),(0,n.float)(0),(0,n.float)(1)),s=(0,n.normalize)((0,n.cross)((0,n.select)((0,n.abs)(i.z).lessThan(.999),(0,n.vec3)(0,0,1),(0,n.vec3)(1,0,0)),i)).toVar(),c=(0,n.cross)(i,s),l=(0,n.dot)(a,s),u=(0,n.atan)((0,n.dot)(a,c),l).div((0,n.float)(2*Math.PI)).add(.5);if(Gr){let t=(0,n.texture)(Gr,(0,n.vec2)(u,o)).depth(e.iesIndex).r,i=(0,n.clamp)(e.iesIntensity,(0,n.float)(0),(0,n.float)(1));r.assign((0,n.mix)((0,n.float)(1),t,i))}}),r}),Jr=(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}),Yr=null,Xr=null;function Zr(e){Yr=e}function Qr(e){Xr=e}var $r=(0,n.Fn)(([e,t,r,i,a,o,s])=>{let c=(0,n.float)(1).toVar(),l=e.toVar(),u=(0,n.float)(r).toVar();return(0,n.Loop)({start:(0,n.int)(0),end:(0,n.int)(8)},()=>{let e=_t({origin:l,direction:t}),r=bt.wrap(i(e,a,o,u));(0,n.If)(r.didHit.not(),()=>{(0,n.Break)()});let d=(0,n.int)(8),f=X(o,r.triangleIndex,(0,n.int)(3),d).w;(0,n.If)(f.greaterThan(.5),()=>{c.assign(0),(0,n.Break)()});let p=yt.wrap(nn(r.materialIndex,s)),m=(0,n.bool)(!1).toVar();Xr&&(0,n.If)(Xr.equal((0,n.int)(1)),()=>{let e=(0,n.float)(1).toVar();Yr&&(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),s=(0,n.int)(8),c=X(o,r.triangleIndex,(0,n.int)(6),s),l=X(o,r.triangleIndex,(0,n.int)(7),s),u=wn({uv:c.xy.mul(a).add(c.zw.mul(t)).add(l.xy.mul(i)),transform:p.albedoTransform});e.assign((0,n.texture)(Yr,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);c.mulAssign((0,n.float)(1).sub(t)),(0,n.If)(c.lessThan(.005),()=>{c.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));l.assign(r.hitPoint.add(t.mul(e))),u.subAssign(r.dst.add(e))}).ElseIf(p.transmission.greaterThan(0),()=>{let e=(0,n.int)(8),i=X(o,r.triangleIndex,(0,n.int)(0),e).xyz,a=X(o,r.triangleIndex,(0,n.int)(1),e).xyz,s=X(o,r.triangleIndex,(0,n.int)(2),e).xyz,d=(0,n.normalize)((0,n.cross)(a.sub(i),s.sub(i)));r.normal.assign(d);let f=(0,n.dot)(t,d).lessThan(0),m=(0,n.select)(f,d,d.negate());(0,n.If)(f.not().and(p.attenuationDistance.greaterThan(0)),()=>{let e=(0,n.length)(r.hitPoint.sub(l)),t=yr(p.attenuationColor,p.attenuationDistance,e);c.mulAssign(t.x.add(t.y).add(t.z).div(3))});let h=Wn((0,n.abs)((0,n.dot)(t,m)),Jn(p.ior,(0,n.float)(1))),g=(0,n.float)(1).sub(h).mul(p.transmission);c.mulAssign(g),(0,n.If)(c.lessThan(.005),()=>{c.assign(0),(0,n.Break)()}),l.assign(r.hitPoint.add(t.mul(.001))),u.subAssign(r.dst.add(.001))}).ElseIf(p.transparent,()=>{c.mulAssign((0,n.float)(1).sub(p.opacity)),(0,n.If)(c.lessThan(.005),()=>{c.assign(0),(0,n.Break)()}),l.assign(r.hitPoint.add(t.mul(.001))),u.subAssign(r.dst.add(.001))}).Else(()=>{c.assign(0),(0,n.Break)()})}),c}),ei=(0,n.Fn)(([e,t,r])=>{let i=(0,n.max)((0,n.float)(1e-4),(0,n.length)(e).mul(1e-6)).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)}),ti=(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.float)(0).toVar();return(0,n.If)(a.greaterThan(0),()=>{let t=e.intensity.mul((0,n.dot)(e.color,zt)),s=(0,n.float)(1).toVar();(0,n.If)(r.metalness.greaterThan(.7),()=>{s.assign(1.5)}).ElseIf(r.roughness.greaterThan(.8),()=>{s.assign(.7)});let c=(0,n.float)(1).div((0,n.float)(1).add((0,n.float)(i).mul(.5)));o.assign(t.mul(a).mul(s).mul(c))}),o}),ni=(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,zt)).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}),ri=(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,zt)),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}),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=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,zt)),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}),ai=2*Mt,oi=(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))).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))})}),Mr({valid:a,direction:o,emission:s,distance:c,pdf:l,lightType:u})}),si=(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)(3).toVar(),u=e.position.sub(t).toVar(),d=(0,n.dot)(u,u).toVar();return(0,n.If)(d.greaterThanEqual(1e-20),()=>{let t=(0,n.sqrt)(d).toVar(),l=u.div(t).toVar(),f=(0,n.dot)(l.negate(),e.direction).toVar(),p=(0,n.cos)(e.angle).toVar();a.assign(l),s.assign(t),c.assign(r),i.assign(f.greaterThanEqual(p)),(0,n.If)(i,()=>{let r=Br({coneCosine:p,penumbraCosine:(0,n.cos)(e.angle.mul((0,n.float)(1).sub(e.penumbra))).max(p.add(1e-5)).toVar(),angleCosine:f}),i=zr({lightDistance:t,cutoffDistance:e.distance,decayExponent:e.decay}),a=Ur(e,l),s=qr(e,l);o.assign(e.color.mul(e.intensity).mul(i).mul(r).mul(a).mul(s))})}),Mr({valid:i,direction:a,emission:o,distance:s,pdf:c,lightType:l})}),ci=(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.dot)(u,u).toVar();return(0,n.If)(d.greaterThanEqual(1e-20),()=>{let t=(0,n.sqrt)(d).toVar(),f=u.div(t),p=zr({lightDistance:t,cutoffDistance:e.distance,decayExponent:e.decay});l.assign((0,n.int)(2)),a.assign(f),s.assign(t),o.assign(e.color.mul(e.intensity).mul(p)),c.assign(r),i.assign((0,n.bool)(!0))}),Mr({valid:i,direction:a,emission:o,distance:s,pdf:c,lightType:l})}),li=(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(),w=(0,n.int)(-1).toVar(),T=(0,n.int)(-1).toVar(),E=(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:e})=>{(0,n.If)(C.lessThan((0,n.int)(16)),()=>{let i=ti(Or.wrap(Pr(s,e)),t,r,a).toVar();S.addAssign(i),(0,n.If)(i.greaterThan(0).and(N(o).mul(S).lessThan(i)),()=>{w.assign(0),T.assign(e),E.assign(i)}),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=kr.wrap(Fr(l,i)),s=(0,n.select)(a.intensity.greaterThan(0),ni(a,e,t,r),(0,n.float)(0)).toVar();S.addAssign(s),(0,n.If)(s.greaterThan(0).and(N(o).mul(S).lessThan(s)),()=>{w.assign(1),T.assign(i),E.assign(s)}),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 a=ri(Ar.wrap(Ir(d,i)),e,t,r).toVar();S.addAssign(a),(0,n.If)(a.greaterThan(0).and(N(o).mul(S).lessThan(a)),()=>{w.assign(2),T.assign(i),E.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)),()=>{let a=ii(jr.wrap(Lr(p,i)),e,t,r).toVar();S.addAssign(a),(0,n.If)(a.greaterThan(0).and(N(o).mul(S).lessThan(a)),()=>{w.assign(3),T.assign(i),E.assign(a)}),C.addAssign(1)})})}),(0,n.If)(S.lessThanEqual(0),()=>{let t=(0,n.int)(i.x.mul((0,n.float)(x))).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 r=Or.wrap(Pr(s,t.sub(S)));(0,n.If)(r.intensity.greaterThan(0),()=>{let t=Wr(r,e);g.assign((0,n.normalize)(r.direction)),_.assign(r.color.mul(r.intensity).mul(t)),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=kr.wrap(Fr(l,t.sub(S)));(0,n.If)(s.intensity.greaterThan(0),()=>{let t=(0,n.vec2)(i.y,N(o)).toVar(),c=Mr.wrap(oi(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=Ar.wrap(Ir(d,t.sub(S)));(0,n.If)(i.intensity.greaterThan(0),()=>{let t=Mr.wrap(ci(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 i=jr.wrap(Lr(p,t.sub(S)));(0,n.If)(i.intensity.greaterThan(0),()=>{let t=Mr.wrap(si(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))})})})}).Else(()=>{let t=E.div((0,n.max)(S,1e-10)).toVar();(0,n.If)(w.equal((0,n.int)(0)).and(T.greaterThanEqual((0,n.int)(0))),()=>{let r=Or.wrap(Pr(s,T)),a=(0,n.normalize)(r.direction).toVar(),c=(0,n.float)(1).toVar();(0,n.If)(r.angle.greaterThan(0),()=>{let e=(0,n.cos)(r.angle.mul(.5)).toVar(),t=(0,n.mix)(e,(0,n.float)(1),i.y).toVar(),s=(0,n.sqrt)((0,n.max)((0,n.float)(0),(0,n.float)(1).sub(t.mul(t)))).toVar(),l=(0,n.float)(ai).mul(N(o)).toVar(),u=(0,n.normalize)(r.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();a.assign((0,n.normalize)(u.mul(t).add(d.mul((0,n.cos)(l)).add(f.mul((0,n.sin)(l))).mul(s))));let p=(0,n.float)(ai).mul((0,n.max)((0,n.float)(1).sub(e),1e-10));c.assign((0,n.float)(1).div(p))});let l=Wr(r,e);g.assign(a),_.assign(r.color.mul(r.intensity).mul(l)),v.assign(1e6),y.assign(c.mul(t)),b.assign((0,n.int)(0)),h.assign((0,n.bool)(!0))}),(0,n.If)(w.equal((0,n.int)(1)).and(T.greaterThanEqual((0,n.int)(0))),()=>{let r=kr.wrap(Fr(l,T)),a=(0,n.vec2)(i.y,N(o)).toVar(),s=Mr.wrap(oi(r,e,a,t));h.assign(s.valid),g.assign(s.direction),_.assign(s.emission),v.assign(s.distance),y.assign(s.pdf),b.assign(s.lightType)}),(0,n.If)(w.equal((0,n.int)(2)).and(T.greaterThanEqual((0,n.int)(0))),()=>{let n=Ar.wrap(Ir(d,T)),r=Mr.wrap(ci(n,e,t));h.assign(r.valid),g.assign(r.direction),_.assign(r.emission),v.assign(r.distance),y.assign(r.pdf),b.assign(r.lightType)}),(0,n.If)(w.equal((0,n.int)(3)).and(T.greaterThanEqual((0,n.int)(0))),()=>{let n=jr.wrap(Lr(p,T)),r=Mr.wrap(si(n,e,t));h.assign(r.valid),g.assign(r.direction),_.assign(r.emission),v.assign(r.distance),y.assign(r.pdf),b.assign(r.lightType)})})}),Mr({valid:h,direction:g,emission:_,distance:v,pdf:y,lightType:b})}),ui=(0,n.Fn)(([e,t])=>{let r=t.NoV,i=t.NoL.toVar(),a=t.NoH,o=(0,n.float)(1).sub(e.metalness).mul((0,n.float)(1).sub(e.transmission)).toVar(),s=(0,n.float)(1).sub(o.mul((0,n.float)(1).sub(e.metalness))).toVar(),c=o.add(s).toVar(),l=(0,n.float)(0).toVar();return(0,n.If)(c.greaterThan(0),()=>{let t=(0,n.float)(1).div((0,n.max)(c,1e-10)).toVar();o.mulAssign(t),s.mulAssign(t),(0,n.If)(o.greaterThan(0).and(i.greaterThan(0)),()=>{l.addAssign(o.mul(i).mul(Nt))}),(0,n.If)(s.greaterThan(0).and(i.greaterThan(0)),()=>{let t=(0,n.max)(e.roughness,.02);l.addAssign(s.mul(tr(a,r,t)))})}),(0,n.max)(l,1e-8)});(0,n.Fn)(([e,t,n,r])=>ui(r,wt.wrap(Jt(n,e,t))));var di=(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])=>{let k=(0,n.vec3)(0).toVar(),A=e.add(t.mul(.001)).toVar(),j=(0,n.Fn)(([e,t,n])=>$r(e,t,n,hn,v,y,b));return(0,n.If)(r.emissiveIntensity.lessThanEqual(10),()=>{let v=(0,n.vec3)(1).toVar(),y=jt.wrap($t(r.roughness,r.metalness,c,v)),b=y.useBRDFSampling.toVar(),M=y.useLightSampling.toVar(),P=y.brdfWeight.toVar(),F=y.lightWeight.toVar(),I=d.add(p).add(h).add(_).toVar(),ee=(0,n.float)(.001).mul((0,n.float)(1).add((0,n.float)(c).mul(.5))).toVar(),te=I.greaterThan((0,n.int)(0)).toVar(),L=(0,n.float)(0).toVar();(0,n.If)(M.and(te),()=>{L.addAssign(F)}),(0,n.If)(b,()=>{L.addAssign(P)}),(0,n.If)(L.lessThanEqual(0),()=>{L.assign(1),b.assign((0,n.bool)(!0)),P.assign(1)});let ne=N(l).toVar(),re=N(l).toVar(),ie=ne,ae=(0,n.bool)(!1).toVar(),R=(0,n.bool)(!1).toVar(),z=(0,n.select)(te,F,(0,n.float)(0)),oe=(0,n.float)(1).div((0,n.max)(L,1e-10)),se=z.mul(oe);(0,n.If)(ie.lessThan(se).and(M).and(te),()=>{ae.assign((0,n.bool)(!0))}).ElseIf(b,()=>{R.assign((0,n.bool)(!0))}).ElseIf(te,()=>{ae.assign((0,n.bool)(!0))}),(0,n.If)(ae,()=>{let e=(0,n.vec2)(re,N(l)).toVar(),a=Mr.wrap(li(A,t,r,e,c,l,u,d,f,p,m,h,g,_));(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);(0,n.If)(e.greaterThan(0).and(o.mul(e).greaterThan(ee)).and(Rr({direction:a.direction,surfaceNormal:t})),()=>{let o=(0,n.min)(a.distance.sub(.001),(0,n.float)(1e3)),s=j(A,a.direction,o);(0,n.If)(s.greaterThan(0),()=>{let o=wt.wrap(Jt(t,i,a.direction)),c=Cr(r,o),l=ui(r,o).toVar(),u=(0,n.float)(1).toVar();(0,n.If)(l.greaterThan(0).and(b),()=>{let e=a.pdf.mul(F),t=l.mul(P);(0,n.If)(a.lightType.equal((0,n.int)(1)),()=>{u.assign(Gt({pdf1:e,pdf2:t}))})});let d=a.emission.mul(c).mul(e).mul(s).mul(u).div((0,n.max)(a.pdf,1e-10));k.addAssign(d.mul(L).div((0,n.max)(F,1e-10)))})})})}),(0,n.If)(R,()=>{(0,n.If)(o.greaterThan(0).and(b),()=>{let i=(0,n.max)((0,n.float)(0),(0,n.dot)(t,a)).toVar();(0,n.If)(i.greaterThan(0).and(Rr({direction:a,surfaceNormal:t})),()=>{(0,n.If)(p.greaterThan((0,n.int)(0)),()=>{let c=(0,n.bool)(!1).toVar(),l=(0,n.float)(0).toVar(),u=(0,n.int)(-1).toVar();(0,n.Loop)({start:(0,n.int)(0),end:p,type:`int`,condition:`<`},({i})=>{let o=kr.wrap(Fr(f,i));(0,n.If)(o.intensity.greaterThan(0),()=>{let s=ni(o,e,t,r).toVar();(0,n.If)(s.greaterThanEqual(ee),()=>{(0,n.If)(Jr(o,A,a).toVar().greaterThan(0),()=>{(0,n.If)(s.greaterThan(l),()=>{l.assign(s),u.assign(i)}),c.assign((0,n.bool)(!0))})})})}),(0,n.If)(c.and(u.greaterThanEqual((0,n.int)(0))),()=>{let e=kr.wrap(Fr(f,u)),t=Jr(e,A,a).toVar();(0,n.If)(t.greaterThan(0),()=>{let r=j(A,a,(0,n.min)(t.sub(.001),(0,n.float)(1e3)));(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).div((0,n.max)(e.area.mul(c),Ft)).toVar();a.divAssign((0,n.max)((0,n.float)(I),1));let l=Gt({pdf1:o.mul(P),pdf2:a.mul(F)}).toVar(),u=e.color.mul(e.intensity).mul(s).mul(i).mul(r).mul(l).div((0,n.max)(o,1e-10));k.addAssign(u.mul(L).div((0,n.max)(P,1e-10)))})})})})})})})}),(0,n.If)(O,()=>{let e=(0,n.vec2)(N(l).toVar(),N(l).toVar()).toVar(),a=(0,n.vec3)(0).toVar(),o=bn(x,w,C,S,T,E,D,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(Rr({direction:s,surfaceNormal:t})),()=>{let o=j(A,s,(0,n.float)(1e3));(0,n.If)(o.greaterThan(0),()=>{let l=wt.wrap(Jt(t,i,s)),u=Cr(r,l),d=ui(r,l).toVar(),f=(0,n.select)(d.greaterThan(0),Kt({pdf1:c,pdf2:d}),(0,n.float)(1)).toVar(),p=a.mul(u).mul(e).mul(o).mul(f).div((0,n.max)(c,1e-10));k.addAssign(p)})})})})}),k}),fi=(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(Ft),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)),f=(0,n.abs)((0,n.dot)(t,u)).toVar(),p=(0,n.abs)((0,n.dot)(r,u)).toVar(),m=Xn(p,a),h=d.add(f.mul(s)).toVar(),g=h.mul(h),_=f.mul(s).mul(s).div((0,n.max)(g,Ft));return m.mul(p).mul(_)}),pi=(0,n.Fn)(([e,t,r,i])=>{let a=e.add(t).toVar(),o=(0,n.dot)(a,a).toVar();return tr((0,n.max)((0,n.dot)(r,(0,n.select)(o.greaterThan(Ft),a.div((0,n.sqrt)(o)),r)),0),(0,n.max)((0,n.dot)(r,e),0),i)}),mi=(0,n.Fn)(([e])=>{let t=e.specularImportance.toVar(),r=t.greaterThan(.001).toVar(),i=e.diffuseImportance.toVar(),a=i.greaterThan(.001).toVar(),o=e.transmissionImportance.toVar(),s=o.greaterThan(.001).toVar(),c=e.clearcoatImportance.toVar(),l=c.greaterThan(.001).toVar(),u=t.add(i).add(o).add(c).toVar();return(0,n.If)(u.lessThan(.001),()=>{t.assign(0),i.assign(1),o.assign(0),c.assign(0),u.assign(1),r.assign((0,n.bool)(!1)),a.assign((0,n.bool)(!0)),s.assign((0,n.bool)(!1)),l.assign((0,n.bool)(!1))}).Else(()=>{let e=(0,n.float)(1).div(u).toVar();t.mulAssign(e),i.mulAssign(e),o.mulAssign(e),c.mulAssign(e),u.assign(1)}),At({envWeight:(0,n.float)(0),specularWeight:t,diffuseWeight:i,transmissionWeight:o,clearcoatWeight:c,totalWeight:u,useEnv:(0,n.bool)(!1),useSpecular:r,useDiffuse:a,useTransmission:s,useClearcoat:l})}),hi=(0,n.Fn)(([e,t])=>{let r=(0,n.int)(2).toVar(),i=(0,n.float)(0).toVar(),a=(0,n.bool)(!1).toVar();return(0,n.If)(e.useSpecular.and(a.not()),()=>{i.addAssign(e.specularWeight),(0,n.If)(t.lessThan(i),()=>{r.assign(1),a.assign((0,n.bool)(!0))})}),(0,n.If)(e.useDiffuse.and(a.not()),()=>{i.addAssign(e.diffuseWeight),(0,n.If)(t.lessThan(i),()=>{r.assign(2),a.assign((0,n.bool)(!0))})}),(0,n.If)(e.useTransmission.and(a.not()),()=>{i.addAssign(e.transmissionWeight),(0,n.If)(t.lessThan(i),()=>{r.assign(3),a.assign((0,n.bool)(!0))})}),(0,n.If)(e.useClearcoat.and(a.not()),()=>{r.assign(4)}),r}),gi=(0,n.Fn)(([e])=>(0,n.max)(e,0).mul(Nt)),_i=(0,n.Fn)(([e,t,r,i,a,o,s,c])=>{let l=(0,n.vec3)(0).toVar(),u=(0,n.vec3)(0).toVar(),d=(0,n.float)(0).toVar(),f=(0,n.float)(0).toVar(),p=(0,n.float)(0).toVar();return(0,n.If)(c.diffuseImportance.greaterThanEqual(0).and(c.specularImportance.greaterThanEqual(0)).and(c.transmissionImportance.greaterThanEqual(0)).and(c.clearcoatImportance.greaterThanEqual(0)).not(),()=>{let e=(0,n.vec2)(N(s).toVar(),N(s).toVar());l.assign(lr(t,e)),u.assign(r.color.xyz),d.assign(1),f.assign(1)}).Else(()=>{let m=At.wrap(mi(c).toVar()),h=N(s).toVar(),g=(0,n.vec2)(N(s).toVar(),N(s).toVar()).toVar(),_=hi(m,h).toVar(),v=(0,n.vec3)(0).toVar(),y=(0,n.float)(0).toVar(),b=(0,n.vec3)(0).toVar();(0,n.If)(_.equal((0,n.int)(1)),()=>{v.assign(i),y.assign(a),b.assign(o)}).ElseIf(_.equal((0,n.int)(2)),()=>{v.assign(lr(t,g)),y.assign(gi((0,n.max)((0,n.dot)(t,v),0))),b.assign(wr(e,v,t,r))}).ElseIf(_.equal((0,n.int)(3)),()=>{let i=(0,n.dot)(e,t).greaterThan(0),a=mr.wrap(br(e,t,r.ior,r.roughness,i,r.dispersion,g,s,(0,n.float)(0)).toVar());v.assign(a.direction),y.assign(a.pdf),b.assign(wr(e,v,t,r))}).Else(()=>{v.assign(i),y.assign(a),b.assign(o)});let x=(0,n.dot)(t,v).toVar(),S=(0,n.max)(x,0).toVar(),C=(0,n.abs)(x),w=(0,n.float)(0).toVar();(0,n.If)(m.useSpecular,()=>{let i=tr((0,n.max)((0,n.dot)(t,(0,n.normalize)(e.add(v))),.001),(0,n.max)((0,n.dot)(t,e),.001),r.roughness);w.addAssign(m.specularWeight.mul(i))}),(0,n.If)(m.useDiffuse,()=>{w.addAssign(m.diffuseWeight.mul(gi(S)))}),(0,n.If)(m.useTransmission.and(r.transmission.greaterThan(0)),()=>{let i=(0,n.dot)(e,t).greaterThan(0);w.addAssign(m.transmissionWeight.mul(fi(e,v,t,r.ior,r.roughness,i)))}),(0,n.If)(m.useClearcoat.and(r.clearcoat.greaterThan(0)),()=>{w.addAssign(m.clearcoatWeight.mul(pi(e,v,t,r.clearcoatRoughness)))}),y.assign((0,n.max)(y,Rt)),w.assign((0,n.max)(w,Rt));let T=y.div(w).toVar(),E=(0,n.select)(_.equal((0,n.int)(3)),C,S);l.assign(v),u.assign(b.mul(E).mul(T).div(y)),d.assign(T),f.assign(y),p.assign(w)}),Nr({direction:l,throughput:u,misWeight:d,pdf:f,combinedPdf:p})}),vi=y({position:`vec3`,normal:`vec3`,emission:`vec3`,direction:`vec3`,distance:`float`,pdf:`float`,area:`float`,cosThetaLight:`float`,valid:`bool`}),yi=y({contribution:`vec3`,hasEmissive:`bool`,emissionOnly:`vec3`,distance:`float`}),bi=(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))}),xi=(0,n.Fn)(([e,t,r])=>(0,n.length)((0,n.cross)(t.sub(e),r.sub(e))).mul(.5)),Si=(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))}),Ci=(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}),wi=y({direction:`vec3`,position:`vec3`,solidAngle:`float`,valid:`bool`}),Ti=(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))}),Ei=(0,n.Fn)(([e,t,r,i,a])=>{let o=wi({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=Si(e,t,r,i);return o.solidAngle.assign(u),(0,n.If)(u.greaterThan(1e-7),()=>{let d=(0,n.clamp)((0,n.dot)(Ti((0,n.cross)(s,c)),Ti((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=Ti(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=Ti(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}),Di=(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)}),Oi=(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 ki=8,Ai=2,ji=y({v0:`vec3`,v1:`vec3`,v2:`vec3`,n0:`vec3`,n1:`vec3`,n2:`vec3`,materialIndex:`int`}),Mi=(0,n.Fn)(([e,t])=>{let r=X(t,e,(0,n.int)(0),(0,n.int)(ki)),i=X(t,e,(0,n.int)(1),(0,n.int)(ki)),a=X(t,e,(0,n.int)(2),(0,n.int)(ki)),o=X(t,e,(0,n.int)(3),(0,n.int)(ki)),s=X(t,e,(0,n.int)(4),(0,n.int)(ki)),c=X(t,e,(0,n.int)(5),(0,n.int)(ki)),l=X(t,e,(0,n.int)(7),(0,n.int)(ki));return ji({v0:r.xyz,v1:i.xyz,v2:a.xyz,n0:o.xyz,n1:s.xyz,n2:c.xyz,materialIndex:(0,n.int)(l.z)})}),Ni=(0,n.Fn)(([e,t,r,i,a,o,s])=>{let c=ji.wrap(Mi(e,a)),l=xi(c.v0,c.v1,c.v2),u=X(o,c.materialIndex,(0,n.int)(Bt.EMISSIVE_ROUGHNESS),J),d=X(o,c.materialIndex,(0,n.int)(Bt.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)(Ci(c.v0,c.v1,c.v2,i),()=>{let e=Si(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,Rt)}),Pi=(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)(Ai)))).b;(0,n.If)(s.lessThan(i),()=>{a.assign(r.add(1))}).Else(()=>{o.assign(r)})}),a}),Fi=(0,n.Fn)(([e,t,r,i,a,o,s,c])=>{let l=vi({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)(o.greaterThan((0,n.int)(0)),()=>{let u=Pi(i,a,o,N(r)).toVar(),d=a.add(u.mul((0,n.int)(Ai))),f=i.element(d),p=i.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=ji.wrap(Mi(m,c)),y=(0,n.vec2)(N(r).toVar(),N(r).toVar()),b=(0,n.normalize)((0,n.cross)(v.v1.sub(v.v0),v.v2.sub(v.v0)));(0,n.If)(Ci(v.v0,v.v1,v.v2,e),()=>{let r=wi.wrap(Ei(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),c=(0,n.dot)(i,b.negate());(0,n.If)(o.greaterThan(0).and(c.greaterThan(0)),()=>{let t=Di(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))),u=(0,n.length)(a.sub(e)),d=h.div((0,n.max)(s,(0,n.float)(1e-10))).div(r.solidAngle);l.position.assign(a),l.normal.assign(o),l.emission.assign(g),l.direction.assign(i),l.distance.assign(u),l.pdf.assign((0,n.max)(d,Rt)),l.area.assign(_),l.cosThetaLight.assign(c),l.valid.assign(!0)})})}).Else(()=>{let r=bi(v.v0,v.v1,v.v2,y),i=Oi(v.n0,v.n1,v.n2,y),a=r.sub(e),o=(0,n.dot)(a,a),c=(0,n.sqrt)(o),u=a.div(c),d=(0,n.dot)(u,t),f=(0,n.dot)(u,i.negate());(0,n.If)(d.greaterThan(0).and(f.greaterThan(0)),()=>{let e=h.div((0,n.max)(s,(0,n.float)(1e-10)).mul(_)).mul(o).div(f);l.position.assign(r),l.normal.assign(i),l.emission.assign(g),l.direction.assign(u),l.distance.assign(c),l.pdf.assign((0,n.max)(e,Rt)),l.area.assign(_),l.cosThetaLight.assign(f),l.valid.assign(!0)})})}),l}),Ii=(0,n.Fn)(([e,t,r,i,a,o,s,c,l,u,d,f,p,m])=>{let h=yi({contribution:(0,n.vec3)(0),hasEmissive:!1,emissionOnly:(0,n.vec3)(0),distance:(0,n.float)(0)}).toVar();return(0,n.If)(a.greaterThan((0,n.int)(1)).and(i.roughness.greaterThan(.9)).and(i.metalness.lessThan(.1)).not(),()=>{let a=vi.wrap(Fi(e,t,o,c,l,u,d,f));(0,n.If)(a.valid.and(a.pdf.greaterThan(0)),()=>{h.hasEmissive.assign(!0),h.emissionOnly.assign(a.emission),h.distance.assign(a.distance);let o=(0,n.max)((0,n.float)(0),(0,n.dot)(t,a.direction));(0,n.If)(o.greaterThan(0),()=>{let c=m(e,t,i),l=e.add(c),u=a.distance.sub(.001),d=p(l,a.direction,u);(0,n.If)(d.greaterThan(0),()=>{let e=wt.wrap(Jt(t,r,a.direction)),c=Cr(i,e),l=ui(i,e),u=(0,n.select)(l.greaterThan(0),Gt({pdf1:a.pdf,pdf2:l}),(0,n.float)(1));h.contribution.assign(a.emission.mul(c).mul(o).div(a.pdf).mul(d).mul(s).mul(u))})})})}),h}),Li=(0,n.Fn)(([e,t,n,r,i,a,o,s,c,l,u,d,f,p])=>yi.wrap(Ii(e,t,n,r,i,a,o,s,c,l,u,d,f,p)).contribution),Ri=4,zi=2,Bi=32,Vi=(0,n.Fn)(([e,t,r,i,a,o,s])=>{let c=vi({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)(Bi,()=>{let t=u.mul((0,n.int)(Ri)),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)(Ri)),p=i.element(f),m=i.element(f.add((0,n.int)(1))),h=c.mul((0,n.int)(Ri)),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)(Ri)),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)(zi))),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)(zi))),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=ji.wrap(Mi(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)(Ci(D.v0,D.v1,D.v2,e),()=>{let r=wi.wrap(Ei(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=Di(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,Rt)),c.area.assign(E),c.cosThetaLight.assign(s),c.valid.assign(!0)})})}).Else(()=>{let r=bi(D.v0,D.v1,D.v2,O),i=Oi(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,Rt)),c.area.assign(E),c.cosThetaLight.assign(f),c.valid.assign(!0)})})}),c}),Hi=0,Ui=1,Wi=2,Gi=3,Ki=y({radiance:`vec4`,objectNormal:`vec3`,objectColor:`vec3`,objectID:`float`,firstHitPoint:`vec3`,firstHitDistance:`float`}),qi=(0,n.Fn)(([e,t,r,i,a])=>{let o=a.toVar();return(0,n.If)(r.not().or(i.notEqual(t)),()=>{o.assign(Qt(e.metalness,e.roughness,e.transmission,e.clearcoat,e.emissive))}),o}),Ji=(0,n.Fn)(([e,t,r,i,a,o,s,c,l,u])=>{let d=(0,n.vec3)(0).toVar(),f=(0,n.vec3)(0).toVar(),p=(0,n.float)(0).toVar(),m=c.toVar();(0,n.If)(s.not(),()=>{(0,n.If)(l,()=>{m.assign(ir(r,o,u))}).Else(()=>{let e=kt({F0:Yn(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();m.assign(ir(r,o,e))})});let h=i.x.toVar(),g=(0,n.vec2)(i.y,N(a)).toVar(),_=(0,n.vec3)(0).toVar(),v=m.diffuse.toVar(),y=v.add(m.specular).toVar(),b=y.add(m.sheen).toVar(),x=b.add(m.clearcoat),S=(0,n.clamp)((0,n.dot)(t,e),.001,1).toVar();return(0,n.If)(h.lessThan(v),()=>{d.assign(cr({N:t,xi:g}));let i=(0,n.clamp)((0,n.dot)(t,d),0,1);p.assign(i.mul(Nt)),f.assign(wr(e,d,t,r))}).ElseIf(h.lessThan(y),()=>{let a=qt({N:t}),o=ur({V:a.transpose().mul(e),roughness:r.roughness,Xi:i});_.assign(a.mul(o));let s=(0,n.clamp)((0,n.dot)(t,_),.001,1);d.assign((0,n.reflect)(e.negate(),_)),p.assign(tr(s,S,r.roughness)),f.assign(wr(e,d,t,r))}).ElseIf(h.lessThan(b),()=>{_.assign(sr({N:t,roughness:r.sheenRoughness,Xi:i}));let a=(0,n.clamp)((0,n.dot)(t,_),.001,1),o=(0,n.clamp)((0,n.dot)(e,_),.001,1);d.assign((0,n.reflect)(e.negate(),_));let s=(0,n.dot)(t,d).toVar();(0,n.If)(s.lessThanEqual(0),()=>{d.assign(cr({N:t,xi:i})),s.assign((0,n.clamp)((0,n.dot)(t,d),0,1)),p.assign(s.mul(Nt)),f.assign(wr(e,d,t,r))}).Else(()=>{p.assign(Zn(a,r.sheenRoughness).mul(a).div((0,n.float)(4).mul(o))),p.assign((0,n.max)(p,Rt)),f.assign(wr(e,d,t,r))})}).ElseIf(h.lessThan(x),()=>{let a=(0,n.clamp)(r.clearcoatRoughness,Lt,1);_.assign(sr({N:t,roughness:a,Xi:i}));let o=(0,n.clamp)((0,n.dot)(t,_),0,1);d.assign((0,n.reflect)(e.negate(),_)),p.assign(tr(o,S,a)),p.assign((0,n.max)(p,Rt)),f.assign(wr(e,d,t,r))}).Else(()=>{let o=(0,n.dot)(e,t).greaterThan(0),s=mr.wrap(br(e,t,r.ior,r.roughness,o,r.dispersion,i,a,(0,n.float)(0)));d.assign(s.direction),p.assign((0,n.max)(s.pdf,Rt)),f.assign(wr(e,d,t,r))}),p.assign((0,n.max)(p,Rt)),xt({direction:d,value:f,pdf:p})}),Yi=(0,n.Fn)(([e,t,r,i,a,o,s,c,l,u,d])=>{let f=(0,n.float)(1).toVar();return(0,n.If)(e.greaterThanEqual((0,n.int)(3)),()=>{let p=(0,n.max)(Ut({v:t}),0).toVar();(0,n.If)(p.lessThan(8e-4).and(e.greaterThan((0,n.int)(4))),()=>{let e=(0,n.max)(p.mul(125),.01),t=N(o);f.assign((0,n.select)(t.lessThan(e),e,(0,n.float)(0)))}).Else(()=>{let t=Dt.wrap(qi(r,i,s,c,l)).toVar(),m=t.complexityScore.toVar();(0,n.If)(t.isMetallic.and(t.isSmooth).and(e.lessThan((0,n.int)(7))),()=>{m.addAssign(.3)}),(0,n.If)(t.isTransmissive.and(e.lessThan((0,n.int)(6))),()=>{m.addAssign(.25)}),(0,n.If)(t.isEmissive.and(e.lessThan((0,n.int)(4))),()=>{m.addAssign(.15)}),m.assign((0,n.clamp)(m,0,1));let h=(0,n.int)(3).toVar();(0,n.If)(m.greaterThan(.6),()=>{h.assign(5)}).ElseIf(m.greaterThan(.4),()=>{h.assign(4)}),(0,n.If)(e.lessThan(h),()=>{f.assign(1)}).Else(()=>{let r=t.complexityScore.toVar();(0,n.If)(t.isMetallic.and(t.isSmooth),()=>{r.addAssign(.15)}),(0,n.If)(t.isTransmissive.and(t.hasClearcoat),()=>{r.addAssign(.12)}),(0,n.If)(t.isEmissive,()=>{r.addAssign(.1)}),r.assign((0,n.clamp)(r,0,1));let i=(0,n.float)(.5).toVar();(0,n.If)(u.and(d).and(p.greaterThan(.01)),()=>{let e=(0,n.clamp)(a.y,0,1);i.assign((0,n.mix)((0,n.float)(.3),(0,n.float)(.8),e.mul(e)))});let s=(0,n.smoothstep)((0,n.float)(.001),(0,n.float)(.1),p),c=p.mul((0,n.mix)(r.mul(.7),i,.3)).mul(s).toVar(),l=(0,n.mix)((0,n.clamp)(m.mul(.4).add(p.mul(.6)).mul(1.2),.15,.95),(0,n.clamp)(p.mul(.4).add(m.mul(.1)),.03,.6),(0,n.clamp)((0,n.float)(e.sub(h)).div(10),0,1)).toVar();l.assign((0,n.mix)(l,(0,n.max)(l,c),.4)),(0,n.If)(m.greaterThan(.5),()=>{let e=m.sub(.5).mul(.6);l.assign((0,n.mix)(l,(0,n.float)(1),e))});let g=(0,n.float)(.12).add(m.mul(.08)),_=(0,n.exp)((0,n.float)(e.sub(h)).negate().mul(g));l.mulAssign(_);let v=(0,n.select)(t.isEmissive,(0,n.float)(.04),(0,n.float)(.02));l.assign((0,n.max)(l,v));let y=N(o);f.assign((0,n.select)(y.lessThan(l),l,(0,n.float)(0)))})})}),f}),Xi=(0,n.Fn)(([e,t,r,i,a,o,s,c,l,u,d,f])=>{let p=(0,n.vec4)(0).toVar();return(0,n.If)(e.and(c.not()),()=>{p.assign((0,n.vec4)(0))}).Else(()=>{let c=r.toVar();(0,n.If)(e.and(u),()=>{c.assign(Sn(t,r,d,f))});let m=xn({tex:i,samp:(0,n.sampler)(i),direction:c,environmentMatrix:a,environmentIntensity:o,enableEnvironmentLight:s});(0,n.If)(e,()=>{p.assign(m.mul(l))}).Else(()=>{p.assign(m)})}),p}),Zi=(0,n.wgslFn)(`
531
+ `),Hr=null;function Ur(e){Hr=e}var Wr=(0,n.Fn)(([e,t])=>{let r=(0,n.float)(1).toVar();return(0,n.If)(e.goboIndex.greaterThanEqual((0,n.int)(0)),()=>{let i=e.direction.toVar(),a=t.negate().toVar(),o=(0,n.dot)(a,i).toVar();(0,n.If)(o.greaterThan(0),()=>{let t=(0,n.normalize)((0,n.cross)((0,n.select)((0,n.abs)(i.z).lessThan(.999),(0,n.vec3)(0,0,1),(0,n.vec3)(1,0,0)),i)).toVar(),s=(0,n.cross)(i,t),c=(0,n.float)(1).div(o).toVar(),l=(0,n.dot)(a,t).mul(c),u=(0,n.dot)(a,s).mul(c),d=(0,n.float)(.5).div((0,n.max)((0,n.tan)(e.angle),(0,n.float)(1e-4))).toVar(),f=(0,n.clamp)(l.mul(d).add(.5),(0,n.float)(0),(0,n.float)(1)),p=(0,n.clamp)(u.mul(d).add(.5),(0,n.float)(0),(0,n.float)(1));if(Hr){let t=(0,n.texture)(Hr,(0,n.vec2)(f,p)).depth(e.goboIndex),i=(0,n.min)(t.r,t.a),a=(0,n.select)(e.goboIntensity.lessThan(0),(0,n.float)(1).sub(i),i),o=(0,n.clamp)((0,n.abs)(e.goboIntensity),(0,n.float)(0),(0,n.float)(1));r.assign((0,n.mix)((0,n.float)(1),a,o))}}).Else(()=>{r.assign(0)})}),r}),Gr=(0,n.Fn)(([e,t])=>{let r=(0,n.float)(1).toVar();return(0,n.If)(e.goboIndex.greaterThanEqual((0,n.int)(0)),()=>{let i=e.direction.toVar(),a=(0,n.normalize)((0,n.cross)((0,n.select)((0,n.abs)(i.z).lessThan(.999),(0,n.vec3)(0,0,1),(0,n.vec3)(1,0,0)),i)).toVar(),o=(0,n.cross)(i,a),s=(0,n.float)(1).div((0,n.max)(e.goboScale,(0,n.float)(1e-4))).toVar(),c=(0,n.dot)(t,a).mul(s).add(.5).toVar(),l=(0,n.dot)(t,o).mul(s).add(.5).toVar(),u=c.sub(c.floor()),d=l.sub(l.floor());if(Hr){let t=(0,n.texture)(Hr,(0,n.vec2)(u,d)).depth(e.goboIndex),i=(0,n.min)(t.r,t.a),a=(0,n.select)(e.goboIntensity.lessThan(0),(0,n.float)(1).sub(i),i),o=(0,n.clamp)((0,n.abs)(e.goboIntensity),(0,n.float)(0),(0,n.float)(1));r.assign((0,n.mix)((0,n.float)(1),a,o))}}),r}),Kr=null;function qr(e){Kr=e}var Jr=(0,n.Fn)(([e,t])=>{let r=(0,n.float)(1).toVar();return(0,n.If)(e.iesIndex.greaterThanEqual((0,n.int)(0)),()=>{let i=e.direction.toVar(),a=t.negate().toVar(),o=(0,n.clamp)((0,n.acos)((0,n.clamp)((0,n.dot)(a,i),(0,n.float)(-1),(0,n.float)(1))).div((0,n.float)(Math.PI)),(0,n.float)(0),(0,n.float)(1)),s=(0,n.normalize)((0,n.cross)((0,n.select)((0,n.abs)(i.z).lessThan(.999),(0,n.vec3)(0,0,1),(0,n.vec3)(1,0,0)),i)).toVar(),c=(0,n.cross)(i,s),l=(0,n.dot)(a,s),u=(0,n.atan)((0,n.dot)(a,c),l).div((0,n.float)(2*Math.PI)).add(.5);if(Kr){let t=(0,n.texture)(Kr,(0,n.vec2)(u,o)).depth(e.iesIndex).r,i=(0,n.clamp)(e.iesIntensity,(0,n.float)(0),(0,n.float)(1));r.assign((0,n.mix)((0,n.float)(1),t,i))}}),r}),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}var ei=(0,n.Fn)(([e,t,r,i,a,o,s])=>{let c=(0,n.float)(1).toVar(),l=e.toVar(),u=(0,n.float)(r).toVar();return(0,n.Loop)({start:(0,n.int)(0),end:(0,n.int)(8)},()=>{let e=vt({origin:l,direction:t}),r=xt.wrap(i(e,a,o,u));(0,n.If)(r.didHit.not(),()=>{(0,n.Break)()});let d=(0,n.int)(8),f=Y(o,r.triangleIndex,(0,n.int)(3),d).w;(0,n.If)(f.greaterThan(.5),()=>{c.assign(0),(0,n.Break)()});let p=bt.wrap(rn(r.materialIndex,s)),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),s=(0,n.int)(8),c=Y(o,r.triangleIndex,(0,n.int)(6),s),l=Y(o,r.triangleIndex,(0,n.int)(7),s),u=Tn({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);c.mulAssign((0,n.float)(1).sub(t)),(0,n.If)(c.lessThan(.005),()=>{c.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));l.assign(r.hitPoint.add(t.mul(e))),u.subAssign(r.dst.add(e))}).ElseIf(p.transmission.greaterThan(0),()=>{let e=(0,n.int)(8),i=Y(o,r.triangleIndex,(0,n.int)(0),e).xyz,a=Y(o,r.triangleIndex,(0,n.int)(1),e).xyz,s=Y(o,r.triangleIndex,(0,n.int)(2),e).xyz,d=(0,n.normalize)((0,n.cross)(a.sub(i),s.sub(i)));r.normal.assign(d);let f=(0,n.dot)(t,d).lessThan(0),m=(0,n.select)(f,d,d.negate());(0,n.If)(f.not().and(p.attenuationDistance.greaterThan(0)),()=>{let e=(0,n.length)(r.hitPoint.sub(l)),t=br(p.attenuationColor,p.attenuationDistance,e);c.mulAssign(t.x.add(t.y).add(t.z).div(3))});let h=Gn((0,n.abs)((0,n.dot)(t,m)),Yn(p.ior,(0,n.float)(1))),g=(0,n.float)(1).sub(h).mul(p.transmission);c.mulAssign(g),(0,n.If)(c.lessThan(.005),()=>{c.assign(0),(0,n.Break)()}),l.assign(r.hitPoint.add(t.mul(.001))),u.subAssign(r.dst.add(.001))}).ElseIf(p.transparent,()=>{c.mulAssign((0,n.float)(1).sub(p.opacity)),(0,n.If)(c.lessThan(.005),()=>{c.assign(0),(0,n.Break)()}),l.assign(r.hitPoint.add(t.mul(.001))),u.subAssign(r.dst.add(.001))}).Else(()=>{c.assign(0),(0,n.Break)()})}),c}),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();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])=>{let a=(0,n.max)((0,n.float)(0),(0,n.dot)(t,e.direction)),o=(0,n.float)(0).toVar();return(0,n.If)(a.greaterThan(0),()=>{let t=e.intensity.mul((0,n.dot)(e.color,Bt)),s=(0,n.float)(1).toVar();(0,n.If)(r.metalness.greaterThan(.7),()=>{s.assign(1.5)}).ElseIf(r.roughness.greaterThan(.8),()=>{s.assign(.7)});let c=(0,n.float)(1).div((0,n.float)(1).add((0,n.float)(i).mul(.5)));o.assign(t.mul(a).mul(s).mul(c))}),o}),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,Bt)).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,Bt)),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,Bt)),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=2*Nt,si=(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))).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))})}),Nr({valid:a,direction:o,emission:s,distance:c,pdf:l,lightType:u})}),ci=(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)(3).toVar(),u=e.position.sub(t).toVar(),d=(0,n.dot)(u,u).toVar();return(0,n.If)(d.greaterThanEqual(1e-20),()=>{let t=(0,n.sqrt)(d).toVar(),l=u.div(t).toVar(),f=(0,n.dot)(l.negate(),e.direction).toVar(),p=(0,n.cos)(e.angle).toVar();a.assign(l),s.assign(t),c.assign(r),i.assign(f.greaterThanEqual(p)),(0,n.If)(i,()=>{let r=Vr({coneCosine:p,penumbraCosine:(0,n.cos)(e.angle.mul((0,n.float)(1).sub(e.penumbra))).max(p.add(1e-5)).toVar(),angleCosine:f}),i=Br({lightDistance:t,cutoffDistance:e.distance,decayExponent:e.decay}),a=Wr(e,l),s=Jr(e,l);o.assign(e.color.mul(e.intensity).mul(i).mul(r).mul(a).mul(s))})}),Nr({valid:i,direction:a,emission:o,distance:s,pdf:c,lightType:l})}),li=(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.dot)(u,u).toVar();return(0,n.If)(d.greaterThanEqual(1e-20),()=>{let t=(0,n.sqrt)(d).toVar(),f=u.div(t),p=Br({lightDistance:t,cutoffDistance:e.distance,decayExponent:e.decay});l.assign((0,n.int)(2)),a.assign(f),s.assign(t),o.assign(e.color.mul(e.intensity).mul(p)),c.assign(r),i.assign((0,n.bool)(!0))}),Nr({valid:i,direction:a,emission:o,distance:s,pdf:c,lightType:l})}),ui=(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(),w=(0,n.int)(-1).toVar(),T=(0,n.int)(-1).toVar(),E=(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:e})=>{(0,n.If)(C.lessThan((0,n.int)(16)),()=>{let i=ni(kr.wrap(Fr(s,e)),t,r,a).toVar();S.addAssign(i),(0,n.If)(i.greaterThan(0).and(N(o).mul(S).lessThan(i)),()=>{w.assign(0),T.assign(e),E.assign(i)}),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=Ar.wrap(Ir(l,i)),s=(0,n.select)(a.intensity.greaterThan(0),ri(a,e,t,r),(0,n.float)(0)).toVar();S.addAssign(s),(0,n.If)(s.greaterThan(0).and(N(o).mul(S).lessThan(s)),()=>{w.assign(1),T.assign(i),E.assign(s)}),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 a=ii(jr.wrap(Lr(d,i)),e,t,r).toVar();S.addAssign(a),(0,n.If)(a.greaterThan(0).and(N(o).mul(S).lessThan(a)),()=>{w.assign(2),T.assign(i),E.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)),()=>{let a=ai(Mr.wrap(Rr(p,i)),e,t,r).toVar();S.addAssign(a),(0,n.If)(a.greaterThan(0).and(N(o).mul(S).lessThan(a)),()=>{w.assign(3),T.assign(i),E.assign(a)}),C.addAssign(1)})})}),(0,n.If)(S.lessThanEqual(0),()=>{let t=(0,n.int)(i.x.mul((0,n.float)(x))).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 r=kr.wrap(Fr(s,t.sub(S)));(0,n.If)(r.intensity.greaterThan(0),()=>{let t=Gr(r,e);g.assign((0,n.normalize)(r.direction)),_.assign(r.color.mul(r.intensity).mul(t)),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=Ar.wrap(Ir(l,t.sub(S)));(0,n.If)(s.intensity.greaterThan(0),()=>{let t=(0,n.vec2)(i.y,N(o)).toVar(),c=Nr.wrap(si(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=jr.wrap(Lr(d,t.sub(S)));(0,n.If)(i.intensity.greaterThan(0),()=>{let t=Nr.wrap(li(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 i=Mr.wrap(Rr(p,t.sub(S)));(0,n.If)(i.intensity.greaterThan(0),()=>{let t=Nr.wrap(ci(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))})})})}).Else(()=>{let t=E.div((0,n.max)(S,1e-10)).toVar();(0,n.If)(w.equal((0,n.int)(0)).and(T.greaterThanEqual((0,n.int)(0))),()=>{let r=kr.wrap(Fr(s,T)),a=(0,n.normalize)(r.direction).toVar(),c=(0,n.float)(1).toVar();(0,n.If)(r.angle.greaterThan(0),()=>{let e=(0,n.cos)(r.angle.mul(.5)).toVar(),t=(0,n.mix)(e,(0,n.float)(1),i.y).toVar(),s=(0,n.sqrt)((0,n.max)((0,n.float)(0),(0,n.float)(1).sub(t.mul(t)))).toVar(),l=(0,n.float)(oi).mul(N(o)).toVar(),u=(0,n.normalize)(r.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();a.assign((0,n.normalize)(u.mul(t).add(d.mul((0,n.cos)(l)).add(f.mul((0,n.sin)(l))).mul(s))));let p=(0,n.float)(oi).mul((0,n.max)((0,n.float)(1).sub(e),1e-10));c.assign((0,n.float)(1).div(p))});let l=Gr(r,e);g.assign(a),_.assign(r.color.mul(r.intensity).mul(l)),v.assign(1e6),y.assign(c.mul(t)),b.assign((0,n.int)(0)),h.assign((0,n.bool)(!0))}),(0,n.If)(w.equal((0,n.int)(1)).and(T.greaterThanEqual((0,n.int)(0))),()=>{let r=Ar.wrap(Ir(l,T)),a=(0,n.vec2)(i.y,N(o)).toVar(),s=Nr.wrap(si(r,e,a,t));h.assign(s.valid),g.assign(s.direction),_.assign(s.emission),v.assign(s.distance),y.assign(s.pdf),b.assign(s.lightType)}),(0,n.If)(w.equal((0,n.int)(2)).and(T.greaterThanEqual((0,n.int)(0))),()=>{let n=jr.wrap(Lr(d,T)),r=Nr.wrap(li(n,e,t));h.assign(r.valid),g.assign(r.direction),_.assign(r.emission),v.assign(r.distance),y.assign(r.pdf),b.assign(r.lightType)}),(0,n.If)(w.equal((0,n.int)(3)).and(T.greaterThanEqual((0,n.int)(0))),()=>{let n=Mr.wrap(Rr(p,T)),r=Nr.wrap(ci(n,e,t));h.assign(r.valid),g.assign(r.direction),_.assign(r.emission),v.assign(r.distance),y.assign(r.pdf),b.assign(r.lightType)})})}),Nr({valid:h,direction:g,emission:_,distance:v,pdf:y,lightType:b})}),di=(0,n.Fn)(([e,t])=>{let r=t.NoV,i=t.NoL.toVar(),a=t.NoH,o=(0,n.float)(1).sub(e.metalness).mul((0,n.float)(1).sub(e.transmission)).toVar(),s=(0,n.float)(1).sub(o.mul((0,n.float)(1).sub(e.metalness))).toVar(),c=o.add(s).toVar(),l=(0,n.float)(0).toVar();return(0,n.If)(c.greaterThan(0),()=>{let t=(0,n.float)(1).div((0,n.max)(c,1e-10)).toVar();o.mulAssign(t),s.mulAssign(t),(0,n.If)(o.greaterThan(0).and(i.greaterThan(0)),()=>{l.addAssign(o.mul(i).mul(Pt))}),(0,n.If)(s.greaterThan(0).and(i.greaterThan(0)),()=>{let t=(0,n.max)(e.roughness,.02);l.addAssign(s.mul(nr(a,r,t)))})}),(0,n.max)(l,1e-8)});(0,n.Fn)(([e,t,n,r])=>di(r,Tt.wrap(Yt(n,e,t))));var fi=(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])=>{let k=(0,n.vec3)(0).toVar(),A=e.add(t.mul(.001)).toVar(),j=(0,n.Fn)(([e,t,n])=>ei(e,t,n,gn,v,y,b));return(0,n.If)(r.emissiveIntensity.lessThanEqual(10),()=>{let v=(0,n.vec3)(1).toVar(),y=Mt.wrap(en(r.roughness,r.metalness,c,v)),b=y.useBRDFSampling.toVar(),M=y.useLightSampling.toVar(),P=y.brdfWeight.toVar(),F=y.lightWeight.toVar(),ee=d.add(p).add(h).add(_).toVar(),te=(0,n.float)(.001).mul((0,n.float)(1).add((0,n.float)(c).mul(.5))).toVar(),ne=ee.greaterThan((0,n.int)(0)).toVar(),I=(0,n.float)(0).toVar();(0,n.If)(M.and(ne),()=>{I.addAssign(F)}),(0,n.If)(b,()=>{I.addAssign(P)}),(0,n.If)(I.lessThanEqual(0),()=>{I.assign(1),b.assign((0,n.bool)(!0)),P.assign(1)});let re=N(l).toVar(),ie=N(l).toVar(),ae=re,oe=(0,n.bool)(!1).toVar(),L=(0,n.bool)(!1).toVar(),R=(0,n.select)(ne,F,(0,n.float)(0)),se=(0,n.float)(1).div((0,n.max)(I,1e-10)),ce=R.mul(se);(0,n.If)(ae.lessThan(ce).and(M).and(ne),()=>{oe.assign((0,n.bool)(!0))}).ElseIf(b,()=>{L.assign((0,n.bool)(!0))}).ElseIf(ne,()=>{oe.assign((0,n.bool)(!0))}),(0,n.If)(oe,()=>{let e=(0,n.vec2)(ie,N(l)).toVar(),a=Nr.wrap(ui(A,t,r,e,c,l,u,d,f,p,m,h,g,_));(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);(0,n.If)(e.greaterThan(0).and(o.mul(e).greaterThan(te)).and(zr({direction:a.direction,surfaceNormal:t})),()=>{let o=(0,n.min)(a.distance.sub(.001),(0,n.float)(1e3)),s=j(A,a.direction,o);(0,n.If)(s.greaterThan(0),()=>{let o=Tt.wrap(Yt(t,i,a.direction)),c=wr(r,o),l=di(r,o).toVar(),u=(0,n.float)(1).toVar();(0,n.If)(l.greaterThan(0).and(b),()=>{let e=a.pdf.mul(F),t=l.mul(P);(0,n.If)(a.lightType.equal((0,n.int)(1)),()=>{u.assign(Kt({pdf1:e,pdf2:t}))})});let d=a.emission.mul(c).mul(e).mul(s).mul(u).div((0,n.max)(a.pdf,1e-10));k.addAssign(d.mul(I).div((0,n.max)(F,1e-10)))})})})}),(0,n.If)(L,()=>{(0,n.If)(o.greaterThan(0).and(b),()=>{let i=(0,n.max)((0,n.float)(0),(0,n.dot)(t,a)).toVar();(0,n.If)(i.greaterThan(0).and(zr({direction:a,surfaceNormal:t})),()=>{(0,n.If)(p.greaterThan((0,n.int)(0)),()=>{let c=(0,n.bool)(!1).toVar(),l=(0,n.float)(0).toVar(),u=(0,n.int)(-1).toVar();(0,n.Loop)({start:(0,n.int)(0),end:p,type:`int`,condition:`<`},({i})=>{let o=Ar.wrap(Ir(f,i));(0,n.If)(o.intensity.greaterThan(0),()=>{let s=ri(o,e,t,r).toVar();(0,n.If)(s.greaterThanEqual(te),()=>{(0,n.If)(Yr(o,A,a).toVar().greaterThan(0),()=>{(0,n.If)(s.greaterThan(l),()=>{l.assign(s),u.assign(i)}),c.assign((0,n.bool)(!0))})})})}),(0,n.If)(c.and(u.greaterThanEqual((0,n.int)(0))),()=>{let e=Ar.wrap(Ir(f,u)),t=Yr(e,A,a).toVar();(0,n.If)(t.greaterThan(0),()=>{let r=j(A,a,(0,n.min)(t.sub(.001),(0,n.float)(1e3)));(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).div((0,n.max)(e.area.mul(c),It)).toVar();a.divAssign((0,n.max)((0,n.float)(ee),1));let l=Kt({pdf1:o.mul(P),pdf2:a.mul(F)}).toVar(),u=e.color.mul(e.intensity).mul(s).mul(i).mul(r).mul(l).div((0,n.max)(o,1e-10));k.addAssign(u.mul(I).div((0,n.max)(P,1e-10)))})})})})})})})}),(0,n.If)(O,()=>{let e=(0,n.vec2)(N(l).toVar(),N(l).toVar()).toVar(),a=(0,n.vec3)(0).toVar(),o=xn(x,w,C,S,T,E,D,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(zr({direction:s,surfaceNormal:t})),()=>{let o=j(A,s,(0,n.float)(1e3));(0,n.If)(o.greaterThan(0),()=>{let l=Tt.wrap(Yt(t,i,s)),u=wr(r,l),d=di(r,l).toVar(),f=(0,n.select)(d.greaterThan(0),qt({pdf1:c,pdf2:d}),(0,n.float)(1)).toVar(),p=a.mul(u).mul(e).mul(o).mul(f).div((0,n.max)(c,1e-10));k.addAssign(p)})})})})}),k}),pi=(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(It),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)),f=(0,n.abs)((0,n.dot)(t,u)).toVar(),p=(0,n.abs)((0,n.dot)(r,u)).toVar(),m=Zn(p,a),h=d.add(f.mul(s)).toVar(),g=h.mul(h),_=f.mul(s).mul(s).div((0,n.max)(g,It));return m.mul(p).mul(_)}),mi=(0,n.Fn)(([e,t,r,i])=>{let a=e.add(t).toVar(),o=(0,n.dot)(a,a).toVar();return nr((0,n.max)((0,n.dot)(r,(0,n.select)(o.greaterThan(It),a.div((0,n.sqrt)(o)),r)),0),(0,n.max)((0,n.dot)(r,e),0),i)}),hi=(0,n.Fn)(([e])=>{let t=e.specularImportance.toVar(),r=t.greaterThan(.001).toVar(),i=e.diffuseImportance.toVar(),a=i.greaterThan(.001).toVar(),o=e.transmissionImportance.toVar(),s=o.greaterThan(.001).toVar(),c=e.clearcoatImportance.toVar(),l=c.greaterThan(.001).toVar(),u=t.add(i).add(o).add(c).toVar();return(0,n.If)(u.lessThan(.001),()=>{t.assign(0),i.assign(1),o.assign(0),c.assign(0),u.assign(1),r.assign((0,n.bool)(!1)),a.assign((0,n.bool)(!0)),s.assign((0,n.bool)(!1)),l.assign((0,n.bool)(!1))}).Else(()=>{let e=(0,n.float)(1).div(u).toVar();t.mulAssign(e),i.mulAssign(e),o.mulAssign(e),c.mulAssign(e),u.assign(1)}),jt({envWeight:(0,n.float)(0),specularWeight:t,diffuseWeight:i,transmissionWeight:o,clearcoatWeight:c,totalWeight:u,useEnv:(0,n.bool)(!1),useSpecular:r,useDiffuse:a,useTransmission:s,useClearcoat:l})}),gi=(0,n.Fn)(([e,t])=>{let r=(0,n.int)(2).toVar(),i=(0,n.float)(0).toVar(),a=(0,n.bool)(!1).toVar();return(0,n.If)(e.useSpecular.and(a.not()),()=>{i.addAssign(e.specularWeight),(0,n.If)(t.lessThan(i),()=>{r.assign(1),a.assign((0,n.bool)(!0))})}),(0,n.If)(e.useDiffuse.and(a.not()),()=>{i.addAssign(e.diffuseWeight),(0,n.If)(t.lessThan(i),()=>{r.assign(2),a.assign((0,n.bool)(!0))})}),(0,n.If)(e.useTransmission.and(a.not()),()=>{i.addAssign(e.transmissionWeight),(0,n.If)(t.lessThan(i),()=>{r.assign(3),a.assign((0,n.bool)(!0))})}),(0,n.If)(e.useClearcoat.and(a.not()),()=>{r.assign(4)}),r}),_i=(0,n.Fn)(([e])=>(0,n.max)(e,0).mul(Pt)),vi=(0,n.Fn)(([e,t,r,i,a,o,s,c])=>{let l=(0,n.vec3)(0).toVar(),u=(0,n.vec3)(0).toVar(),d=(0,n.float)(0).toVar(),f=(0,n.float)(0).toVar(),p=(0,n.float)(0).toVar();return(0,n.If)(c.diffuseImportance.greaterThanEqual(0).and(c.specularImportance.greaterThanEqual(0)).and(c.transmissionImportance.greaterThanEqual(0)).and(c.clearcoatImportance.greaterThanEqual(0)).not(),()=>{let e=(0,n.vec2)(N(s).toVar(),N(s).toVar());l.assign(ur(t,e)),u.assign(r.color.xyz),d.assign(1),f.assign(1)}).Else(()=>{let m=jt.wrap(hi(c).toVar()),h=N(s).toVar(),g=(0,n.vec2)(N(s).toVar(),N(s).toVar()).toVar(),_=gi(m,h).toVar(),v=(0,n.vec3)(0).toVar(),y=(0,n.float)(0).toVar(),b=(0,n.vec3)(0).toVar();(0,n.If)(_.equal((0,n.int)(1)),()=>{v.assign(i),y.assign(a),b.assign(o)}).ElseIf(_.equal((0,n.int)(2)),()=>{v.assign(ur(t,g)),y.assign(_i((0,n.max)((0,n.dot)(t,v),0))),b.assign(Tr(e,v,t,r))}).ElseIf(_.equal((0,n.int)(3)),()=>{let i=(0,n.dot)(e,t).greaterThan(0),a=hr.wrap(xr(e,t,r.ior,r.roughness,i,r.dispersion,g,s,(0,n.float)(0)).toVar());v.assign(a.direction),y.assign(a.pdf),b.assign(Tr(e,v,t,r))}).Else(()=>{v.assign(i),y.assign(a),b.assign(o)});let x=(0,n.dot)(t,v).toVar(),S=(0,n.max)(x,0).toVar(),C=(0,n.abs)(x),w=(0,n.float)(0).toVar();(0,n.If)(m.useSpecular,()=>{let i=nr((0,n.max)((0,n.dot)(t,(0,n.normalize)(e.add(v))),.001),(0,n.max)((0,n.dot)(t,e),.001),r.roughness);w.addAssign(m.specularWeight.mul(i))}),(0,n.If)(m.useDiffuse,()=>{w.addAssign(m.diffuseWeight.mul(_i(S)))}),(0,n.If)(m.useTransmission.and(r.transmission.greaterThan(0)),()=>{let i=(0,n.dot)(e,t).greaterThan(0);w.addAssign(m.transmissionWeight.mul(pi(e,v,t,r.ior,r.roughness,i)))}),(0,n.If)(m.useClearcoat.and(r.clearcoat.greaterThan(0)),()=>{w.addAssign(m.clearcoatWeight.mul(mi(e,v,t,r.clearcoatRoughness)))}),y.assign((0,n.max)(y,zt)),w.assign((0,n.max)(w,zt));let T=y.div(w).toVar(),E=(0,n.select)(_.equal((0,n.int)(3)),C,S);l.assign(v),u.assign(b.mul(E).mul(T).div(y)),d.assign(T),f.assign(y),p.assign(w)}),Pr({direction:l,throughput:u,misWeight:d,pdf:f,combinedPdf:p})}),yi=y({position:`vec3`,normal:`vec3`,emission:`vec3`,direction:`vec3`,distance:`float`,pdf:`float`,area:`float`,cosThetaLight:`float`,valid:`bool`}),bi=y({contribution:`vec3`,hasEmissive:`bool`,emissionOnly:`vec3`,distance:`float`}),xi=(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))}),Si=(0,n.Fn)(([e,t,r])=>(0,n.length)((0,n.cross)(t.sub(e),r.sub(e))).mul(.5)),Ci=(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))}),wi=(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}),Ti=y({direction:`vec3`,position:`vec3`,solidAngle:`float`,valid:`bool`}),Ei=(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))}),Di=(0,n.Fn)(([e,t,r,i,a])=>{let o=Ti({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=Ci(e,t,r,i);return o.solidAngle.assign(u),(0,n.If)(u.greaterThan(1e-7),()=>{let d=(0,n.clamp)((0,n.dot)(Ei((0,n.cross)(s,c)),Ei((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=Ei(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=Ei(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}),Oi=(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)}),ki=(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 Ai=8,ji=2,Mi=y({v0:`vec3`,v1:`vec3`,v2:`vec3`,n0:`vec3`,n1:`vec3`,n2:`vec3`,materialIndex:`int`}),Ni=(0,n.Fn)(([e,t])=>{let r=Y(t,e,(0,n.int)(0),(0,n.int)(Ai)),i=Y(t,e,(0,n.int)(1),(0,n.int)(Ai)),a=Y(t,e,(0,n.int)(2),(0,n.int)(Ai)),o=Y(t,e,(0,n.int)(3),(0,n.int)(Ai)),s=Y(t,e,(0,n.int)(4),(0,n.int)(Ai)),c=Y(t,e,(0,n.int)(5),(0,n.int)(Ai)),l=Y(t,e,(0,n.int)(7),(0,n.int)(Ai));return Mi({v0:r.xyz,v1:i.xyz,v2:a.xyz,n0:o.xyz,n1:s.xyz,n2:c.xyz,materialIndex:(0,n.int)(l.z)})}),Pi=(0,n.Fn)(([e,t,r,i,a,o,s])=>{let c=Mi.wrap(Ni(e,a)),l=Si(c.v0,c.v1,c.v2),u=Y(o,c.materialIndex,(0,n.int)(Vt.EMISSIVE_ROUGHNESS),q),d=Y(o,c.materialIndex,(0,n.int)(Vt.IOR_TRANSMISSION),q),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)(wi(c.v0,c.v1,c.v2,i),()=>{let e=Ci(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,zt)}),Fi=(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)(ji)))).b;(0,n.If)(s.lessThan(i),()=>{a.assign(r.add(1))}).Else(()=>{o.assign(r)})}),a}),Ii=(0,n.Fn)(([e,t,r,i,a,o,s,c])=>{let l=yi({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)(o.greaterThan((0,n.int)(0)),()=>{let u=Fi(i,a,o,N(r)).toVar(),d=a.add(u.mul((0,n.int)(ji))),f=i.element(d),p=i.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=Mi.wrap(Ni(m,c)),y=(0,n.vec2)(N(r).toVar(),N(r).toVar()),b=(0,n.normalize)((0,n.cross)(v.v1.sub(v.v0),v.v2.sub(v.v0)));(0,n.If)(wi(v.v0,v.v1,v.v2,e),()=>{let r=Ti.wrap(Di(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),c=(0,n.dot)(i,b.negate());(0,n.If)(o.greaterThan(0).and(c.greaterThan(0)),()=>{let t=Oi(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))),u=(0,n.length)(a.sub(e)),d=h.div((0,n.max)(s,(0,n.float)(1e-10))).div(r.solidAngle);l.position.assign(a),l.normal.assign(o),l.emission.assign(g),l.direction.assign(i),l.distance.assign(u),l.pdf.assign((0,n.max)(d,zt)),l.area.assign(_),l.cosThetaLight.assign(c),l.valid.assign(!0)})})}).Else(()=>{let r=xi(v.v0,v.v1,v.v2,y),i=ki(v.n0,v.n1,v.n2,y),a=r.sub(e),o=(0,n.dot)(a,a),c=(0,n.sqrt)(o),u=a.div(c),d=(0,n.dot)(u,t),f=(0,n.dot)(u,i.negate());(0,n.If)(d.greaterThan(0).and(f.greaterThan(0)),()=>{let e=h.div((0,n.max)(s,(0,n.float)(1e-10)).mul(_)).mul(o).div(f);l.position.assign(r),l.normal.assign(i),l.emission.assign(g),l.direction.assign(u),l.distance.assign(c),l.pdf.assign((0,n.max)(e,zt)),l.area.assign(_),l.cosThetaLight.assign(f),l.valid.assign(!0)})})}),l}),Li=(0,n.Fn)(([e,t,r,i,a,o,s,c,l,u,d,f,p,m])=>{let h=bi({contribution:(0,n.vec3)(0),hasEmissive:!1,emissionOnly:(0,n.vec3)(0),distance:(0,n.float)(0)}).toVar();return(0,n.If)(a.greaterThan((0,n.int)(1)).and(i.roughness.greaterThan(.9)).and(i.metalness.lessThan(.1)).not(),()=>{let a=yi.wrap(Ii(e,t,o,c,l,u,d,f));(0,n.If)(a.valid.and(a.pdf.greaterThan(0)),()=>{h.hasEmissive.assign(!0),h.emissionOnly.assign(a.emission),h.distance.assign(a.distance);let o=(0,n.max)((0,n.float)(0),(0,n.dot)(t,a.direction));(0,n.If)(o.greaterThan(0),()=>{let c=m(e,t,i),l=e.add(c),u=a.distance.sub(.001),d=p(l,a.direction,u);(0,n.If)(d.greaterThan(0),()=>{let e=Tt.wrap(Yt(t,r,a.direction)),c=wr(i,e),l=di(i,e),u=(0,n.select)(l.greaterThan(0),Kt({pdf1:a.pdf,pdf2:l}),(0,n.float)(1));h.contribution.assign(a.emission.mul(c).mul(o).div(a.pdf).mul(d).mul(s).mul(u))})})})}),h}),Ri=(0,n.Fn)(([e,t,n,r,i,a,o,s,c,l,u,d,f,p])=>bi.wrap(Li(e,t,n,r,i,a,o,s,c,l,u,d,f,p)).contribution),zi=4,Bi=2,Vi=32,Hi=(0,n.Fn)(([e,t,r,i,a,o,s])=>{let c=yi({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)(Vi,()=>{let t=u.mul((0,n.int)(zi)),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)(zi)),p=i.element(f),m=i.element(f.add((0,n.int)(1))),h=c.mul((0,n.int)(zi)),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)(zi)),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)(Bi))),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)(Bi))),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=Mi.wrap(Ni(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)(wi(D.v0,D.v1,D.v2,e),()=>{let r=Ti.wrap(Di(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=Oi(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,zt)),c.area.assign(E),c.cosThetaLight.assign(s),c.valid.assign(!0)})})}).Else(()=>{let r=xi(D.v0,D.v1,D.v2,O),i=ki(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,zt)),c.area.assign(E),c.cosThetaLight.assign(f),c.valid.assign(!0)})})}),c}),Ui=0,Wi=1,Gi=2,Ki=3,qi=y({radiance:`vec4`,objectNormal:`vec3`,objectColor:`vec3`,objectID:`float`,firstHitPoint:`vec3`,firstHitDistance:`float`}),Ji=(0,n.Fn)(([e,t,r,i,a])=>{let o=a.toVar();return(0,n.If)(r.not().or(i.notEqual(t)),()=>{o.assign($t(e.metalness,e.roughness,e.transmission,e.clearcoat,e.emissive))}),o}),Yi=(0,n.Fn)(([e,t,r,i,a,o,s,c,l,u])=>{let d=(0,n.vec3)(0).toVar(),f=(0,n.vec3)(0).toVar(),p=(0,n.float)(0).toVar(),m=c.toVar();(0,n.If)(s.not(),()=>{(0,n.If)(l,()=>{m.assign(ar(r,o,u))}).Else(()=>{let e=At({F0:Xn(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();m.assign(ar(r,o,e))})});let h=i.x.toVar(),g=(0,n.vec2)(i.y,N(a)).toVar(),_=(0,n.vec3)(0).toVar(),v=m.diffuse.toVar(),y=v.add(m.specular).toVar(),b=y.add(m.sheen).toVar(),x=b.add(m.clearcoat),S=(0,n.clamp)((0,n.dot)(t,e),.001,1).toVar();return(0,n.If)(h.lessThan(v),()=>{d.assign(lr({N:t,xi:g}));let i=(0,n.clamp)((0,n.dot)(t,d),0,1);p.assign(i.mul(Pt)),f.assign(Tr(e,d,t,r))}).ElseIf(h.lessThan(y),()=>{let a=Jt({N:t}),o=dr({V:a.transpose().mul(e),roughness:r.roughness,Xi:i});_.assign(a.mul(o));let s=(0,n.clamp)((0,n.dot)(t,_),.001,1);d.assign((0,n.reflect)(e.negate(),_)),p.assign(nr(s,S,r.roughness)),f.assign(Tr(e,d,t,r))}).ElseIf(h.lessThan(b),()=>{_.assign(cr({N:t,roughness:r.sheenRoughness,Xi:i}));let a=(0,n.clamp)((0,n.dot)(t,_),.001,1),o=(0,n.clamp)((0,n.dot)(e,_),.001,1);d.assign((0,n.reflect)(e.negate(),_));let s=(0,n.dot)(t,d).toVar();(0,n.If)(s.lessThanEqual(0),()=>{d.assign(lr({N:t,xi:i})),s.assign((0,n.clamp)((0,n.dot)(t,d),0,1)),p.assign(s.mul(Pt)),f.assign(Tr(e,d,t,r))}).Else(()=>{p.assign(Qn(a,r.sheenRoughness).mul(a).div((0,n.float)(4).mul(o))),p.assign((0,n.max)(p,zt)),f.assign(Tr(e,d,t,r))})}).ElseIf(h.lessThan(x),()=>{let a=(0,n.clamp)(r.clearcoatRoughness,Rt,1);_.assign(cr({N:t,roughness:a,Xi:i}));let o=(0,n.clamp)((0,n.dot)(t,_),0,1);d.assign((0,n.reflect)(e.negate(),_)),p.assign(nr(o,S,a)),p.assign((0,n.max)(p,zt)),f.assign(Tr(e,d,t,r))}).Else(()=>{let o=(0,n.dot)(e,t).greaterThan(0),s=hr.wrap(xr(e,t,r.ior,r.roughness,o,r.dispersion,i,a,(0,n.float)(0)));d.assign(s.direction),p.assign((0,n.max)(s.pdf,zt)),f.assign(Tr(e,d,t,r))}),p.assign((0,n.max)(p,zt)),St({direction:d,value:f,pdf:p})}),Xi=(0,n.Fn)(([e,t,r,i,a,o,s,c,l,u,d])=>{let f=(0,n.float)(1).toVar();return(0,n.If)(e.greaterThanEqual((0,n.int)(3)),()=>{let p=(0,n.max)(Wt({v:t}),0).toVar();(0,n.If)(p.lessThan(8e-4).and(e.greaterThan((0,n.int)(4))),()=>{let e=(0,n.max)(p.mul(125),.01),t=N(o);f.assign((0,n.select)(t.lessThan(e),e,(0,n.float)(0)))}).Else(()=>{let t=Ot.wrap(Ji(r,i,s,c,l)).toVar(),m=t.complexityScore.toVar();(0,n.If)(t.isMetallic.and(t.isSmooth).and(e.lessThan((0,n.int)(7))),()=>{m.addAssign(.3)}),(0,n.If)(t.isTransmissive.and(e.lessThan((0,n.int)(6))),()=>{m.addAssign(.25)}),(0,n.If)(t.isEmissive.and(e.lessThan((0,n.int)(4))),()=>{m.addAssign(.15)}),m.assign((0,n.clamp)(m,0,1));let h=(0,n.int)(3).toVar();(0,n.If)(m.greaterThan(.6),()=>{h.assign(5)}).ElseIf(m.greaterThan(.4),()=>{h.assign(4)}),(0,n.If)(e.lessThan(h),()=>{f.assign(1)}).Else(()=>{let r=t.complexityScore.toVar();(0,n.If)(t.isMetallic.and(t.isSmooth),()=>{r.addAssign(.15)}),(0,n.If)(t.isTransmissive.and(t.hasClearcoat),()=>{r.addAssign(.12)}),(0,n.If)(t.isEmissive,()=>{r.addAssign(.1)}),r.assign((0,n.clamp)(r,0,1));let i=(0,n.float)(.5).toVar();(0,n.If)(u.and(d).and(p.greaterThan(.01)),()=>{let e=(0,n.clamp)(a.y,0,1);i.assign((0,n.mix)((0,n.float)(.3),(0,n.float)(.8),e.mul(e)))});let s=(0,n.smoothstep)((0,n.float)(.001),(0,n.float)(.1),p),c=p.mul((0,n.mix)(r.mul(.7),i,.3)).mul(s).toVar(),l=(0,n.mix)((0,n.clamp)(m.mul(.4).add(p.mul(.6)).mul(1.2),.15,.95),(0,n.clamp)(p.mul(.4).add(m.mul(.1)),.03,.6),(0,n.clamp)((0,n.float)(e.sub(h)).div(10),0,1)).toVar();l.assign((0,n.mix)(l,(0,n.max)(l,c),.4)),(0,n.If)(m.greaterThan(.5),()=>{let e=m.sub(.5).mul(.6);l.assign((0,n.mix)(l,(0,n.float)(1),e))});let g=(0,n.float)(.12).add(m.mul(.08)),_=(0,n.exp)((0,n.float)(e.sub(h)).negate().mul(g));l.mulAssign(_);let v=(0,n.select)(t.isEmissive,(0,n.float)(.04),(0,n.float)(.02));l.assign((0,n.max)(l,v));let y=N(o);f.assign((0,n.select)(y.lessThan(l),l,(0,n.float)(0)))})})}),f}),Zi=(0,n.Fn)(([e,t,r,i,a,o,s,c,l,u,d,f])=>{let p=(0,n.vec4)(0).toVar();return(0,n.If)(e.and(c.not()),()=>{p.assign((0,n.vec4)(0))}).Else(()=>{let c=r.toVar();(0,n.If)(e.and(u),()=>{c.assign(Cn(t,r,d,f))});let m=Sn({tex:i,samp:(0,n.sampler)(i),direction:c,environmentMatrix:a,environmentIntensity:o,enableEnvironmentLight:s});(0,n.If)(e,()=>{p.assign(m.mul(l))}).Else(()=>{p.assign(m)})}),p}),Qi=(0,n.wgslFn)(`
532
532
  fn regularizePathContribution( contribution: vec3f, pathLength: f32, fireflyThreshold: f32, frame: i32 ) -> vec3f {
533
533
  let threshold = calculateFireflyThreshold( fireflyThreshold, i32( pathLength ), frame );
534
534
  return applySoftSuppressionRGB( contribution, threshold, 0.5f );
535
535
  }
536
- `,[Yt,Zt]),Qi=(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,F,I,ee,te,L,ne,ie,ae,R,z,oe,se,B,ce,le,ue,V])=>{let de=(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(),H=(0,n.int)(0).toVar(),Se=(0,n.float)(1).toVar(),Ce=(0,n.float)(1).toVar(),we=(0,n.float)(1).toVar(),Te=(0,n.vec3)(1).toVar(),Ee=(0,n.vec3)(1).toVar(),De=(0,n.vec3)(1).toVar(),Oe=(0,n.float)(0).toVar(),U=(0,n.float)(0).toVar(),W=(0,n.float)(0).toVar(),ke=(0,n.vec3)(0).toVar(),Ae=(0,n.vec3)(0).toVar(),je=(0,n.vec3)(0).toVar(),Me=(0,n.float)(0).toVar(),Ne=P.toVar(),Pe=F.toVar(),Fe=(0,n.int)(Hi).toVar(),Ie=(0,n.bool)(!0).toVar(),Le=(0,n.bool)(!1).toVar(),Re=(0,n.bool)(!1).toVar(),ze=(0,n.bool)(!1).toVar(),Be=(0,n.int)(-1).toVar(),Ve=Dt({isMetallic:!1,isRough:!1,isSmooth:!1,isTransmissive:!1,hasClearcoat:!1,isEmissive:!1,complexityScore:(0,n.float)(0)}).toVar(),He=St({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(),Ue=kt({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(),We=(0,n.int)(0).toVar(),Ge=e.origin.toVar(),Ke=e.direction.toVar();return(0,n.Loop)({start:(0,n.int)(0),end:P.add(F).add(1),type:`int`,condition:`<`},({i:e})=>{Ne.assign(P.sub(We)),Ie.assign(e.equal((0,n.int)(0))),(0,n.If)(We.greaterThan(P),()=>{(0,n.Break)()});let F=(0,n.select)(e.greaterThan((0,n.int)(0)),ne,(0,n.float)(1)),qe=_t({origin:Ge,direction:Ke}),G=bt.wrap(mn(qe,i,a)).toVar();(0,n.If)(G.didHit.and(H.greaterThan((0,n.int)(0))),()=>{let e=(0,n.vec3)(0).toVar();(0,n.If)(H.equal((0,n.int)(1)),()=>{e.assign(ke)}).ElseIf(H.equal((0,n.int)(2)),()=>{e.assign(Ae)}).ElseIf(H.equal((0,n.int)(3)),()=>{e.assign(je)}),fe.mulAssign((0,n.exp)(e.mul(G.dst).negate()))}),(0,n.If)(G.didHit.not(),()=>{let t=Xi(Ie,Ge,Ke,S,w,C,k,ee,I,j,M,N),r=(0,n.float)(1).toVar();(0,n.If)(he.greaterThan(0).and(k).and(A),()=>{let e=yn(S,Ke,w,E,D,O).w.toVar();(0,n.If)(e.greaterThan(0),()=>{r.assign(Kt({pdf1:he,pdf2:e}))})}),de.addAssign(Zi({contribution:t.xyz.mul(fe).mul(F).mul(r),pathLength:(0,n.float)(e),fireflyThreshold:L,frame:(0,n.int)(V)})),(0,n.If)(te.and(me.not()),()=>{pe.assign(0)}).ElseIf(te.not(),()=>{pe.mulAssign(t.a)}),(0,n.Break)()});let K=vt.wrap(tn(G.materialIndex,o)).toVar(),Je=G.uv.toVar(),Ye=G.normal.toVar();(0,n.If)(K.displacementMapIndex.greaterThanEqual((0,n.int)(0)).and(K.displacementScale.greaterThan(0)),()=>{let t=Bn.wrap(Vn(qe,G,a,p,K,e)).toVar();Je.assign(t.uv),Ye.assign(t.normal),G.hitPoint.assign(t.hitPoint)});let Xe=Et.wrap(Nn(s,c,l,u,d,f,K,Je,G.normal)).toVar();K.color.assign(Xe.albedo),K.metalness.assign((0,n.clamp)(Xe.metalness,0,1)),K.roughness.assign((0,n.clamp)(Xe.roughness,It,1));let q=Xe.normal.toVar();(0,n.If)(K.displacementMapIndex.greaterThanEqual((0,n.int)(0)).and(K.displacementScale.greaterThan(0)),()=>{q.assign((0,n.normalize)(Ye.add(Xe.normal.sub(G.normal))))});let Ze=(0,n.float)(1).toVar(),Qe=(0,n.float)(1).toVar();(0,n.If)(H.equal((0,n.int)(1)),()=>{Ze.assign(Se)}).ElseIf(H.equal((0,n.int)(2)),()=>{Ze.assign(Ce),Qe.assign(Se)}).ElseIf(H.equal((0,n.int)(3)),()=>{Ze.assign(we),Qe.assign(Ce)});let $e=fr.wrap(Sr(qe,q,K,t,Pe,Ze,Qe,Me)).toVar();Me.assign($e.pathWavelength),(0,n.If)($e.continueRay,()=>{let e=(0,n.bool)(!1).toVar();(0,n.If)($e.isTransmissive.and(Pe.greaterThan((0,n.int)(0))),()=>{Pe.subAssign(1),Fe.assign((0,n.int)(Wi)),e.assign((0,n.bool)(!0)),(0,n.If)($e.didReflect.not(),()=>{(0,n.If)($e.entering,()=>{(0,n.If)(H.lessThan((0,n.int)(3)),()=>{H.addAssign(1);let e=(0,n.select)(K.attenuationDistance.greaterThan(0),(0,n.log)((0,n.max)(K.attenuationColor,(0,n.vec3)(.001))).negate().div(K.attenuationDistance),(0,n.vec3)(0)).toVar();(0,n.If)(H.equal((0,n.int)(1)),()=>{Se.assign(K.ior),Te.assign(K.attenuationColor),Oe.assign(K.attenuationDistance),ke.assign(e)}).ElseIf(H.equal((0,n.int)(2)),()=>{Ce.assign(K.ior),Ee.assign(K.attenuationColor),U.assign(K.attenuationDistance),Ae.assign(e)}).ElseIf(H.equal((0,n.int)(3)),()=>{we.assign(K.ior),De.assign(K.attenuationColor),W.assign(K.attenuationDistance),je.assign(e)})})}).Else(()=>{(0,n.If)(H.greaterThan((0,n.int)(0)),()=>{H.subAssign(1)})})})}).ElseIf($e.isAlphaSkip,()=>{e.assign((0,n.bool)(!0))}),fe.mulAssign($e.throughput),(0,n.If)(te.not(),()=>{pe.mulAssign($e.alpha)});let t=(0,n.select)($e.entering,q,q.negate()),r=(0,n.select)($e.didReflect,t,Ke);Ge.assign(G.hitPoint.add(r.mul(.001))),Ke.assign($e.direction),Ie.assign((0,n.bool)(!1)),Le.assign((0,n.bool)(!1)),ze.assign((0,n.bool)(!1)),(0,n.If)(e.not(),()=>{We.addAssign(1)}),(0,n.Continue)()}),(0,n.If)(te.not(),()=>{pe.mulAssign($e.alpha)}),me.assign((0,n.bool)(!0));let et=re(le,r,e,t,(0,n.int)(-1),ue,V).toVar(),tt=Ke.negate().toVar();K.sheenRoughness.assign((0,n.clamp)(K.sheenRoughness,It,1)),Ve.assign(Dt.wrap(qi(K,G.materialIndex,Re,Be,Ve))),Re.assign((0,n.bool)(!0)),Be.assign(G.materialIndex),(0,n.If)(ze.not(),()=>{Ue.assign(or(q,tt,K,Xe,Ve)),ze.assign((0,n.bool)(!0))});let nt=(0,n.vec3)(0).toVar(),rt=(0,n.vec3)(0).toVar(),it=(0,n.float)(0).toVar();(0,n.If)(K.clearcoat.greaterThan(0),()=>{let e=Er.wrap(Dr(qe,G,K,et,t));nt.assign(e.L),rt.assign(e.brdf),it.assign(e.pdf)}).Else(()=>{let e=xt.wrap(Ji(tt,q,K,et,t,Ve,Le,He,ze,Ue));nt.assign(e.direction),rt.assign(e.value),it.assign(e.pdf),Le.assign((0,n.bool)(!0))}),(0,n.If)((0,n.length)(Xe.emissive).greaterThan(0),()=>{let t=(0,n.float)(1).toVar();(0,n.If)(ie.equal((0,n.int)(1)).and(z.greaterThan((0,n.int)(0))).and(he.greaterThan(0)),()=>{let e=Ni(G.triangleIndex,G.dst,Ke,Ge,a,o,oe);t.assign(Gt({pdf1:he,pdf2:e}))}),de.addAssign(Zi({contribution:Xe.emissive.mul(fe).mul(F).mul(t),pathLength:(0,n.float)(e),fireflyThreshold:L,frame:(0,n.int)(V)}))});let at=di(G.hitPoint,q,K,tt,nt,it,rt,e,t,m,h,g,_,v,y,b,x,i,a,o,S,C,w,T,E,D,O,k);de.addAssign(Zi({contribution:at.mul(fe).mul(F),pathLength:(0,n.float)(e),fireflyThreshold:L,frame:(0,n.int)(V)})),(0,n.If)(ie.equal((0,n.int)(1)).and(z.greaterThan((0,n.int)(0))),()=>{let r=(0,n.Fn)(([e,t,n])=>$r(e,t,n,hn,i,a,o));(0,n.If)(ce.greaterThan((0,n.int)(0)),()=>{let i=vi.wrap(Vi(G.hitPoint,q,t,B,ae,R,a));(0,n.If)(e.greaterThan((0,n.int)(1)).and(K.roughness.greaterThan(.9)).and(K.metalness.lessThan(.1)).not().and(i.valid).and(i.pdf.greaterThan(0)),()=>{let t=(0,n.max)((0,n.float)(0),(0,n.dot)(q,i.direction));(0,n.If)(t.greaterThan(0),()=>{let a=ei(G.hitPoint,q,K),o=G.hitPoint.add(a),s=i.distance.sub(.001),c=r(o,i.direction,s);(0,n.If)(c.greaterThan(0),()=>{let r=wt.wrap(Jt(q,tt,i.direction)),a=Cr(K,r),o=ui(K,r),s=(0,n.select)(o.greaterThan(0),Gt({pdf1:i.pdf,pdf2:o}),(0,n.float)(1)),l=i.emission.mul(a).mul(t).div(i.pdf).mul(c).mul(se).mul(s);de.addAssign(Zi({contribution:l.mul(fe).mul(F),pathLength:(0,n.float)(e),fireflyThreshold:L,frame:(0,n.int)(V)}))})})})}).Else(()=>{let i=Li(G.hitPoint,q,tt,K,e,t,se,ae,R,z,oe,a,r,ei);de.addAssign(Zi({contribution:i.mul(fe).mul(F),pathLength:(0,n.float)(e),fireflyThreshold:L,frame:(0,n.int)(V)}))})});let ot=Ct.wrap(ar(K,e,Ve)),st=Nr.wrap(_i(tt,q,K,nt,it,rt,t,ot));fe.mulAssign(st.throughput),Ge.assign(G.hitPoint.add(q.mul(.001))),Ke.assign(st.direction),he.assign(st.combinedPdf),Ie.assign((0,n.bool)(!1)),(0,n.If)(K.metalness.greaterThan(.7).and(K.roughness.lessThan(.3)),()=>{Fe.assign((0,n.int)(Ui))}).ElseIf(K.transmission.greaterThan(.5),()=>{Fe.assign((0,n.int)(Wi))}).Else(()=>{Fe.assign((0,n.int)(Gi))}),(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 ct=Yi(e,fe,K,G.materialIndex,Ke,t,Re,Be,Ve,k,A);(0,n.If)(ct.lessThanEqual(0),()=>{(0,n.Break)()}),fe.divAssign(ct),We.addAssign(1),Le.assign((0,n.bool)(!1)),ze.assign((0,n.bool)(!1))}),Ki({radiance:(0,n.vec4)(de,pe),objectNormal:ge,objectColor:_e,objectID:ve,firstHitPoint:ye,firstHitDistance:be})}),$i=(0,n.wgslFn)(`
536
+ `,[Xt,Qt]),$i=(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,F,ee,te,ne,I,re,ae,oe,L,R,se,ce,z,le,ue,de,B])=>{let fe=(0,n.vec3)(0).toVar(),pe=(0,n.vec3)(1).toVar(),me=(0,n.float)(1).toVar(),he=(0,n.bool)(!1).toVar(),ge=(0,n.float)(0).toVar(),_e=(0,n.vec3)(0).toVar(),ve=(0,n.vec3)(0).toVar(),ye=(0,n.float)(-1e3).toVar(),be=e.origin.toVar(),xe=(0,n.float)(1e10).toVar(),Se=(0,n.bool)(!1).toVar(),V=(0,n.int)(0).toVar(),Ce=(0,n.float)(1).toVar(),we=(0,n.float)(1).toVar(),Te=(0,n.float)(1).toVar(),Ee=(0,n.vec3)(1).toVar(),De=(0,n.vec3)(1).toVar(),Oe=(0,n.vec3)(1).toVar(),ke=(0,n.float)(0).toVar(),H=(0,n.float)(0).toVar(),U=(0,n.float)(0).toVar(),Ae=(0,n.vec3)(0).toVar(),je=(0,n.vec3)(0).toVar(),Me=(0,n.vec3)(0).toVar(),Ne=(0,n.float)(0).toVar(),Pe=P.toVar(),Fe=F.toVar(),Ie=(0,n.int)(Ui).toVar(),Le=(0,n.bool)(!0).toVar(),Re=(0,n.bool)(!1).toVar(),ze=(0,n.bool)(!1).toVar(),Be=(0,n.bool)(!1).toVar(),Ve=(0,n.int)(-1).toVar(),He=Ot({isMetallic:!1,isRough:!1,isSmooth:!1,isTransmissive:!1,hasClearcoat:!1,isEmissive:!1,complexityScore:(0,n.float)(0)}).toVar(),Ue=Ct({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(),We=At({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(),Ge=(0,n.int)(0).toVar(),Ke=e.origin.toVar(),qe=e.direction.toVar();return(0,n.Loop)({start:(0,n.int)(0),end:P.add(F).add(1),type:`int`,condition:`<`},({i:e})=>{Pe.assign(P.sub(Ge)),Le.assign(e.equal((0,n.int)(0))),(0,n.If)(Ge.greaterThan(P),()=>{(0,n.Break)()});let F=(0,n.select)(e.greaterThan((0,n.int)(0)),re,(0,n.float)(1)),Je=vt({origin:Ke,direction:qe}),W=xt.wrap(hn(Je,i,a)).toVar();(0,n.If)(W.didHit.and(V.greaterThan((0,n.int)(0))),()=>{let e=(0,n.vec3)(0).toVar();(0,n.If)(V.equal((0,n.int)(1)),()=>{e.assign(Ae)}).ElseIf(V.equal((0,n.int)(2)),()=>{e.assign(je)}).ElseIf(V.equal((0,n.int)(3)),()=>{e.assign(Me)}),pe.mulAssign((0,n.exp)(e.mul(W.dst).negate()))}),(0,n.If)(W.didHit.not(),()=>{let t=Zi(Le,Ke,qe,S,w,C,k,te,ee,j,M,N),r=(0,n.float)(1).toVar();(0,n.If)(ge.greaterThan(0).and(k).and(A),()=>{let e=bn(S,qe,w,E,D,O).w.toVar();(0,n.If)(e.greaterThan(0),()=>{r.assign(qt({pdf1:ge,pdf2:e}))})}),fe.addAssign(Qi({contribution:t.xyz.mul(pe).mul(F).mul(r),pathLength:(0,n.float)(e),fireflyThreshold:I,frame:(0,n.int)(B)})),(0,n.If)(ne.and(he.not()),()=>{me.assign(0)}).ElseIf(ne.not(),()=>{me.mulAssign(t.a)}),(0,n.Break)()});let G=yt.wrap(nn(W.materialIndex,o)).toVar(),Ye=W.uv.toVar(),Xe=W.normal.toVar();(0,n.If)(G.displacementMapIndex.greaterThanEqual((0,n.int)(0)).and(G.displacementScale.greaterThan(0)),()=>{let t=Vn.wrap(Hn(Je,W,a,p,G,e)).toVar();Ye.assign(t.uv),Xe.assign(t.normal),W.hitPoint.assign(t.hitPoint)});let Ze=Dt.wrap(Pn(s,c,l,u,d,f,G,Ye,W.normal)).toVar();G.color.assign(Ze.albedo),G.metalness.assign((0,n.clamp)(Ze.metalness,0,1)),G.roughness.assign((0,n.clamp)(Ze.roughness,Lt,1));let K=Ze.normal.toVar();(0,n.If)(G.displacementMapIndex.greaterThanEqual((0,n.int)(0)).and(G.displacementScale.greaterThan(0)),()=>{K.assign((0,n.normalize)(Xe.add(Ze.normal.sub(W.normal))))});let Qe=(0,n.float)(1).toVar(),$e=(0,n.float)(1).toVar();(0,n.If)(V.equal((0,n.int)(1)),()=>{Qe.assign(Ce)}).ElseIf(V.equal((0,n.int)(2)),()=>{Qe.assign(we),$e.assign(Ce)}).ElseIf(V.equal((0,n.int)(3)),()=>{Qe.assign(Te),$e.assign(we)});let et=pr.wrap(Cr(Je,K,G,t,Fe,Qe,$e,Ne)).toVar();Ne.assign(et.pathWavelength),(0,n.If)(et.continueRay,()=>{let e=(0,n.bool)(!1).toVar();(0,n.If)(et.isTransmissive.and(Fe.greaterThan((0,n.int)(0))),()=>{Fe.subAssign(1),Ie.assign((0,n.int)(Gi)),e.assign((0,n.bool)(!0)),(0,n.If)(et.didReflect.not(),()=>{(0,n.If)(et.entering,()=>{(0,n.If)(V.lessThan((0,n.int)(3)),()=>{V.addAssign(1);let e=(0,n.select)(G.attenuationDistance.greaterThan(0),(0,n.log)((0,n.max)(G.attenuationColor,(0,n.vec3)(.001))).negate().div(G.attenuationDistance),(0,n.vec3)(0)).toVar();(0,n.If)(V.equal((0,n.int)(1)),()=>{Ce.assign(G.ior),Ee.assign(G.attenuationColor),ke.assign(G.attenuationDistance),Ae.assign(e)}).ElseIf(V.equal((0,n.int)(2)),()=>{we.assign(G.ior),De.assign(G.attenuationColor),H.assign(G.attenuationDistance),je.assign(e)}).ElseIf(V.equal((0,n.int)(3)),()=>{Te.assign(G.ior),Oe.assign(G.attenuationColor),U.assign(G.attenuationDistance),Me.assign(e)})})}).Else(()=>{(0,n.If)(V.greaterThan((0,n.int)(0)),()=>{V.subAssign(1)})})})}).ElseIf(et.isAlphaSkip,()=>{e.assign((0,n.bool)(!0))}),pe.mulAssign(et.throughput),(0,n.If)(ne.not(),()=>{me.mulAssign(et.alpha)});let t=(0,n.select)(et.entering,K,K.negate()),r=(0,n.select)(et.didReflect,t,qe);Ke.assign(W.hitPoint.add(r.mul(.001))),qe.assign(et.direction),Le.assign((0,n.bool)(!1)),Re.assign((0,n.bool)(!1)),Be.assign((0,n.bool)(!1)),(0,n.If)(e.not(),()=>{Ge.addAssign(1)}),(0,n.Continue)()}),(0,n.If)(ne.not(),()=>{me.mulAssign(et.alpha)}),he.assign((0,n.bool)(!0));let tt=ie(ue,r,e,t,(0,n.int)(-1),de,B).toVar(),nt=qe.negate().toVar();(0,n.If)((0,n.dot)(K,nt).lessThan(0),()=>{K.assign(K.negate())}),G.sheenRoughness.assign((0,n.clamp)(G.sheenRoughness,Lt,1)),He.assign(Ot.wrap(Ji(G,W.materialIndex,ze,Ve,He))),ze.assign((0,n.bool)(!0)),Ve.assign(W.materialIndex),(0,n.If)(Be.not(),()=>{We.assign(sr(K,nt,G,Ze,He)),Be.assign((0,n.bool)(!0))});let rt=(0,n.vec3)(0).toVar(),it=(0,n.vec3)(0).toVar(),at=(0,n.float)(0).toVar();(0,n.If)(G.clearcoat.greaterThan(0),()=>{let e=Dr.wrap(Or(Je,W,G,tt,t));rt.assign(e.L),it.assign(e.brdf),at.assign(e.pdf)}).Else(()=>{let e=St.wrap(Yi(nt,K,G,tt,t,He,Re,Ue,Be,We));rt.assign(e.direction),it.assign(e.value),at.assign(e.pdf),Re.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)(ae.equal((0,n.int)(1)).and(R.greaterThan((0,n.int)(0))).and(ge.greaterThan(0)),()=>{let e=Pi(W.triangleIndex,W.dst,qe,Ke,a,o,se);t.assign(Kt({pdf1:ge,pdf2:e}))}),fe.addAssign(Qi({contribution:Ze.emissive.mul(pe).mul(F).mul(t),pathLength:(0,n.float)(e),fireflyThreshold:I,frame:(0,n.int)(B)}))});let ot=fi(W.hitPoint,K,G,nt,rt,at,it,e,t,m,h,g,_,v,y,b,x,i,a,o,S,C,w,T,E,D,O,k);fe.addAssign(Qi({contribution:ot.mul(pe).mul(F),pathLength:(0,n.float)(e),fireflyThreshold:I,frame:(0,n.int)(B)})),(0,n.If)(ae.equal((0,n.int)(1)).and(R.greaterThan((0,n.int)(0))),()=>{let r=(0,n.Fn)(([e,t,n])=>ei(e,t,n,gn,i,a,o));(0,n.If)(le.greaterThan((0,n.int)(0)),()=>{let i=yi.wrap(Hi(W.hitPoint,K,t,z,oe,L,a));(0,n.If)(e.greaterThan((0,n.int)(1)).and(G.roughness.greaterThan(.9)).and(G.metalness.lessThan(.1)).not().and(i.valid).and(i.pdf.greaterThan(0)),()=>{let t=(0,n.max)((0,n.float)(0),(0,n.dot)(K,i.direction));(0,n.If)(t.greaterThan(0),()=>{let a=ti(W.hitPoint,K,G),o=W.hitPoint.add(a),s=i.distance.sub(.001),c=r(o,i.direction,s);(0,n.If)(c.greaterThan(0),()=>{let r=Tt.wrap(Yt(K,nt,i.direction)),a=wr(G,r),o=di(G,r),s=(0,n.select)(o.greaterThan(0),Kt({pdf1:i.pdf,pdf2:o}),(0,n.float)(1)),l=i.emission.mul(a).mul(t).div(i.pdf).mul(c).mul(ce).mul(s);fe.addAssign(Qi({contribution:l.mul(pe).mul(F),pathLength:(0,n.float)(e),fireflyThreshold:I,frame:(0,n.int)(B)}))})})})}).Else(()=>{let i=Ri(W.hitPoint,K,nt,G,e,t,ce,oe,L,R,se,a,r,ti);fe.addAssign(Qi({contribution:i.mul(pe).mul(F),pathLength:(0,n.float)(e),fireflyThreshold:I,frame:(0,n.int)(B)}))})});let st=wt.wrap(or(G,e,He)),ct=Pr.wrap(vi(nt,K,G,rt,at,it,t,st));pe.mulAssign(ct.throughput),Ke.assign(W.hitPoint.add(K.mul(.001))),qe.assign(ct.direction),ge.assign(ct.combinedPdf),Le.assign((0,n.bool)(!1)),(0,n.If)(G.metalness.greaterThan(.7).and(G.roughness.lessThan(.3)),()=>{Ie.assign((0,n.int)(Wi))}).ElseIf(G.transmission.greaterThan(.5),()=>{Ie.assign((0,n.int)(Gi))}).Else(()=>{Ie.assign((0,n.int)(Ki))}),(0,n.If)(e.equal((0,n.int)(0)).and(W.didHit),()=>{be.assign(W.hitPoint),xe.assign(W.dst)}),(0,n.If)(Se.not().and(W.didHit),()=>{_e.assign(K),ve.assign(G.color.xyz),ye.assign((0,n.float)(W.materialIndex));let e=G.metalness.greaterThan(.7).and(G.roughness.lessThan(.3)),t=G.transmission.greaterThan(.5);(0,n.If)(e.or(t).not(),()=>{Se.assign((0,n.bool)(!0))})});let lt=Xi(e,pe,G,W.materialIndex,qe,t,ze,Ve,He,k,A);(0,n.If)(lt.lessThanEqual(0),()=>{(0,n.Break)()}),pe.divAssign(lt),Ge.addAssign(1),Re.assign((0,n.bool)(!1)),Be.assign((0,n.bool)(!1))}),qi({radiance:(0,n.vec4)(fe,me),objectNormal:_e,objectColor:ve,objectID:ye,firstHitPoint:be,firstHitDistance:xe})}),ea=(0,n.wgslFn)(`
537
537
  fn visualizeDepth( depth: f32 ) -> vec3f {
538
538
  return vec3f( 1.0f - depth );
539
539
  }
540
- `),ea=(0,n.wgslFn)(`
540
+ `),ta=(0,n.wgslFn)(`
541
541
  fn visualizeNormal( normal: vec3f ) -> vec3f {
542
542
  return normal * 0.5f + 0.5f;
543
543
  }
544
- `),ta=(0,n.wgslFn)(`
544
+ `),na=(0,n.wgslFn)(`
545
545
  fn computeNDCDepthLocal( worldPos: vec3f, cameraProjectionMatrix: mat4x4f, cameraViewMatrix: mat4x4f ) -> f32 {
546
546
  let clipPos = cameraProjectionMatrix * cameraViewMatrix * vec4f( worldPos, 1.0f );
547
547
  let ndcDepth = clipPos.z / clipPos.w * 0.5f + 0.5f;
548
548
  return clamp( ndcDepth, 0.0f, 1.0f );
549
549
  }
550
- `),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])=>{let C=(0,n.vec4)(1,0,1,1).toVar(),w=_t({origin:e,direction:t}),T=bt.wrap(mn(w,r,i).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=xn({tex:o,samp:(0,n.sampler)(o),direction:t,environmentMatrix:s,environmentIntensity:c,enableEnvironmentLight:l}).toVar(),r=(0,n.dot)(e.xyz,zt).toVar(),i=r,a=(0,n.max)(d.mul(.1),.001),u=r.div(a),m=(0,n.log)(r.add(1e-6)).add(10).div(10),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=vt.wrap(tn(T.materialIndex,a)).toVar(),r=Et.wrap(Nn(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=vt.wrap(tn(T.materialIndex,a)).toVar(),t=(0,n.normalize)(Et.wrap(Nn(m,h,g,_,v,y,e,T.uv,T.normal)).toVar().normal);C.assign((0,n.vec4)(ea({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=ta({worldPos:T.hitPoint,cameraProjectionMatrix:b,cameraViewMatrix:x});C.assign((0,n.vec4)($i({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=vt.wrap(tn(T.materialIndex,a)).toVar(),t=Et.wrap(Nn(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=vt.wrap(tn(T.materialIndex,a)).toVar(),t=Et.wrap(Nn(m,h,g,_,v,y,e,T.uv,T.normal)).toVar(),u=t.albedo.rgb,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=lr({N:d,xi:(0,n.vec2)(N(p).toVar(),N(p).toVar())}).toVar(),x=_t({origin:T.hitPoint.add(d.mul(.001)),direction:b}),w=bt.wrap(mn(x,r,i).toVar()),E=(0,n.vec3)(0).toVar();(0,n.If)(w.didHit.not(),()=>{(0,n.If)(l,()=>{E.assign(xn({tex:o,samp:(0,n.sampler)(o),direction:b,environmentMatrix:s,environmentIntensity:c,enableEnvironmentLight:l}).xyz)})}).Else(()=>{let e=vt.wrap(tn(w.materialIndex,a)).toVar(),t=Et.wrap(Nn(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=xn({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=xn({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=xn({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 ra=(0,n.wgslFn)(`
550
+ `),ra=(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=vt({origin:e,direction:t}),T=xt.wrap(hn(w,r,i).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=Sn({tex:o,samp:(0,n.sampler)(o),direction:t,environmentMatrix:s,environmentIntensity:c,enableEnvironmentLight:l}).toVar(),r=(0,n.dot)(e.xyz,Bt).toVar(),i=r,a=(0,n.max)(d.mul(.1),.001),u=r.div(a),m=(0,n.log)(r.add(1e-6)).add(10).div(10),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=yt.wrap(nn(T.materialIndex,a)).toVar(),r=Dt.wrap(Pn(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=yt.wrap(nn(T.materialIndex,a)).toVar(),t=(0,n.normalize)(Dt.wrap(Pn(m,h,g,_,v,y,e,T.uv,T.normal)).toVar().normal);C.assign((0,n.vec4)(ta({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=na({worldPos:T.hitPoint,cameraProjectionMatrix:b,cameraViewMatrix:x});C.assign((0,n.vec4)(ea({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=yt.wrap(nn(T.materialIndex,a)).toVar(),t=Dt.wrap(Pn(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=yt.wrap(nn(T.materialIndex,a)).toVar(),t=Dt.wrap(Pn(m,h,g,_,v,y,e,T.uv,T.normal)).toVar(),u=t.albedo.rgb,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=ur({N:d,xi:(0,n.vec2)(N(p).toVar(),N(p).toVar())}).toVar(),x=vt({origin:T.hitPoint.add(d.mul(.001)),direction:b}),w=xt.wrap(hn(x,r,i).toVar()),E=(0,n.vec3)(0).toVar();(0,n.If)(w.didHit.not(),()=>{(0,n.If)(l,()=>{E.assign(Sn({tex:o,samp:(0,n.sampler)(o),direction:b,environmentMatrix:s,environmentIntensity:c,enableEnvironmentLight:l}).xyz)})}).Else(()=>{let e=yt.wrap(nn(w.materialIndex,a)).toVar(),t=Dt.wrap(Pn(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=Sn({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=Sn({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=Sn({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 ia=(0,n.wgslFn)(`
551
551
  fn nanInfToRed( c: vec3f ) -> vec3f {
552
552
  let isNan = c.x != c.x || c.y != c.y || c.z != c.z;
553
553
  let isInf = abs( c.x ) > 1e30f || abs( c.y ) > 1e30f || abs( c.z ) > 1e30f;
554
554
  if ( isNan || isInf ) { return vec3f( 1.0f, 0.0f, 0.0f ); }
555
555
  return vec3f( 0.0f );
556
556
  }
557
- `),ia=(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}),aa=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:F,envCDFBuffer:I,envTotalSum:ee,envCompensationDelta:te,envResolution:L,enableEnvironmentLight:ne,useEnvMapIS:re,groundProjectionEnabled:R,groundProjectionRadius:z,groundProjectionHeight:oe,maxBounceCount:se,transmissiveBounces:B,showBackground:ce,transparentBackground:le,backgroundIntensity:ue,fireflyThreshold:V,globalIlluminationIntensity:de,enableEmissiveTriangleSampling:fe,emissiveTriangleBuffer:pe,emissiveVec4Offset:me,emissiveTriangleCount:he,emissiveTotalPower:ge,emissiveBoost:_e,lightBVHBuffer:ve,lightBVHNodeCount:ye,debugVisScale:be,enableAccumulation:xe,hasPreviousAccumulated:H,prevAccumTexture:Se,prevNormalDepthTexture:Ce,prevAlbedoTexture:we,accumulationAlpha:Te,cameraIsMoving:Ee,useAdaptiveSampling:De,adaptiveSamplingTexture:Oe,adaptiveSamplingMin:U,adaptiveSamplingMax:W,enableDOF:ke,focalLength:Ae,aperture:je,focusDistance:Me,sceneScale:Ne,apertureScale:Pe,anamorphicRatio:Fe}=e,Ie=(0,n.uvec2)((0,n.uint)((0,n.int)(t.x)),(0,n.uint)((0,n.int)(t.y))),Le=t.div(o),Re=t.div(o).mul(2).sub(1).toVar();Re.y.assign(Re.y.negate());let ze=(0,n.vec4)(0).toVar(),Be=(0,n.int)(0).toVar(),Ve=ae({pixelCoord:t,rayIndex:(0,n.int)(0),frame:s}).toVar(),He=(0,n.vec3)(0,0,1).toVar(),Ue=(0,n.float)(1e6).toVar(),We=(0,n.float)(0).toVar(),Ge=(0,n.int)(c).toVar();(0,n.If)(s.greaterThan((0,n.uint)(2)).and(De),()=>{let e=ia(t,o,Oe,U,W);Ge.assign(e),(0,n.If)(Ge.equal((0,n.int)(0)),()=>{(0,n.If)(xe.and(H),()=>{let e=(0,n.texture)(Se,Le,0);ze.assign(e),We.assign(e.w);let t=(0,n.texture)(Ce,Le,0);He.assign(t.xyz.mul(2).sub(1)),Ue.assign(t.w)}).Else(()=>{Ge.assign(1)})})});let Ke=(0,n.vec3)(0).toVar(),qe=(0,n.vec3)(0).toVar(),G=(0,n.float)(-1e3).toVar(),K=(0,n.vec2)(2).div(o).toVar();(0,n.Loop)({start:(0,n.int)(0),end:Ge,type:`int`,condition:`<`},({i:e})=>{let r=A({state:Ve.add((0,n.uint)(e))}).toVar(),i=ie(t,e,Ge,r,o,s).toVar();(0,n.If)(l.equal((0,n.int)(9)),()=>{ze.assign((0,n.vec4)(i,1,1)),Be.assign(1),(0,n.Break)()});let a=i.sub(.5).mul(K),c=Re.add(a),ae=_t.wrap(gn(c,r,u,d,ke,Ae,je,Me,Ne,Pe,Fe)),xe=(0,n.vec4)(0).toVar();(0,n.If)(l.greaterThan((0,n.int)(0)).and(l.notEqual((0,n.int)(11))),()=>{xe.assign(na(ae.origin,ae.direction,m,h,g,N,F,P,ne,l,be,t,o,_,v,y,b,x,S,p,f,s))}).Else(()=>{let i=Ki.wrap(Qi(ae,r,e,m,h,g,_,v,y,b,x,S,C,w,T,E,D,O,k,j,M,N,P,F,I,ee,te,L,ne,re,R,z,oe,se,B,ue,ce,le,V,de,fe,pe,me,he,ge,_e,ve,ye,t,o,s));xe.assign(i.radiance),(0,n.If)(e.equal((0,n.int)(0)),()=>{Ke.assign(i.objectNormal),qe.assign(i.objectColor),G.assign(i.objectID),(0,n.If)(i.firstHitDistance.lessThan(1e9),()=>{He.assign((0,n.normalize)(i.objectNormal)),Ue.assign(i.firstHitDistance)})})}),ze.addAssign(xe),We.addAssign(xe.w),Be.addAssign(1)}),(0,n.If)(Be.greaterThan((0,n.int)(0)),()=>{ze.divAssign((0,n.float)(Be)),We.divAssign((0,n.float)(Be))});let Je=ze.xyz.toVar(),Ye=(0,n.vec4)(He.mul(.5).add(.5),Ue).toVar(),Xe=(0,n.vec3)(qe).toVar(),q=(0,n.select)(le,We,(0,n.float)(1)).toVar();(0,n.If)(xe.and(Ee.not()).and(s.greaterThan((0,n.uint)(0))).and(H).and(l.notEqual((0,n.int)(11))),()=>{let e=(0,n.texture)(Se,Le,0).toVar();Je.assign((0,n.mix)(e.xyz,ze.xyz,Te)),Ye.assign((0,n.mix)((0,n.texture)(Ce,Le,0),Ye,Te)),Xe.assign((0,n.mix)((0,n.texture)(we,Le,0).xyz,Xe,Te)),(0,n.If)(le,()=>{q.assign((0,n.mix)(e.w,We,Te))})}),(0,n.If)(l.equal((0,n.int)(11)),()=>{Je.assign(ra(Je))}),(0,n.textureStore)(r,Ie,(0,n.vec4)(Je.xyz,q)).toWriteOnly(),(0,n.textureStore)(i,Ie,Ye).toWriteOnly(),(0,n.textureStore)(a,Ie,(0,n.vec4)(Xe,1)).toWriteOnly()},oa=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)}}},sa=8,ca=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 oa(`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/sa),this._dispatchY=Math.ceil(o/sa),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),e.goboMaps&&t.goboMapsTex&&(t.goboMapsTex.value=e.goboMaps),e.iesProfiles&&t.iesProfilesTex&&(t.iesProfilesTex.value=e.iesProfiles),console.log(`ShaderBuilder: Scene textures updated in-place`)}updateGoboMaps(e){let t=this._sceneTextureNodes;!t||!t.goboMapsTex||e&&(t.goboMapsTex.value=e)}updateIESProfiles(e){let t=this._sceneTextureNodes;!t||!t.iesProfilesTex||e&&(t.iesProfilesTex.value=e)}getSceneTextureNodes(){return this._sceneTextureNodes}setSize(e,t){this._dispatchX=Math.ceil(e/sa),this._dispatchY=Math.ceil(t/sa),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/sa),a=Math.ceil(r/sa);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;Qr(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(),S=e.goboMaps?(0,n.texture)(e.goboMaps):p();Hr(S);let C=e.iesProfiles?(0,n.texture)(e.iesProfiles):p();Kr(C),Zr(h);let w={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,goboMapsTex:S,iesProfilesTex:C};return this._sceneTextureNodes=w,w}_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(sa)).add((0,n.int)(n.localId.x)),D=x.add((0,n.int)(n.workgroupId.y).mul(sa)).add((0,n.int)(n.localId.y));(0,n.If)(t.lessThan(S).and(D.lessThan(C)),()=>{aa({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,groundProjectionEnabled:e.groundProjectionEnabled,groundProjectionRadius:e.groundProjectionRadius,groundProjectionHeight:e.groundProjectionHeight,maxBounceCount:e.maxBounces,transmissiveBounces:e.transmissiveBounces,showBackground:e.showBackground,transparentBackground:e.transparentBackground,backgroundIntensity:e.backgroundIntensity,fireflyThreshold:e.fireflyThreshold,globalIlluminationIntensity:e.globalIlluminationIntensity,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],[sa,sa,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}},la=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 ua;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 ua;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}}},ua=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}},da=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}},fa=``+(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),pa={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},ma=pa.FLOATS_PER_TRIANGLE,ha=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}},ga=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=pa.POSITION_A_OFFSET,r=pa.POSITION_B_OFFSET,i=pa.POSITION_C_OFFSET;for(let a=0;a<e;a++){let e=a*ma,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/(ma*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*ma*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(fa,{type:`module`}))}catch(i){i.name===`SecurityError`?Ue(fa).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/(ma*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 la(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 da(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*ma);for(let e=0;e<a;e++){let t=this.indices[e]*ma,n=e*ma;f.set(d.subarray(t,t+ma),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 ha;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 ha;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},_a=Z.FLOATS_PER_TRIANGLE,va=16,ya=-1,ba=-2,xa=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*_a,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*va,o=(r-n)*6;if(e[a+3]===ya){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)*_a,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*va,a=i*6,o=e[n+3];if(o===ya){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)*_a,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===ba){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)}}}},Sa=``+(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),Ca=32,wa=5e4,Ta=8;function Ea(e,t,n,r){let i=e.byteLength/(Ca*4),a=Math.min(navigator.hardwareConcurrency||4,Ta),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*Ca*4),h;try{h=new Worker(fa,{type:`module`})}catch(e){if(e.name!==`SecurityError`)throw e;h=await Ue(fa)}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(Oa(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,Da(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 Da(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(Sa,{type:`module`})}catch(e){if(e.name!==`SecurityError`)throw e;s=await Ue(Sa)}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 Oa(e,t,n,r){return new Promise((i,a)=>{(async()=>{let o;try{o=new Worker(fa,{type:`module`})}catch(e){if(e.name!==`SecurityError`)throw e;o=await Ue(fa)}let s=e.byteLength/(Ca*4),c=typeof SharedArrayBuffer<`u`?new SharedArrayBuffer(s*Ca*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 ka(e){return typeof Worker<`u`&&typeof SharedArrayBuffer<`u`&&e>=wa}var Aa=16,ja=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}},Ma=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 ja;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*Aa;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*Aa;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}},Na=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=U.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}},Pa=``+(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),Fa=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=[]}},Ia=class{constructor(e={}){this.pools=new Map,this.memoryUsage=0,this.maxMemoryUsage=e.maxMemory||Pe.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*Pe.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`}},La=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=[]}},Ra=class{constructor(e={}){this.useWorkers=typeof Worker<`u`,this.maxConcurrentWorkers=Ae.MAX_CONCURRENT_WORKERS,this.activeWorkers=0,this.canvasPool=new Fa,this.bufferPool=new Ia({maxMemory:e.maxBufferMemory||Pe.MAX_BUFFER_MEMORY,sizeStrategy:e.bufferSizeStrategy||`adaptive`}),this.textureCache=new La,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>Pe.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(Pa,{type:`module`})}catch(e){if(e.name!==`SecurityError`)throw e;t=await Ue(Pa)}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%Pe.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=W.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??je,s=n.normalMapMatrices??je,c=n.roughnessMapMatrices??je,l=n.metalnessMapMatrices??je,u=n.emissiveMapMatrices??je,d=n.bumpMapMatrices??je,f=n.displacementMapMatrices??je,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 La;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:za(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:za(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 za(e,t,n){let r=new Uint8ClampedArray(e.buffer,e.byteOffset,e.byteLength);return createImageBitmap(new ImageData(r,t,n))}var Ba=128,Va=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*U.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*U.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<Ba){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*U.FLOATS_PER_TRIANGLE;this.triangleData[f+U.POSITION_A_OFFSET+0]=t.x,this.triangleData[f+U.POSITION_A_OFFSET+1]=t.y,this.triangleData[f+U.POSITION_A_OFFSET+2]=t.z,this.triangleData[f+U.POSITION_A_OFFSET+3]=0,this.triangleData[f+U.POSITION_B_OFFSET+0]=n.x,this.triangleData[f+U.POSITION_B_OFFSET+1]=n.y,this.triangleData[f+U.POSITION_B_OFFSET+2]=n.z,this.triangleData[f+U.POSITION_B_OFFSET+3]=0,this.triangleData[f+U.POSITION_C_OFFSET+0]=r.x,this.triangleData[f+U.POSITION_C_OFFSET+1]=r.y,this.triangleData[f+U.POSITION_C_OFFSET+2]=r.z,this.triangleData[f+U.POSITION_C_OFFSET+3]=0,this.triangleData[f+U.NORMAL_A_OFFSET+0]=i.x,this.triangleData[f+U.NORMAL_A_OFFSET+1]=i.y,this.triangleData[f+U.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+U.NORMAL_A_OFFSET+3]=t}this.triangleData[f+U.NORMAL_B_OFFSET+0]=a.x,this.triangleData[f+U.NORMAL_B_OFFSET+1]=a.y,this.triangleData[f+U.NORMAL_B_OFFSET+2]=a.z,this.triangleData[f+U.NORMAL_B_OFFSET+3]=0,this.triangleData[f+U.NORMAL_C_OFFSET+0]=o.x,this.triangleData[f+U.NORMAL_C_OFFSET+1]=o.y,this.triangleData[f+U.NORMAL_C_OFFSET+2]=o.z,this.triangleData[f+U.NORMAL_C_OFFSET+3]=this.materials[u]?.side??0,this.triangleData[f+U.UV_AB_OFFSET+0]=s.x,this.triangleData[f+U.UV_AB_OFFSET+1]=s.y,this.triangleData[f+U.UV_AB_OFFSET+2]=c.x,this.triangleData[f+U.UV_AB_OFFSET+3]=c.y,this.triangleData[f+U.UV_C_MAT_OFFSET+0]=l.x,this.triangleData[f+U.UV_C_MAT_OFFSET+1]=l.y,this.triangleData[f+U.UV_C_MAT_OFFSET+2]=u,this.triangleData[f+U.UV_C_MAT_OFFSET+3]=d}getTriangleData(){return this.triangleData?this.triangleData.subarray(0,this.currentTriangleIndex*U.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*U.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}}},Ha=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}}},Ua=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=U.FLOATS_PER_TRIANGLE,i=U.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 Ha().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}},Wa=``+(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),Ga=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 Va,this.bvhBuilder=new ga,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 Ra,this.emissiveTriangleBuilder=new Ua,this.tlasBuilder=new Ma}_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 oa(`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,V({status:`Building light data...`,progress:77}),t.start(`Emissive extraction + Light BVH`),this._buildEmissiveData(),t.end(`Emissive extraction + Light BVH`),n||V({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`,V({status:`Scene data ready`,progress:85}),this}catch(e){throw this.processingStage=`error`,console.error(`[SceneProcessor] Processing error:`,e),V({status:`Error: ${e.message}`,progress:100}),e}finally{this.isProcessing=!1}}async _extractGeometry(e){V({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}),V({status:`Extracted ${this.triangleCount.toLocaleString()} triangles`,progress:25})}catch(e){throw console.error(`[SceneProcessor] Geometry extraction error:`,e),V({status:`Extraction error: ${e.message}`,progress:25}),e}}async _buildBVH(){if(V({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=U.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 Na,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&&ka(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=>{V({status:`Building BLAS ${e+o.length}/${c}...`,progress:25+Math.floor(e/c*45)})}),u=o.map(({m:e,range:n})=>Ea(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});V({status:`Built all BLASes`,progress:70}),V({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)`),V({status:`BVH construction complete`,progress:75})}catch(e){throw console.error(`[SceneProcessor] BVH building error:`,e),V({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=U.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(fa,{type:`module`})}catch(t){if(t.name!==`SecurityError`){l(t);return}e=await Ue(fa)}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(Wa,{type:`module`})}catch(e){if(e.name!==`SecurityError`)throw e;this._refitWorker=await Ue(Wa)}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 xa;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=U.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=U.FLOATS_PER_TRIANGLE,r=U.POSITION_A_OFFSET,i=U.POSITION_B_OFFSET,a=U.POSITION_C_OFFSET,o=U.NORMAL_A_OFFSET,s=U.NORMAL_B_OFFSET,c=U.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=U.FLOATS_PER_TRIANGLE,i=U.NORMAL_A_OFFSET,a=U.NORMAL_B_OFFSET,o=U.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=U.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(fa,{type:`module`}),i(t,e,r)}catch(n){if(n.name!==`SecurityError`)throw n;Ue(fa).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=U.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}},Ka=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,o=e.userData?.gobo,s=o&&Number.isInteger(o.index)?o.index:-1,c=o&&typeof o.intensity==`number`?o.intensity:1,l=o&&o.inverted?-Math.abs(c):Math.abs(c),u=o&&typeof o.scale==`number`?o.scale:5;this.directionalLightCache.push({data:[n.x,n.y,n.z,e.color.r,e.color.g,e.color.b,e.intensity,a,s,l,u,0],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`),a=e.userData?.gobo,o=a&&Number.isInteger(a.index)?a.index:-1,s=a&&typeof a.intensity==`number`?a.intensity:1,c=a&&a.inverted?-Math.abs(s):Math.abs(s),l=e.userData?.ies,u=l&&Number.isInteger(l.index)?l.index:-1,d=l&&typeof l.intensity==`number`?l.intensity:1;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,o,c,u,d,0,0],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/12),n=Math.floor(this.lightData.rectArea.length/13),r=Math.floor(this.lightData.point.length/9),i=Math.floor(this.lightData.spot.length/20);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}))}}},qa={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 Ja(e){e&&Object.assign(qa,e)}function Ya(){return{...qa}}var Xa=4,Za=class extends z{constructor(e,t,n,i={}){super(`PathTracer`,{...i,executionMode:R.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 oe(a,o,H.tiles),this.sdfs=new Ga,this.lightSerializer=new Ka,this.accumulationEnabled=!0,this.isComplete=!1,this.cameras=[],this.performanceMonitor=ye(),this.completionThreshold=0,this.renderLimitMode=`frames`,this._initDataTextures(),this.storageTextures=new xe(0,0),this.uniforms=new Ie(a,o),this._defineUniformGetters(),this.materialData=new He(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 gt(this.scene,this.uniforms),this.environment.callbacks.onReset=()=>this.reset(),this.environment.callbacks.getSceneTextureNodes=()=>this.shaderBuilder.getSceneTextureNodes(),this.shaderBuilder=new ca,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.goboMaps=null,this.iesProfiles=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 se(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:H.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}=Ya();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.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/12)):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/20)):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/Xa),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){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 t=this.frameCount,n=this.renderMode.value,r=null,i=null;n===1&&t===0&&(r=this.maxBounces.value,i=this.samplesPerPixel.value,this.maxBounces.value=1,this.samplesPerPixel.value=1),this._handleResize(),this.manageASVGFForRenderMode(n,t);let a=this.tileManager.handleTileRendering(this.renderer,n,t,null);if(e&&e.setState(`tileRenderingComplete`,a.isCompleteCycle),a.tileIndex>=0){let e=this.tileManager.calculateTileBounds(a.tileIndex,this.tileManager.tiles,this.width,this.height);this.emit(`tile:changed`,{tileIndex:a.tileIndex,tileBounds:e,renderMode:n}),this.tileChanged=!0}this.cameraChanged=this._updateCameraUniforms(),this.cameraOptimizer?.updateInteractionMode(this.cameraChanged),this._updateAccumulationUniforms(t,n),this.frame.value=t,a.tileIndex>=0&&a.tileBounds?this.shaderBuilder.setTileDispatch(a.tileBounds.x,a.tileBounds.y,a.tileBounds.width,a.tileBounds.height):this.shaderBuilder.setFullScreenDispatch();let o=this.storageTextures.getReadTextures();this.shaderBuilder.prevColorTexNode&&(this.shaderBuilder.prevColorTexNode.value=o.color,this.shaderBuilder.prevNormalDepthTexNode.value=o.normalDepth,this.shaderBuilder.prevAlbedoTexNode.value=o.albedo),this.renderer.compute(this.shaderBuilder.computeNode),this.storageTextures.copyToReadTargets(this.renderer);let s=this.storageTextures.getReadTextures();e&&this._publishTexturesToContext(e,s),this._emitStateEvents(),this.cameraOptimizer?.isInInteractionMode()||this.frameCount++,r!==null&&(this.maxBounces.value=r),i!==null&&(this.samplesPerPixel.value=i),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=ve(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=_e(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}},Qa=class extends z{constructor(e,i={}){super(`NormalDepth`,{...i,executionMode:R.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;let s={type:r.HalfFloatType,format:r.RGBAFormat,minFilter:r.NearestFilter,magFilter:r.NearestFilter,depthBuffer:!1,stencilBuffer:!1};this._rtA=new t.RenderTarget(a,o,s),this._rtB=new t.RenderTarget(a,o,s),this._currentIdx=0,this._hasHistory=!1,this._dispatchX=Math.ceil(a/8),this._dispatchY=Math.ceil(o/8),this._triStorageNode=null,this._bvhStorageNode=null,this._lastTriAttr=null,this._lastBvhAttr=null,this._computeNode=null,this._computeBuilt=!1}setupEventListeners(){this.on(`camera:moved`,()=>{this._dirty=!0}),this.on(`pipeline:reset`,()=>{this._dirty=!0,this._hasHistory=!1})}_syncStorageBuffers(){let e=this.pathTracer;if(!e)return!1;let t=e.triangleStorageAttr&&e.triangleStorageAttr!==this._lastTriAttr,r=e.bvhStorageAttr&&e.bvhStorageAttr!==this._lastBvhAttr;return(t||r)&&(this._computeNode?.dispose?.(),this._computeNode=null,this._computeBuilt=!1,this._triStorageNode=null,this._bvhStorageNode=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()),this._lastTriAttr=e.triangleStorageAttr||this._lastTriAttr,this._lastBvhAttr=e.bvhStorageAttr||this._lastBvhAttr,!!(this._triStorageNode&&this._bvhStorageNode)}_buildCompute(){let e=this._triStorageNode,t=this._bvhStorageNode,r=this.cameraWorldMatrix,i=this.cameraProjectionMatrixInverse,a=this.resolutionWidth,o=this.resolutionHeight,s=this._outputStorageTex;this._computeNode=(0,n.Fn)(([r,i])=>{let c=(0,n.int)(n.workgroupId.x).mul(8).add((0,n.int)(n.localId.x)),l=(0,n.int)(n.workgroupId.y).mul(8).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.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),d=i.mul((0,n.vec4)(u,1)),f=(0,n.normalize)((0,n.mat3)(r[0].xyz,r[1].xyz,r[2].xyz).mul(d.xyz.div(d.w))),p=_t({origin:(0,n.vec3)(r[3]),direction:f}),m=bt.wrap(mn(p,t,e)),h=m.normal.mul(.5).add(.5),g=m.dst,_=m.didHit.select((0,n.vec4)(h,g),(0,n.vec4)(0,0,0,(0,n.float)(1e6)));(0,n.textureStore)(s,(0,n.uvec2)((0,n.uint)(c),(0,n.uint)(l)),_).toWriteOnly()})})(r,i).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._hasHistory){let t=this._currentIdx===0?this._rtA:this._rtB;e.setTexture(`pathtracer:normalDepth`,t.texture),e.setTexture(`pathtracer:prevNormalDepth`,t.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._rtA.width||e.height!==this._rtA.height)&&this.setSize(e.width,e.height)}this._hasHistory&&(this._currentIdx=1-this._currentIdx);let r=this._currentIdx===0?this._rtA:this._rtB,i=this._currentIdx===0?this._rtB:this._rtA;this.renderer.compute(this._computeNode),this.renderer.copyTextureToTexture(this._outputStorageTex,r.texture),this._hasHistory||=(this.renderer.copyTextureToTexture(this._outputStorageTex,i.texture),!0),e.setTexture(`pathtracer:normalDepth`,r.texture),e.setTexture(`pathtracer:prevNormalDepth`,i.texture),this._dirty=!1}reset(){this._dirty=!0,this._hasHistory=!1}setSize(e,t){this._outputStorageTex.setSize(e,t),this._rtA.setSize(e,t),this._rtB.setSize(e,t),this._hasHistory=!1,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._rtA?.dispose(),this._rtB?.dispose()}},$a=class extends z{constructor(e,i,a={}){super(`MotionVector`,{...a,executionMode:R.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()}},eo=class extends z{constructor(e,i={}){super(`ASVGF`,{...i,executionMode:R.PER_CYCLE}),this.renderer=e,this.temporalAlpha=(0,n.uniform)(i.temporalAlpha??0),this.gradientStrength=(0,n.uniform)(i.gradientStrength??0),this.gradientNoiseFloor=(0,n.uniform)(i.gradientNoiseFloor??.15),this.maxAccumFrames=(0,n.uniform)(i.maxAccumFrames??32),this.resW=(0,n.uniform)(i.width||1),this.resH=(0,n.uniform)(i.height||1),this.temporalEnabledU=(0,n.uniform)(1),this._colorTexNode=new t.TextureNode,this._prevColorTexNode=new t.TextureNode,this._albedoTexNode=new t.TextureNode,this._motionTexNode=new t.TextureNode,this._normalDepthTexNode=new t.TextureNode,this._prevNormalDepthTexNode=new t.TextureNode,this._readTemporalTexNode=new t.TextureNode,this._gradientReadTexNode=new t.TextureNode;let a=i.width||1,o=i.height||1;this._temporalTexA=new t.StorageTexture(a,o),this._temporalTexA.type=r.FloatType,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.FloatType,this._temporalTexB.format=r.RGBAFormat,this._temporalTexB.minFilter=r.LinearFilter,this._temporalTexB.magFilter=r.LinearFilter,this._outputModulatedTex=new t.StorageTexture(a,o),this._outputModulatedTex.type=r.FloatType,this._outputModulatedTex.format=r.RGBAFormat,this._outputModulatedTex.minFilter=r.LinearFilter,this._outputModulatedTex.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._prevColorRT=new t.RenderTarget(a,o,{type:r.FloatType,format:r.RGBAFormat,minFilter:r.NearestFilter,magFilter:r.NearestFilter,depthBuffer:!1,stencilBuffer:!1}),this._prevColorReady=!1,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()}_buildGradientCompute(){let e=this._colorTexNode,t=this._prevColorTexNode,r=this._motionTexNode,i=this.gradientNoiseFloor,a=this._gradientStorageTex,o=this.resW,s=this.resH,c=(0,n.workgroupArray)(`float`,144),l=(0,n.workgroupArray)(`float`,144);this._gradientNode=(0,n.Fn)(()=>{let u=n.localId.x,d=n.localId.y,f=d.mul(8).add(u),p=(0,n.int)(n.workgroupId.x).mul(8).sub(2).toVar(),m=(0,n.int)(n.workgroupId.y).mul(8).sub(2).toVar(),h=i=>{let a=i.mod((0,n.uint)(12)),u=i.div((0,n.uint)(12)),d=p.add((0,n.int)(a)).clamp((0,n.int)(0),(0,n.int)(o).sub(1)),f=m.add((0,n.int)(u)).clamp((0,n.int)(0),(0,n.int)(s).sub(1)),h=(0,n.textureLoad)(e,(0,n.ivec2)(d,f)).xyz;c.element(i).assign(Wt(h));let g=(0,n.textureLoad)(r,(0,n.ivec2)(d,f)),_=(0,n.float)(d).sub(g.x.mul(o)),v=(0,n.float)(f).sub(g.y.mul(s)),y=(0,n.int)(_).clamp((0,n.int)(0),(0,n.int)(o).sub(1)),b=(0,n.int)(v).clamp((0,n.int)(0),(0,n.int)(s).sub(1)),x=g.w.greaterThan(.5),S=(0,n.textureLoad)(t,(0,n.ivec2)(y,b)).xyz,C=x.select(Wt(S),Wt(h));l.element(i).assign(C)};h(f);let g=f.add((0,n.uint)(64));(0,n.If)(g.lessThan((0,n.uint)(144)),()=>{h(g)});let _=f.add((0,n.uint)(128));(0,n.If)(_.lessThan((0,n.uint)(144)),()=>{h(_)}),(0,n.workgroupBarrier)();let v=(0,n.int)(n.workgroupId.x).mul(8).add((0,n.int)(u)),y=(0,n.int)(n.workgroupId.y).mul(8).add((0,n.int)(d));(0,n.If)(v.lessThan((0,n.int)(o)).and(y.lessThan((0,n.int)(s))),()=>{let e=(0,n.float)(0).toVar(),t=(0,n.float)(0).toVar();for(let r=-2;r<=2;r++)for(let i=-2;i<=2;i++){let a=d.add((0,n.uint)(2+r)).mul((0,n.uint)(12)).add(u.add((0,n.uint)(2+i))),o=c.element(a),s=l.element(a);e.addAssign((0,n.abs)(o.sub(s))),t.addAssign(o.add(s).mul(.5))}let r=e.div((0,n.max)(t,(0,n.float)(.001))).clamp(0,1),o=(0,n.max)((0,n.float)(1).sub(i),(0,n.float)(1e-4)),s=(0,n.max)(r.sub(i),(0,n.float)(0)).div(o).clamp(0,1);(0,n.textureStore)(a,(0,n.uvec2)((0,n.uint)(v),(0,n.uint)(y)),(0,n.vec4)(s,r,t.div(25),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._albedoTexNode,i=this._motionTexNode,a=this._normalDepthTexNode,o=this._prevNormalDepthTexNode,s=this._readTemporalTexNode,c=this._gradientReadTexNode,l=this._outputModulatedTex,u=this.maxAccumFrames,d=this.temporalAlpha,f=this.gradientStrength,p=this.temporalEnabledU,m=this.resW,h=this.resH;return(0,n.Fn)(()=>{let g=(0,n.int)(n.workgroupId.x).mul(8).add((0,n.int)(n.localId.x)),_=(0,n.int)(n.workgroupId.y).mul(8).add((0,n.int)(n.localId.y));(0,n.If)(g.lessThan((0,n.int)(m)).and(_.lessThan((0,n.int)(h))),()=>{let v=(0,n.ivec2)(g,_),y=(0,n.textureLoad)(t,v).xyz,b=(0,n.textureLoad)(r,v).xyz,x=(0,n.max)(b,(0,n.vec3)(Se)),S=y.div(x),C=(0,n.vec4)(S,1).toVar(),w=(0,n.vec4)(y,1).toVar();(0,n.If)(p.greaterThan(.5),()=>{let e=(0,n.textureLoad)(i,v),t=e.w.greaterThan(.5),r=(0,n.float)(g).sub(e.x.mul(m)),l=(0,n.float)(_).sub(e.y.mul(h)),p=r.greaterThanEqual(0).and(r.lessThan((0,n.float)(m).sub(1))).and(l.greaterThanEqual(0)).and(l.lessThan((0,n.float)(h).sub(1)));(0,n.If)(t.and(p),()=>{let e=(0,n.textureLoad)(a,v),t=e.xyz.mul(2).sub(1),i=e.w,p=(0,n.int)(r),g=(0,n.int)(l),_=p.add((0,n.int)(1)),y=g.add((0,n.int)(1)),b=r.sub((0,n.float)(p)),T=l.sub((0,n.float)(g)),E=p.clamp((0,n.int)(0),(0,n.int)(m).sub(1)),D=_.clamp((0,n.int)(0),(0,n.int)(m).sub(1)),O=g.clamp((0,n.int)(0),(0,n.int)(h).sub(1)),k=y.clamp((0,n.int)(0),(0,n.int)(h).sub(1)),A=(0,n.float)(1).sub(b).mul((0,n.float)(1).sub(T)),j=b.mul((0,n.float)(1).sub(T)),M=(0,n.float)(1).sub(b).mul(T),N=b.mul(T),P=(e,r,a)=>{let s=(0,n.textureLoad)(o,(0,n.ivec2)(e,r)),c=s.xyz.mul(2).sub(1),l=s.w,u=(0,n.pow)((0,n.dot)(t,c).clamp(0,1),(0,n.float)(16)),d=(0,n.exp)((0,n.abs)(i.sub(l)).div((0,n.max)(i,(0,n.float)(.001))).div((0,n.float)(.05)).negate());return a.mul(u).mul(d)},F=P(E,O,A),I=P(D,O,j),ee=P(E,k,M),te=P(D,k,N),L=F.add(I).add(ee).add(te);(0,n.If)(L.greaterThan((0,n.float)(.01)),()=>{let e=(0,n.textureLoad)(s,(0,n.ivec2)(E,O)),t=(0,n.textureLoad)(s,(0,n.ivec2)(D,O)),r=(0,n.textureLoad)(s,(0,n.ivec2)(E,k)),i=(0,n.textureLoad)(s,(0,n.ivec2)(D,k)),a=(0,n.float)(1).div(L),o=e.xyz.mul(F).add(t.xyz.mul(I)).add(r.xyz.mul(ee)).add(i.xyz.mul(te)).mul(a),l=e.w.mul(F).add(t.w.mul(I)).add(r.w.mul(ee)).add(i.w.mul(te)).mul(a),p=(0,n.textureLoad)(c,v).x.mul(f).clamp(0,1),m=(0,n.mix)(o,S,(0,n.mix)((0,n.max)((0,n.float)(1).div(l.add(1)),d),(0,n.float)(1),p)),h=(0,n.min)(l.add(1),u);C.assign((0,n.vec4)(m,h)),w.assign((0,n.vec4)(m.mul(x),1))})})}),(0,n.textureStore)(e,(0,n.uvec2)((0,n.uint)(g),(0,n.uint)(_)),C).toWriteOnly(),(0,n.textureStore)(l,(0,n.uvec2)((0,n.uint)(g),(0,n.uint)(_)),w).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=Wt(o);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.setTemporalEnabled(e.enabled)}),this.on(`asvgf:updateParameters`,e=>this.updateParameters(e))}render(e){if(!this.enabled)return;let t=e.getTexture(`pathtracer:color`),n=e.getTexture(`pathtracer:albedo`),r=e.getTexture(`pathtracer:normalDepth`),i=e.getTexture(`pathtracer:prevNormalDepth`)||r,a=e.getTexture(`motionVector:screenSpace`);if(!t)return;let o=t.image;o&&o.width>0&&o.height>0&&(o.width!==this._temporalTexA.image.width||o.height!==this._temporalTexA.image.height)&&this.setSize(o.width,o.height),this._colorTexNode.value=t,n&&(this._albedoTexNode.value=n),a&&(this._motionTexNode.value=a),r&&(this._normalDepthTexNode.value=r),i&&(this._prevNormalDepthTexNode.value=i);let s=this.currentMoments===0?this._temporalTexB:this._temporalTexA,c=this.currentMoments===0?this._temporalNodeA:this._temporalNodeB,l=this.currentMoments===0?this._temporalTexA:this._temporalTexB;this._prevColorTexNode.value=this._prevColorReady?this._prevColorRT.texture:t,this._compiled||=(this.renderer.compute(this._gradientNode),this.renderer.compute(this._temporalNodeA),this.renderer.compute(this._temporalNodeB),!0),this._readTemporalTexNode.value=s,this._gradientReadTexNode.value=this._gradientStorageTex;let u=this.gradientStrength.value>0||this.showHeatmap;u&&this.renderer.compute(this._gradientNode),this.renderer.compute(c),u&&(this.renderer.copyTextureToTexture(t,this._prevColorRT.texture),this._prevColorReady=!0),e.setTexture(`asvgf:demodulated`,l),e.setTexture(`asvgf:output`,this._outputModulatedTex),e.setTexture(`asvgf:gradient`,this._gradientStorageTex),this.currentMoments=1-this.currentMoments,this.showHeatmap&&(this._heatmapRawColorTexNode.value=t,this._heatmapColorTexNode.value=this._outputModulatedTex,this._heatmapTemporalTexNode.value=l,r&&(this._heatmapNDTexNode.value=r),a&&(this._heatmapMotionTexNode.value=a),this._heatmapGradientTexNode.value=this._gradientStorageTex,this.renderer.compute(this._heatmapComputeNode),this.renderer.copyTextureToTexture(this._heatmapStorageTex,this.heatmapTarget.texture))}setHeatmapEnabled(e){this.showHeatmap=e}setTemporalEnabled(e){this.temporalEnabledU.value=+!!e}updateParameters(e){e&&(e.temporalAlpha!==void 0&&(this.temporalAlpha.value=e.temporalAlpha),e.gradientStrength!==void 0&&(this.gradientStrength.value=e.gradientStrength),e.gradientNoiseFloor!==void 0&&(this.gradientNoiseFloor.value=e.gradientNoiseFloor),e.maxAccumFrames!==void 0&&(this.maxAccumFrames.value=e.maxAccumFrames),e.debugMode!==void 0&&(this.debugMode.value=e.debugMode))}resetTemporalData(){this.currentMoments=0,this._prevColorReady=!1}setSize(e,t){this._temporalTexA.setSize(e,t),this._temporalTexB.setSize(e,t),this._outputModulatedTex.setSize(e,t),this._gradientStorageTex.setSize(e,t),this._prevColorRT.setSize(e,t),this._heatmapStorageTex.setSize(e,t),this.heatmapTarget.setSize(e,t),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],this._compiled=!1,this._prevColorReady=!1}reset(){}dispose(){this._gradientNode?.dispose(),this._temporalNodeA?.dispose(),this._temporalNodeB?.dispose(),this._temporalTexA?.dispose(),this._temporalTexB?.dispose(),this._outputModulatedTex?.dispose(),this._gradientStorageTex?.dispose(),this._prevColorRT?.dispose(),this._heatmapComputeNode?.dispose(),this._heatmapStorageTex?.dispose(),this.heatmapTarget?.dispose(),this._colorTexNode?.dispose(),this._prevColorTexNode?.dispose(),this._albedoTexNode?.dispose(),this._motionTexNode?.dispose(),this._normalDepthTexNode?.dispose(),this._prevNormalDepthTexNode?.dispose(),this._readTemporalTexNode?.dispose(),this._gradientReadTexNode?.dispose(),this._heatmapRawColorTexNode?.dispose(),this._heatmapColorTexNode?.dispose(),this._heatmapTemporalTexNode?.dispose(),this._heatmapNDTexNode?.dispose(),this._heatmapMotionTexNode?.dispose(),this._heatmapGradientTexNode?.dispose()}},to=(0,n.wgslFn)(`
557
+ `),aa=(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}),oa=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:F,envCDFBuffer:ee,envTotalSum:te,envCompensationDelta:ne,envResolution:I,enableEnvironmentLight:re,useEnvMapIS:ie,groundProjectionEnabled:L,groundProjectionRadius:R,groundProjectionHeight:se,maxBounceCount:ce,transmissiveBounces:z,showBackground:le,transparentBackground:ue,backgroundIntensity:de,fireflyThreshold:B,globalIlluminationIntensity:fe,enableEmissiveTriangleSampling:pe,emissiveTriangleBuffer:me,emissiveVec4Offset:he,emissiveTriangleCount:ge,emissiveTotalPower:_e,emissiveBoost:ve,lightBVHBuffer:ye,lightBVHNodeCount:be,debugVisScale:xe,enableAccumulation:Se,hasPreviousAccumulated:V,prevAccumTexture:Ce,prevNormalDepthTexture:we,prevAlbedoTexture:Te,accumulationAlpha:Ee,cameraIsMoving:De,useAdaptiveSampling:Oe,adaptiveSamplingTexture:ke,adaptiveSamplingMin:H,adaptiveSamplingMax:U,enableDOF:Ae,focalLength:je,aperture:Me,focusDistance:Ne,sceneScale:Pe,apertureScale:Fe,anamorphicRatio:Ie}=e,Le=(0,n.uvec2)((0,n.uint)((0,n.int)(t.x)),(0,n.uint)((0,n.int)(t.y))),Re=t.div(o),ze=t.div(o).mul(2).sub(1).toVar();ze.y.assign(ze.y.negate());let Be=(0,n.vec4)(0).toVar(),Ve=(0,n.int)(0).toVar(),He=oe({pixelCoord:t,rayIndex:(0,n.int)(0),frame:s}).toVar(),Ue=(0,n.vec3)(0,0,1).toVar(),We=(0,n.float)(1e6).toVar(),Ge=(0,n.float)(0).toVar(),Ke=(0,n.int)(c).toVar();(0,n.If)(s.greaterThan((0,n.uint)(2)).and(Oe),()=>{let e=aa(t,o,ke,H,U);Ke.assign(e),(0,n.If)(Ke.equal((0,n.int)(0)),()=>{(0,n.If)(Se.and(V),()=>{let e=(0,n.texture)(Ce,Re,0);Be.assign(e),Ge.assign(e.w);let t=(0,n.texture)(we,Re,0);Ue.assign(t.xyz.mul(2).sub(1)),We.assign(t.w)}).Else(()=>{Ke.assign(1)})})});let qe=(0,n.vec3)(0).toVar(),Je=(0,n.vec3)(0).toVar(),W=(0,n.float)(-1e3).toVar(),G=(0,n.vec2)(2).div(o).toVar();(0,n.Loop)({start:(0,n.int)(0),end:Ke,type:`int`,condition:`<`},({i:e})=>{let r=A({state:He.add((0,n.uint)(e))}).toVar(),i=ae(t,e,Ke,r,o,s).toVar();(0,n.If)(l.equal((0,n.int)(9)),()=>{Be.assign((0,n.vec4)(i,1,1)),Ve.assign(1),(0,n.Break)()});let a=i.sub(.5).mul(G),c=ze.add(a),oe=vt.wrap(_n(c,r,u,d,Ae,je,Me,Ne,Pe,Fe,Ie)),Se=(0,n.vec4)(0).toVar();(0,n.If)(l.greaterThan((0,n.int)(0)).and(l.notEqual((0,n.int)(11))),()=>{Se.assign(ra(oe.origin,oe.direction,m,h,g,N,F,P,re,l,xe,t,o,_,v,y,b,x,S,p,f,s))}).Else(()=>{let i=qi.wrap($i(oe,r,e,m,h,g,_,v,y,b,x,S,C,w,T,E,D,O,k,j,M,N,P,F,ee,te,ne,I,re,ie,L,R,se,ce,z,de,le,ue,B,fe,pe,me,he,ge,_e,ve,ye,be,t,o,s));Se.assign(i.radiance),(0,n.If)(e.equal((0,n.int)(0)),()=>{qe.assign(i.objectNormal),Je.assign(i.objectColor),W.assign(i.objectID),(0,n.If)(i.firstHitDistance.lessThan(1e9),()=>{Ue.assign((0,n.normalize)(i.objectNormal)),We.assign(i.firstHitDistance)})})}),Be.addAssign(Se),Ge.addAssign(Se.w),Ve.addAssign(1)}),(0,n.If)(Ve.greaterThan((0,n.int)(0)),()=>{Be.divAssign((0,n.float)(Ve)),Ge.divAssign((0,n.float)(Ve))});let Ye=Be.xyz.toVar(),Xe=(0,n.vec4)(Ue.mul(.5).add(.5),We).toVar(),Ze=(0,n.vec3)(Je).toVar(),K=(0,n.select)(ue,Ge,(0,n.float)(1)).toVar();(0,n.If)(Se.and(De.not()).and(s.greaterThan((0,n.uint)(0))).and(V).and(l.notEqual((0,n.int)(11))),()=>{let e=(0,n.texture)(Ce,Re,0).toVar();Ye.assign((0,n.mix)(e.xyz,Be.xyz,Ee)),Xe.assign((0,n.mix)((0,n.texture)(we,Re,0),Xe,Ee)),Ze.assign((0,n.mix)((0,n.texture)(Te,Re,0).xyz,Ze,Ee)),(0,n.If)(ue,()=>{K.assign((0,n.mix)(e.w,Ge,Ee))})}),(0,n.If)(l.equal((0,n.int)(11)),()=>{Ye.assign(ia(Ye))}),(0,n.textureStore)(r,Le,(0,n.vec4)(Ye.xyz,K)).toWriteOnly(),(0,n.textureStore)(i,Le,Xe).toWriteOnly(),(0,n.textureStore)(a,Le,(0,n.vec4)(Ze,1)).toWriteOnly()},sa=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)}}},ca=8,la=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 sa(`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/ca),this._dispatchY=Math.ceil(o/ca),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),e.goboMaps&&t.goboMapsTex&&(t.goboMapsTex.value=e.goboMaps),e.iesProfiles&&t.iesProfilesTex&&(t.iesProfilesTex.value=e.iesProfiles),console.log(`ShaderBuilder: Scene textures updated in-place`)}updateGoboMaps(e){let t=this._sceneTextureNodes;!t||!t.goboMapsTex||e&&(t.goboMapsTex.value=e)}updateIESProfiles(e){let t=this._sceneTextureNodes;!t||!t.iesProfilesTex||e&&(t.iesProfilesTex.value=e)}getSceneTextureNodes(){return this._sceneTextureNodes}setSize(e,t){this._dispatchX=Math.ceil(e/ca),this._dispatchY=Math.ceil(t/ca),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/ca),a=Math.ceil(r/ca);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(),S=e.goboMaps?(0,n.texture)(e.goboMaps):p();Ur(S);let C=e.iesProfiles?(0,n.texture)(e.iesProfiles):p();qr(C),Qr(h);let w={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,goboMapsTex:S,iesProfilesTex:C};return this._sceneTextureNodes=w,w}_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(ca)).add((0,n.int)(n.localId.x)),D=x.add((0,n.int)(n.workgroupId.y).mul(ca)).add((0,n.int)(n.localId.y));(0,n.If)(t.lessThan(S).and(D.lessThan(C)),()=>{oa({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,groundProjectionEnabled:e.groundProjectionEnabled,groundProjectionRadius:e.groundProjectionRadius,groundProjectionHeight:e.groundProjectionHeight,maxBounceCount:e.maxBounces,transmissiveBounces:e.transmissiveBounces,showBackground:e.showBackground,transparentBackground:e.transparentBackground,backgroundIntensity:e.backgroundIntensity,fireflyThreshold:e.fireflyThreshold,globalIlluminationIntensity:e.globalIlluminationIntensity,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],[ca,ca,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}},ua=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 da;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 da;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}}},da=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}},fa=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}},pa=``+(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),ma={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},ha=ma.FLOATS_PER_TRIANGLE,ga=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}},_a=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=ma.POSITION_A_OFFSET,r=ma.POSITION_B_OFFSET,i=ma.POSITION_C_OFFSET;for(let a=0;a<e;a++){let e=a*ha,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/(ha*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*ha*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(pa,{type:`module`}))}catch(i){i.name===`SecurityError`?We(pa).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/(ha*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 ua(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 fa(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*ha);for(let e=0;e<a;e++){let t=this.indices[e]*ha,n=e*ha;f.set(d.subarray(t,t+ha),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 ga;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 ga;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)}},X={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},va=X.FLOATS_PER_TRIANGLE,ya=16,ba=-1,xa=-2,Sa=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*va,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+X.POSITION_A_OFFSET]=s,e[a+X.POSITION_A_OFFSET+1]=c,e[a+X.POSITION_A_OFFSET+2]=l,e[a+X.POSITION_B_OFFSET]=u,e[a+X.POSITION_B_OFFSET+1]=d,e[a+X.POSITION_B_OFFSET+2]=f,e[a+X.POSITION_C_OFFSET]=p,e[a+X.POSITION_C_OFFSET+1]=m,e[a+X.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+X.NORMAL_A_OFFSET]=S,e[a+X.NORMAL_A_OFFSET+1]=C,e[a+X.NORMAL_A_OFFSET+2]=w,e[a+X.NORMAL_B_OFFSET]=S,e[a+X.NORMAL_B_OFFSET+1]=C,e[a+X.NORMAL_B_OFFSET+2]=w,e[a+X.NORMAL_C_OFFSET]=S,e[a+X.NORMAL_C_OFFSET+1]=C,e[a+X.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*ya,o=(r-n)*6;if(e[a+3]===ba){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)*va,i=t[r+X.POSITION_A_OFFSET],a=t[r+X.POSITION_A_OFFSET+1],o=t[r+X.POSITION_A_OFFSET+2],p=t[r+X.POSITION_B_OFFSET],m=t[r+X.POSITION_B_OFFSET+1],h=t[r+X.POSITION_B_OFFSET+2],g=t[r+X.POSITION_C_OFFSET],_=t[r+X.POSITION_C_OFFSET+1],v=t[r+X.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*ya,a=i*6,o=e[n+3];if(o===ba){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)*va,r=t[n+X.POSITION_A_OFFSET],a=t[n+X.POSITION_A_OFFSET+1],o=t[n+X.POSITION_A_OFFSET+2],p=t[n+X.POSITION_B_OFFSET],m=t[n+X.POSITION_B_OFFSET+1],h=t[n+X.POSITION_B_OFFSET+2],g=t[n+X.POSITION_C_OFFSET],_=t[n+X.POSITION_C_OFFSET+1],v=t[n+X.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===xa){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)}}}},Ca=``+(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),wa=32,Ta=5e4,Ea=8;function Da(e,t,n,r){let i=e.byteLength/(wa*4),a=Math.min(navigator.hardwareConcurrency||4,Ea),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*wa*4),h;try{h=new Worker(pa,{type:`module`})}catch(e){if(e.name!==`SecurityError`)throw e;h=await We(pa)}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(ka(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,Oa(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 Oa(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(Ca,{type:`module`})}catch(e){if(e.name!==`SecurityError`)throw e;s=await We(Ca)}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 ka(e,t,n,r){return new Promise((i,a)=>{(async()=>{let o;try{o=new Worker(pa,{type:`module`})}catch(e){if(e.name!==`SecurityError`)throw e;o=await We(pa)}let s=e.byteLength/(wa*4),c=typeof SharedArrayBuffer<`u`?new SharedArrayBuffer(s*wa*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 Aa(e){return typeof Worker<`u`&&typeof SharedArrayBuffer<`u`&&e>=Ta}var ja=16,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.entryIndex=-1}},Na=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 Ma;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*ja;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*ja;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]=Ae.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}},Pa=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}},Fa=``+(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),Ia=class{constructor(){this.canvasContextPairs=[],this.maxPoolSize=je.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=[]}},La=class{constructor(e={}){this.pools=new Map,this.memoryUsage=0,this.maxMemoryUsage=e.maxMemory||Fe.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*Fe.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<je.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`}},Ra=class{constructor(e=je.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=[]}},za=class{constructor(e={}){this.useWorkers=typeof Worker<`u`,this.maxConcurrentWorkers=je.MAX_CONCURRENT_WORKERS,this.activeWorkers=0,this.canvasPool=new Ia,this.bufferPool=new La({maxMemory:e.maxBufferMemory||Fe.MAX_BUFFER_MEMORY,sizeStrategy:e.bufferSizeStrategy||`adaptive`}),this.textureCache=new Ra,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>Fe.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(Fa,{type:`module`})}catch(e){if(e.name!==`SecurityError`)throw e;t=await We(Fa)}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:je.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%Fe.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??Me,s=n.normalMapMatrices??Me,c=n.roughnessMapMatrices??Me,l=n.metalnessMapMatrices??Me,u=n.emissiveMapMatrices??Me,d=n.bumpMapMatrices??Me,f=n.displacementMapMatrices??Me,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=je.VEC4_PER_BVH_NODE*je.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 Ra;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>=je.MAX_TEXTURE_SIZE/2||n>=je.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:Ba(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:Ba(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 Ba(e,t,n){let r=new Uint8ClampedArray(e.buffer,e.byteOffset,e.byteLength);return createImageBitmap(new ImageData(r,t,n))}var Va=128,Ha=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<Va){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}}},Ua=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}}},Wa=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 Ua().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}},Ga=``+(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),Ka=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 Ha,this.bvhBuilder=new _a,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 za,this.emissiveTriangleBuilder=new Wa,this.tlasBuilder=new Na}_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 sa(`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 Pa,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&&Aa(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})=>Da(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(pa,{type:`module`})}catch(t){if(t.name!==`SecurityError`){l(t);return}e=await We(pa)}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(Ga,{type:`module`})}catch(e){if(e.name!==`SecurityError`)throw e;this._refitWorker=await We(Ga)}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 Sa;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(pa,{type:`module`}),i(t,e,r)}catch(n){if(n.name!==`SecurityError`)throw n;We(pa).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}},qa=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,o=e.userData?.gobo,s=o&&Number.isInteger(o.index)?o.index:-1,c=o&&typeof o.intensity==`number`?o.intensity:1,l=o&&o.inverted?-Math.abs(c):Math.abs(c),u=o&&typeof o.scale==`number`?o.scale:5;this.directionalLightCache.push({data:[n.x,n.y,n.z,e.color.r,e.color.g,e.color.b,e.intensity,a,s,l,u,0],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`),a=e.userData?.gobo,o=a&&Number.isInteger(a.index)?a.index:-1,s=a&&typeof a.intensity==`number`?a.intensity:1,c=a&&a.inverted?-Math.abs(s):Math.abs(s),l=e.userData?.ies,u=l&&Number.isInteger(l.index)?l.index:-1,d=l&&typeof l.intensity==`number`?l.intensity:1;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,o,c,u,d,0,0],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/12),n=Math.floor(this.lightData.rectArea.length/13),r=Math.floor(this.lightData.point.length/9),i=Math.floor(this.lightData.spot.length/20);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}))}}},Ja={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 Ya(e){e&&Object.assign(Ja,e)}function Xa(){return{...Ja}}var Za=4,Qa=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 Ka,this.lightSerializer=new qa,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 Le(a,o),this._defineUniformGetters(),this.materialData=new Ue(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 _t(this.scene,this.uniforms),this.environment.callbacks.onReset=()=>this.reset(),this.environment.callbacks.getSceneTextureNodes=()=>this.shaderBuilder.getSceneTextureNodes(),this.shaderBuilder=new la,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.goboMaps=null,this.iesProfiles=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}=Xa();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.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/12)):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/20)):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/Za),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){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 t=this.frameCount,n=this.renderMode.value,r=null,i=null;n===1&&t===0&&(r=this.maxBounces.value,i=this.samplesPerPixel.value,this.maxBounces.value=1,this.samplesPerPixel.value=1),this._handleResize(),this.manageASVGFForRenderMode(n,t);let a=this.tileManager.handleTileRendering(this.renderer,n,t,null);if(e&&e.setState(`tileRenderingComplete`,a.isCompleteCycle),a.tileIndex>=0){let e=this.tileManager.calculateTileBounds(a.tileIndex,this.tileManager.tiles,this.width,this.height);this.emit(`tile:changed`,{tileIndex:a.tileIndex,tileBounds:e,renderMode:n}),this.tileChanged=!0}this.cameraChanged=this._updateCameraUniforms(),this.cameraOptimizer?.updateInteractionMode(this.cameraChanged),this._updateAccumulationUniforms(t,n),this.frame.value=t,a.tileIndex>=0&&a.tileBounds?this.shaderBuilder.setTileDispatch(a.tileBounds.x,a.tileBounds.y,a.tileBounds.width,a.tileBounds.height):this.shaderBuilder.setFullScreenDispatch();let o=this.storageTextures.getReadTextures();this.shaderBuilder.prevColorTexNode&&(this.shaderBuilder.prevColorTexNode.value=o.color,this.shaderBuilder.prevNormalDepthTexNode.value=o.normalDepth,this.shaderBuilder.prevAlbedoTexNode.value=o.albedo),this.renderer.compute(this.shaderBuilder.computeNode),this.storageTextures.copyToReadTargets(this.renderer);let s=this.storageTextures.getReadTextures();e&&this._publishTexturesToContext(e,s),this._emitStateEvents(),this.cameraOptimizer?.isInInteractionMode()||this.frameCount++,r!==null&&(this.maxBounces.value=r),i!==null&&(this.samplesPerPixel.value=i),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}},$a=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;let s={type:r.HalfFloatType,format:r.RGBAFormat,minFilter:r.NearestFilter,magFilter:r.NearestFilter,depthBuffer:!1,stencilBuffer:!1};this._rtA=new t.RenderTarget(a,o,s),this._rtB=new t.RenderTarget(a,o,s),this._currentIdx=0,this._hasHistory=!1,this._dispatchX=Math.ceil(a/8),this._dispatchY=Math.ceil(o/8),this._triStorageNode=null,this._bvhStorageNode=null,this._lastTriAttr=null,this._lastBvhAttr=null,this._computeNode=null,this._computeBuilt=!1}setupEventListeners(){this.on(`camera:moved`,()=>{this._dirty=!0}),this.on(`pipeline:reset`,()=>{this._dirty=!0,this._hasHistory=!1})}_syncStorageBuffers(){let e=this.pathTracer;if(!e)return!1;let t=e.triangleStorageAttr&&e.triangleStorageAttr!==this._lastTriAttr,r=e.bvhStorageAttr&&e.bvhStorageAttr!==this._lastBvhAttr;return(t||r)&&(this._computeNode?.dispose?.(),this._computeNode=null,this._computeBuilt=!1,this._triStorageNode=null,this._bvhStorageNode=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()),this._lastTriAttr=e.triangleStorageAttr||this._lastTriAttr,this._lastBvhAttr=e.bvhStorageAttr||this._lastBvhAttr,!!(this._triStorageNode&&this._bvhStorageNode)}_buildCompute(){let e=this._triStorageNode,t=this._bvhStorageNode,r=this.cameraWorldMatrix,i=this.cameraProjectionMatrixInverse,a=this.resolutionWidth,o=this.resolutionHeight,s=this._outputStorageTex;this._computeNode=(0,n.Fn)(([r,i])=>{let c=(0,n.int)(n.workgroupId.x).mul(8).add((0,n.int)(n.localId.x)),l=(0,n.int)(n.workgroupId.y).mul(8).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.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),d=i.mul((0,n.vec4)(u,1)),f=(0,n.normalize)((0,n.mat3)(r[0].xyz,r[1].xyz,r[2].xyz).mul(d.xyz.div(d.w))),p=vt({origin:(0,n.vec3)(r[3]),direction:f}),m=xt.wrap(hn(p,t,e)),h=m.normal.mul(.5).add(.5),g=m.dst,_=m.didHit.select((0,n.vec4)(h,g),(0,n.vec4)(0,0,0,(0,n.float)(1e6)));(0,n.textureStore)(s,(0,n.uvec2)((0,n.uint)(c),(0,n.uint)(l)),_).toWriteOnly()})})(r,i).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._hasHistory){let t=this._currentIdx===0?this._rtA:this._rtB;e.setTexture(`pathtracer:normalDepth`,t.texture),e.setTexture(`pathtracer:prevNormalDepth`,t.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._rtA.width||e.height!==this._rtA.height)&&this.setSize(e.width,e.height)}this._hasHistory&&(this._currentIdx=1-this._currentIdx);let r=this._currentIdx===0?this._rtA:this._rtB,i=this._currentIdx===0?this._rtB:this._rtA;this.renderer.compute(this._computeNode),this.renderer.copyTextureToTexture(this._outputStorageTex,r.texture),this._hasHistory||=(this.renderer.copyTextureToTexture(this._outputStorageTex,i.texture),!0),e.setTexture(`pathtracer:normalDepth`,r.texture),e.setTexture(`pathtracer:prevNormalDepth`,i.texture),this._dirty=!1}reset(){this._dirty=!0,this._hasHistory=!1}setSize(e,t){this._outputStorageTex.setSize(e,t),this._rtA.setSize(e,t),this._rtB.setSize(e,t),this._hasHistory=!1,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._rtA?.dispose(),this._rtB?.dispose()}},eo=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()}},to=class extends R{constructor(e,i={}){super(`ASVGF`,{...i,executionMode:L.PER_CYCLE}),this.renderer=e,this.temporalAlpha=(0,n.uniform)(i.temporalAlpha??0),this.gradientStrength=(0,n.uniform)(i.gradientStrength??0),this.gradientNoiseFloor=(0,n.uniform)(i.gradientNoiseFloor??.15),this.maxAccumFrames=(0,n.uniform)(i.maxAccumFrames??32),this.resW=(0,n.uniform)(i.width||1),this.resH=(0,n.uniform)(i.height||1),this.temporalEnabledU=(0,n.uniform)(1),this._colorTexNode=new t.TextureNode,this._prevColorTexNode=new t.TextureNode,this._albedoTexNode=new t.TextureNode,this._motionTexNode=new t.TextureNode,this._normalDepthTexNode=new t.TextureNode,this._prevNormalDepthTexNode=new t.TextureNode,this._readTemporalTexNode=new t.TextureNode,this._gradientReadTexNode=new t.TextureNode;let a=i.width||1,o=i.height||1;this._temporalTexA=new t.StorageTexture(a,o),this._temporalTexA.type=r.FloatType,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.FloatType,this._temporalTexB.format=r.RGBAFormat,this._temporalTexB.minFilter=r.LinearFilter,this._temporalTexB.magFilter=r.LinearFilter,this._outputModulatedTex=new t.StorageTexture(a,o),this._outputModulatedTex.type=r.FloatType,this._outputModulatedTex.format=r.RGBAFormat,this._outputModulatedTex.minFilter=r.LinearFilter,this._outputModulatedTex.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._prevColorRT=new t.RenderTarget(a,o,{type:r.FloatType,format:r.RGBAFormat,minFilter:r.NearestFilter,magFilter:r.NearestFilter,depthBuffer:!1,stencilBuffer:!1}),this._prevColorReady=!1,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()}_buildGradientCompute(){let e=this._colorTexNode,t=this._prevColorTexNode,r=this._motionTexNode,i=this.gradientNoiseFloor,a=this._gradientStorageTex,o=this.resW,s=this.resH,c=(0,n.workgroupArray)(`float`,144),l=(0,n.workgroupArray)(`float`,144);this._gradientNode=(0,n.Fn)(()=>{let u=n.localId.x,d=n.localId.y,f=d.mul(8).add(u),p=(0,n.int)(n.workgroupId.x).mul(8).sub(2).toVar(),m=(0,n.int)(n.workgroupId.y).mul(8).sub(2).toVar(),h=i=>{let a=i.mod((0,n.uint)(12)),u=i.div((0,n.uint)(12)),d=p.add((0,n.int)(a)).clamp((0,n.int)(0),(0,n.int)(o).sub(1)),f=m.add((0,n.int)(u)).clamp((0,n.int)(0),(0,n.int)(s).sub(1)),h=(0,n.textureLoad)(e,(0,n.ivec2)(d,f)).xyz;c.element(i).assign(Gt(h));let g=(0,n.textureLoad)(r,(0,n.ivec2)(d,f)),_=(0,n.float)(d).sub(g.x.mul(o)),v=(0,n.float)(f).sub(g.y.mul(s)),y=(0,n.int)(_).clamp((0,n.int)(0),(0,n.int)(o).sub(1)),b=(0,n.int)(v).clamp((0,n.int)(0),(0,n.int)(s).sub(1)),x=g.w.greaterThan(.5),S=(0,n.textureLoad)(t,(0,n.ivec2)(y,b)).xyz,C=x.select(Gt(S),Gt(h));l.element(i).assign(C)};h(f);let g=f.add((0,n.uint)(64));(0,n.If)(g.lessThan((0,n.uint)(144)),()=>{h(g)});let _=f.add((0,n.uint)(128));(0,n.If)(_.lessThan((0,n.uint)(144)),()=>{h(_)}),(0,n.workgroupBarrier)();let v=(0,n.int)(n.workgroupId.x).mul(8).add((0,n.int)(u)),y=(0,n.int)(n.workgroupId.y).mul(8).add((0,n.int)(d));(0,n.If)(v.lessThan((0,n.int)(o)).and(y.lessThan((0,n.int)(s))),()=>{let e=(0,n.float)(0).toVar(),t=(0,n.float)(0).toVar();for(let r=-2;r<=2;r++)for(let i=-2;i<=2;i++){let a=d.add((0,n.uint)(2+r)).mul((0,n.uint)(12)).add(u.add((0,n.uint)(2+i))),o=c.element(a),s=l.element(a);e.addAssign((0,n.abs)(o.sub(s))),t.addAssign(o.add(s).mul(.5))}let r=e.div((0,n.max)(t,(0,n.float)(.001))).clamp(0,1),o=(0,n.max)((0,n.float)(1).sub(i),(0,n.float)(1e-4)),s=(0,n.max)(r.sub(i),(0,n.float)(0)).div(o).clamp(0,1);(0,n.textureStore)(a,(0,n.uvec2)((0,n.uint)(v),(0,n.uint)(y)),(0,n.vec4)(s,r,t.div(25),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._albedoTexNode,i=this._motionTexNode,a=this._normalDepthTexNode,o=this._prevNormalDepthTexNode,s=this._readTemporalTexNode,c=this._gradientReadTexNode,l=this._outputModulatedTex,u=this.maxAccumFrames,d=this.temporalAlpha,f=this.gradientStrength,p=this.temporalEnabledU,m=this.resW,h=this.resH;return(0,n.Fn)(()=>{let g=(0,n.int)(n.workgroupId.x).mul(8).add((0,n.int)(n.localId.x)),_=(0,n.int)(n.workgroupId.y).mul(8).add((0,n.int)(n.localId.y));(0,n.If)(g.lessThan((0,n.int)(m)).and(_.lessThan((0,n.int)(h))),()=>{let v=(0,n.ivec2)(g,_),y=(0,n.textureLoad)(t,v).xyz,b=(0,n.textureLoad)(r,v).xyz,x=(0,n.max)(b,(0,n.vec3)(Ce)),S=y.div(x),C=(0,n.vec4)(S,1).toVar(),w=(0,n.vec4)(y,1).toVar();(0,n.If)(p.greaterThan(.5),()=>{let e=(0,n.textureLoad)(i,v),t=e.w.greaterThan(.5),r=(0,n.float)(g).sub(e.x.mul(m)),l=(0,n.float)(_).sub(e.y.mul(h)),p=r.greaterThanEqual(0).and(r.lessThan((0,n.float)(m).sub(1))).and(l.greaterThanEqual(0)).and(l.lessThan((0,n.float)(h).sub(1)));(0,n.If)(t.and(p),()=>{let e=(0,n.textureLoad)(a,v),t=e.xyz.mul(2).sub(1),i=e.w,p=(0,n.int)(r),g=(0,n.int)(l),_=p.add((0,n.int)(1)),y=g.add((0,n.int)(1)),b=r.sub((0,n.float)(p)),T=l.sub((0,n.float)(g)),E=p.clamp((0,n.int)(0),(0,n.int)(m).sub(1)),D=_.clamp((0,n.int)(0),(0,n.int)(m).sub(1)),O=g.clamp((0,n.int)(0),(0,n.int)(h).sub(1)),k=y.clamp((0,n.int)(0),(0,n.int)(h).sub(1)),A=(0,n.float)(1).sub(b).mul((0,n.float)(1).sub(T)),j=b.mul((0,n.float)(1).sub(T)),M=(0,n.float)(1).sub(b).mul(T),N=b.mul(T),P=(e,r,a)=>{let s=(0,n.textureLoad)(o,(0,n.ivec2)(e,r)),c=s.xyz.mul(2).sub(1),l=s.w,u=(0,n.pow)((0,n.dot)(t,c).clamp(0,1),(0,n.float)(16)),d=(0,n.exp)((0,n.abs)(i.sub(l)).div((0,n.max)(i,(0,n.float)(.001))).div((0,n.float)(.05)).negate());return a.mul(u).mul(d)},F=P(E,O,A),ee=P(D,O,j),te=P(E,k,M),ne=P(D,k,N),I=F.add(ee).add(te).add(ne);(0,n.If)(I.greaterThan((0,n.float)(.01)),()=>{let e=(0,n.textureLoad)(s,(0,n.ivec2)(E,O)),t=(0,n.textureLoad)(s,(0,n.ivec2)(D,O)),r=(0,n.textureLoad)(s,(0,n.ivec2)(E,k)),i=(0,n.textureLoad)(s,(0,n.ivec2)(D,k)),a=(0,n.float)(1).div(I),o=e.xyz.mul(F).add(t.xyz.mul(ee)).add(r.xyz.mul(te)).add(i.xyz.mul(ne)).mul(a),l=e.w.mul(F).add(t.w.mul(ee)).add(r.w.mul(te)).add(i.w.mul(ne)).mul(a),p=(0,n.textureLoad)(c,v).x.mul(f).clamp(0,1),m=(0,n.mix)(o,S,(0,n.mix)((0,n.max)((0,n.float)(1).div(l.add(1)),d),(0,n.float)(1),p)),h=(0,n.min)(l.add(1),u);C.assign((0,n.vec4)(m,h)),w.assign((0,n.vec4)(m.mul(x),1))})})}),(0,n.textureStore)(e,(0,n.uvec2)((0,n.uint)(g),(0,n.uint)(_)),C).toWriteOnly(),(0,n.textureStore)(l,(0,n.uvec2)((0,n.uint)(g),(0,n.uint)(_)),w).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=Gt(o);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.setTemporalEnabled(e.enabled)}),this.on(`asvgf:updateParameters`,e=>this.updateParameters(e))}render(e){if(!this.enabled)return;let t=e.getTexture(`pathtracer:color`),n=e.getTexture(`pathtracer:albedo`),r=e.getTexture(`pathtracer:normalDepth`),i=e.getTexture(`pathtracer:prevNormalDepth`)||r,a=e.getTexture(`motionVector:screenSpace`);if(!t)return;let o=t.image;o&&o.width>0&&o.height>0&&(o.width!==this._temporalTexA.image.width||o.height!==this._temporalTexA.image.height)&&this.setSize(o.width,o.height),this._colorTexNode.value=t,n&&(this._albedoTexNode.value=n),a&&(this._motionTexNode.value=a),r&&(this._normalDepthTexNode.value=r),i&&(this._prevNormalDepthTexNode.value=i);let s=this.currentMoments===0?this._temporalTexB:this._temporalTexA,c=this.currentMoments===0?this._temporalNodeA:this._temporalNodeB,l=this.currentMoments===0?this._temporalTexA:this._temporalTexB;this._prevColorTexNode.value=this._prevColorReady?this._prevColorRT.texture:t,this._compiled||=(this.renderer.compute(this._gradientNode),this.renderer.compute(this._temporalNodeA),this.renderer.compute(this._temporalNodeB),!0),this._readTemporalTexNode.value=s,this._gradientReadTexNode.value=this._gradientStorageTex;let u=this.gradientStrength.value>0||this.showHeatmap;u&&this.renderer.compute(this._gradientNode),this.renderer.compute(c),u&&(this.renderer.copyTextureToTexture(t,this._prevColorRT.texture),this._prevColorReady=!0),e.setTexture(`asvgf:demodulated`,l),e.setTexture(`asvgf:output`,this._outputModulatedTex),e.setTexture(`asvgf:gradient`,this._gradientStorageTex),this.currentMoments=1-this.currentMoments,this.showHeatmap&&(this._heatmapRawColorTexNode.value=t,this._heatmapColorTexNode.value=this._outputModulatedTex,this._heatmapTemporalTexNode.value=l,r&&(this._heatmapNDTexNode.value=r),a&&(this._heatmapMotionTexNode.value=a),this._heatmapGradientTexNode.value=this._gradientStorageTex,this.renderer.compute(this._heatmapComputeNode),this.renderer.copyTextureToTexture(this._heatmapStorageTex,this.heatmapTarget.texture))}setHeatmapEnabled(e){this.showHeatmap=e}setTemporalEnabled(e){this.temporalEnabledU.value=+!!e}updateParameters(e){e&&(e.temporalAlpha!==void 0&&(this.temporalAlpha.value=e.temporalAlpha),e.gradientStrength!==void 0&&(this.gradientStrength.value=e.gradientStrength),e.gradientNoiseFloor!==void 0&&(this.gradientNoiseFloor.value=e.gradientNoiseFloor),e.maxAccumFrames!==void 0&&(this.maxAccumFrames.value=e.maxAccumFrames),e.debugMode!==void 0&&(this.debugMode.value=e.debugMode))}resetTemporalData(){this.currentMoments=0,this._prevColorReady=!1}setSize(e,t){this._temporalTexA.setSize(e,t),this._temporalTexB.setSize(e,t),this._outputModulatedTex.setSize(e,t),this._gradientStorageTex.setSize(e,t),this._prevColorRT.setSize(e,t),this._heatmapStorageTex.setSize(e,t),this.heatmapTarget.setSize(e,t),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],this._compiled=!1,this._prevColorReady=!1}reset(){}dispose(){this._gradientNode?.dispose(),this._temporalNodeA?.dispose(),this._temporalNodeB?.dispose(),this._temporalTexA?.dispose(),this._temporalTexB?.dispose(),this._outputModulatedTex?.dispose(),this._gradientStorageTex?.dispose(),this._prevColorRT?.dispose(),this._heatmapComputeNode?.dispose(),this._heatmapStorageTex?.dispose(),this.heatmapTarget?.dispose(),this._colorTexNode?.dispose(),this._prevColorTexNode?.dispose(),this._albedoTexNode?.dispose(),this._motionTexNode?.dispose(),this._normalDepthTexNode?.dispose(),this._prevNormalDepthTexNode?.dispose(),this._readTemporalTexNode?.dispose(),this._gradientReadTexNode?.dispose(),this._heatmapRawColorTexNode?.dispose(),this._heatmapColorTexNode?.dispose(),this._heatmapTemporalTexNode?.dispose(),this._heatmapNDTexNode?.dispose(),this._heatmapMotionTexNode?.dispose(),this._heatmapGradientTexNode?.dispose()}},no=(0,n.wgslFn)(`
558
558
  fn temporalAccumulate(
559
559
  lum: f32,
560
560
  prevMean: f32,
@@ -576,7 +576,7 @@
576
576
  );
577
577
 
578
578
  }
579
- `),no=class extends z{constructor(e,i={}){super(`VarianceEstimation`,{...i,executionMode:R.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(Wt(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(Wt(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)),to(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()}},ro=(0,n.wgslFn)(`
579
+ `),ro=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(Gt(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(Gt(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)),no(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()}},io=(0,n.wgslFn)(`
580
580
  fn bilateralWeight(
581
581
  centerLum: f32, sLum: f32,
582
582
  centerNormal: vec3f, sNormal: vec3f,
@@ -599,7 +599,7 @@
599
599
  return kernelW * lumW * normW * depW * colW;
600
600
 
601
601
  }
602
- `),io=class extends z{constructor(e,i={}){super(`BilateralFiltering`,{...i,executionMode:R.ALWAYS}),this.renderer=e,this.inputTextureName=i.inputTextureName||`asvgf:demodulated`,this.normalDepthTextureName=i.normalDepthTextureName||`pathtracer:normalDepth`,this.albedoTextureName=i.albedoTextureName||`pathtracer:albedo`,this.varianceTextureName=i.varianceTextureName||`variance:output`,this.iterations=i.iterations??4,this.phiColor=(0,n.uniform)(i.phiColor??.5),this.phiNormal=(0,n.uniform)(i.phiNormal??128),this.phiDepth=(0,n.uniform)(i.phiDepth??.05),this.phiLuminance=(0,n.uniform)(i.phiLuminance??4),this.stepSizeU=(0,n.uniform)(1,`int`),this.isLastIterationU=(0,n.uniform)(0,`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,this._albedoTexNode=new t.TextureNode,this._varianceTexNode=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._albedoTexNode,a=this._varianceTexNode,o=this.phiColor,s=this.phiNormal,c=this.phiDepth,l=this.phiLuminance,u=this.stepSizeU,d=this.isLastIterationU,f=this.resW,p=this.resH,m=[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 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)(f)).and(g.lessThan((0,n.int)(p))),()=>{let _=(0,n.ivec2)(h,g),v=(0,n.textureLoad)(t,_).xyz,y=(0,n.textureLoad)(r,_),b=y.xyz.mul(2).sub(1),x=y.w,S=Wt(v),C=(0,n.max)((0,n.textureLoad)(i,_).xyz,(0,n.vec3)(Se)),w=(0,n.max)(Wt(C),(0,n.float)(Se)).toVar(),T=(0,n.textureLoad)(a,_).z,E=l.mul((0,n.sqrt)((0,n.max)(T,(0,n.float)(0)))).div(w).add((0,n.float)(1e-4)),D=(0,n.vec3)(0).toVar(),O=(0,n.float)(0).toVar();for(let e=0;e<5;e++)for(let i=0;i<5;i++){let a=i-2,l=e-2,d=m[e*5+i],_=h.add(u.mul(a)).clamp((0,n.int)(0),(0,n.int)(f).sub(1)),y=g.add(u.mul(l)).clamp((0,n.int)(0),(0,n.int)(p).sub(1)),C=(0,n.textureLoad)(t,(0,n.ivec2)(_,y)).xyz,w=(0,n.textureLoad)(r,(0,n.ivec2)(_,y)),T=w.xyz.mul(2).sub(1),k=w.w,A=ro(S,Wt(C),b,T,x,k,v,C,(0,n.float)(d),E,s,c,o);D.addAssign(C.mul(A)),O.addAssign(A)}let k=D.div((0,n.max)(O,(0,n.float)(1e-4))),A=d.equal((0,n.int)(1)).select(k.mul(C),k);(0,n.textureStore)(e,(0,n.uvec2)((0,n.uint)(h),(0,n.uint)(g)),(0,n.vec4)(A,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(`asvgf:output`)||e.getTexture(`pathtracer:color`),n=e.getTexture(this.normalDepthTextureName),r=e.getTexture(this.albedoTextureName),i=e.getTexture(this.varianceTextureName);if(!t)return;let a=t.image;a&&a.width>0&&a.height>0&&(a.width!==this._storageTexA.image.width||a.height!==this._storageTexA.image.height)&&this.setSize(a.width,a.height),n&&(this._normalDepthTexNode.value=n),r&&(this._albedoTexNode.value=r),this._compiled||=(this.renderer.compute(this._computeNodeA),this.renderer.compute(this._computeNodeB),!0),i&&(this._varianceTexNode.value=i);let o=t,s=this._computeNodeA,c=this._computeNodeB;for(let e=0;e<this.iterations;e++){this.stepSizeU.value=1<<e,this._readTexNode.value=o,this.isLastIterationU.value=+(e===this.iterations-1),this.renderer.compute(s),o=s===this._computeNodeA?this._storageTexA:this._storageTexB;let t=s;s=c,c=t}e.setTexture(`bilateralFiltering:output`,o)}updateParameters(e){e&&(e.phiColor!==void 0&&(this.phiColor.value=e.phiColor),e.phiNormal!==void 0&&(this.phiNormal.value=e.phiNormal),e.phiDepth!==void 0&&(this.phiDepth.value=e.phiDepth),e.phiLuminance!==void 0&&(this.phiLuminance.value=e.phiLuminance),e.atrousIterations!==void 0&&(this.iterations=e.atrousIterations))}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(),this._albedoTexNode?.dispose(),this._varianceTexNode?.dispose()}},ao=(0,n.wgslFn)(`
602
+ `),ao=class extends R{constructor(e,i={}){super(`BilateralFiltering`,{...i,executionMode:L.ALWAYS}),this.renderer=e,this.inputTextureName=i.inputTextureName||`asvgf:demodulated`,this.normalDepthTextureName=i.normalDepthTextureName||`pathtracer:normalDepth`,this.albedoTextureName=i.albedoTextureName||`pathtracer:albedo`,this.varianceTextureName=i.varianceTextureName||`variance:output`,this.iterations=i.iterations??4,this.phiColor=(0,n.uniform)(i.phiColor??.5),this.phiNormal=(0,n.uniform)(i.phiNormal??128),this.phiDepth=(0,n.uniform)(i.phiDepth??.05),this.phiLuminance=(0,n.uniform)(i.phiLuminance??4),this.stepSizeU=(0,n.uniform)(1,`int`),this.isLastIterationU=(0,n.uniform)(0,`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,this._albedoTexNode=new t.TextureNode,this._varianceTexNode=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._albedoTexNode,a=this._varianceTexNode,o=this.phiColor,s=this.phiNormal,c=this.phiDepth,l=this.phiLuminance,u=this.stepSizeU,d=this.isLastIterationU,f=this.resW,p=this.resH,m=[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 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)(f)).and(g.lessThan((0,n.int)(p))),()=>{let _=(0,n.ivec2)(h,g),v=(0,n.textureLoad)(t,_).xyz,y=(0,n.textureLoad)(r,_),b=y.xyz.mul(2).sub(1),x=y.w,S=Gt(v),C=(0,n.max)((0,n.textureLoad)(i,_).xyz,(0,n.vec3)(Ce)),w=(0,n.max)(Gt(C),(0,n.float)(Ce)).toVar(),T=(0,n.textureLoad)(a,_).z,E=l.mul((0,n.sqrt)((0,n.max)(T,(0,n.float)(0)))).div(w).add((0,n.float)(1e-4)),D=(0,n.vec3)(0).toVar(),O=(0,n.float)(0).toVar();for(let e=0;e<5;e++)for(let i=0;i<5;i++){let a=i-2,l=e-2,d=m[e*5+i],_=h.add(u.mul(a)).clamp((0,n.int)(0),(0,n.int)(f).sub(1)),y=g.add(u.mul(l)).clamp((0,n.int)(0),(0,n.int)(p).sub(1)),C=(0,n.textureLoad)(t,(0,n.ivec2)(_,y)).xyz,w=(0,n.textureLoad)(r,(0,n.ivec2)(_,y)),T=w.xyz.mul(2).sub(1),k=w.w,A=io(S,Gt(C),b,T,x,k,v,C,(0,n.float)(d),E,s,c,o);D.addAssign(C.mul(A)),O.addAssign(A)}let k=D.div((0,n.max)(O,(0,n.float)(1e-4))),A=d.equal((0,n.int)(1)).select(k.mul(C),k);(0,n.textureStore)(e,(0,n.uvec2)((0,n.uint)(h),(0,n.uint)(g)),(0,n.vec4)(A,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(`asvgf:output`)||e.getTexture(`pathtracer:color`),n=e.getTexture(this.normalDepthTextureName),r=e.getTexture(this.albedoTextureName),i=e.getTexture(this.varianceTextureName);if(!t)return;let a=t.image;a&&a.width>0&&a.height>0&&(a.width!==this._storageTexA.image.width||a.height!==this._storageTexA.image.height)&&this.setSize(a.width,a.height),n&&(this._normalDepthTexNode.value=n),r&&(this._albedoTexNode.value=r),this._compiled||=(this.renderer.compute(this._computeNodeA),this.renderer.compute(this._computeNodeB),!0),i&&(this._varianceTexNode.value=i);let o=t,s=this._computeNodeA,c=this._computeNodeB;for(let e=0;e<this.iterations;e++){this.stepSizeU.value=1<<e,this._readTexNode.value=o,this.isLastIterationU.value=+(e===this.iterations-1),this.renderer.compute(s),o=s===this._computeNodeA?this._storageTexA:this._storageTexB;let t=s;s=c,c=t}e.setTexture(`bilateralFiltering:output`,o)}updateParameters(e){e&&(e.phiColor!==void 0&&(this.phiColor.value=e.phiColor),e.phiNormal!==void 0&&(this.phiNormal.value=e.phiNormal),e.phiDepth!==void 0&&(this.phiDepth.value=e.phiDepth),e.phiLuminance!==void 0&&(this.phiLuminance.value=e.phiLuminance),e.atrousIterations!==void 0&&(this.iterations=e.atrousIterations))}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(),this._albedoTexNode?.dispose(),this._varianceTexNode?.dispose()}},oo=(0,n.wgslFn)(`
603
603
  fn computeSamplingGuidance(
604
604
  temporalVariance: f32,
605
605
  spatialVariance: f32,
@@ -661,7 +661,7 @@
661
661
  );
662
662
 
663
663
  }
664
- `),oo=(0,n.wgslFn)(`
664
+ `),so=(0,n.wgslFn)(`
665
665
  fn heatmapGradient( t: f32, normalizedVariance: f32, converged: f32 ) -> vec4f {
666
666
 
667
667
  let r = clamp( ( t - 0.5 ) * 4.0, 0.0, 1.0 );
@@ -684,7 +684,7 @@
684
684
  return vec4f( color, 1.0 );
685
685
 
686
686
  }
687
- `),so=class extends z{constructor(e,i={}){super(`AdaptiveSampling`,{...i,executionMode:R.PER_CYCLE}),this.renderer=e,this.frameNumber=0,this.delayByFrames=i.delayByFrames??2,this.showAdaptiveSamplingHelper=!1,this.adaptiveSamplingMax=(0,n.uniform)(i.adaptiveSamplingMax??H.adaptiveSamplingMax??32,`int`),this.varianceThreshold=(0,n.uniform)(i.varianceThreshold??H.adaptiveSamplingVarianceThreshold??.01),this.materialBias=(0,n.uniform)(i.materialBias??H.adaptiveSamplingMaterialBias??1.2),this.edgeBias=(0,n.uniform)(i.edgeBias??H.adaptiveSamplingEdgeBias??1.5),this.convergenceSpeed=(0,n.uniform)(i.convergenceSpeed??H.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/8),this._dispatchY=Math.ceil(o/8),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(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)(c)).and(f.lessThan((0,n.int)(l))),()=>{let c=(0,n.textureLoad)(e,(0,n.ivec2)(d,f)),l=ao(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],[8,8,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(8).add((0,n.int)(n.localId.x)),o=(0,n.int)(n.workgroupId.y).mul(8).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=oo(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],[8,8,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/8),this._dispatchY=Math.ceil(t/8),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}},co=class extends z{constructor(e,i={}){super(`EdgeAwareFiltering`,{...i,executionMode:R.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,zt),_=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,zt),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)),F=D.mul(N).mul(A).mul(P);C.addAssign(m.mul(F)),w.addAssign(F)}let T=(0,n.mix)(h,C.div((0,n.max)(w,(0,n.float)(1e-4))),S),E=(0,n.dot)(T,zt),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()}},lo=256,uo=-8,fo=6-uo,po=fo/lo,mo=1e4,ho=(0,n.wgslFn)(`
687
+ `),co=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/8),this._dispatchY=Math.ceil(o/8),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(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)(c)).and(f.lessThan((0,n.int)(l))),()=>{let c=(0,n.textureLoad)(e,(0,n.ivec2)(d,f)),l=oo(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],[8,8,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(8).add((0,n.int)(n.localId.x)),o=(0,n.int)(n.workgroupId.y).mul(8).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=so(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],[8,8,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/8),this._dispatchY=Math.ceil(t/8),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}},lo=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,Bt),_=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,Bt),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)),F=D.mul(N).mul(A).mul(P);C.addAssign(m.mul(F)),w.addAssign(F)}let T=(0,n.mix)(h,C.div((0,n.max)(w,(0,n.float)(1e-4))),S),E=(0,n.dot)(T,Bt),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()}},uo=256,fo=-8,po=6-fo,mo=po/uo,ho=1e4,go=(0,n.wgslFn)(`
688
688
  fn adaptExposure(
689
689
  geoMean: f32,
690
690
  prevExposure: f32,
@@ -713,6 +713,8 @@
713
713
  return vec4f( newExposure, geoMean, targetExp, 1.0 );
714
714
 
715
715
  }
716
- `),go=class extends z{constructor(e,r={}){super(`AutoExposure`,{...r,executionMode:R.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)(lo,`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=Wt((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)(uo)).div((0,n.float)(fo)).mul((0,n.float)(lo)).floor().clamp(0,(0,n.float)(lo-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)(mo)));(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)(lo,({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)(lo,({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)(uo).add((0,n.float)(t).add(.5).mul((0,n.float)(po)));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=ho(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 _o({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=rn(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 vo({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),_=rn(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 yo=class extends z{constructor(e,i={}){super(`SSRC`,{...i,executionMode:R.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=_o({...e,writeCacheTex:this._cacheTexA,writePrevNDTex:this._prevNDTexA,framesSinceReset:this._framesSinceReset}),n=_o({...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=vo({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)}},bo=class extends z{constructor(e,i={}){super(`Compositor`,{...i,executionMode:R.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,zt)),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(`bilateralFiltering: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}},xo=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={}}},So=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):[]}},Co=class{constructor(e,t,n){this.renderer=e,this.width=t,this.height=n,this.stages=[],this.context=new xo,this.eventBus=new So,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()}},wo=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}},To=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:B.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:B.OBJECT_SELECTED,object:t.object,uuid:t.uuid})}),this.addEventListener(`objectDeselected`,t=>{this.select(null),e.refreshFrame(),e.dispatchEvent({type:B.OBJECT_DESELECTED,object:t.object,uuid:t.uuid})}),this.addEventListener(`selectModeChanged`,t=>{e.dispatchEvent({type:B.SELECT_MODE_CHANGED,enabled:t.enabled})}),this.addEventListener(`objectDoubleClicked`,t=>{this.select(t.object),e.refreshFrame(),e.dispatchEvent({type:B.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:B.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}},Eo={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`}},Do=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):ge(this.targetModel),this.targetModel=null,this._externalModel=null)}setRenderer(e){this.renderer=e}getFileFormat(e){return Eo[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}`);V({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(Eo[n]&&Eo[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{V({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}=Ya(),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{V({status:`Loading Model...`,progress:2});let n=await t.loadAsync(e);return V({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{V({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||[],V({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(V({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,V({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(V({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,V({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(V({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,V({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(V({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,V({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(V({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,V({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(V({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,V({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(V({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,V({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,V({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 oa(`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(Eo))r.type===e&&(t[n]=r);return t}return Eo}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}},Oo={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},groundProjectionEnabled:{uniform:`groundProjectionEnabled`,reset:!0},groundProjectionRadius:{uniform:`groundProjectionRadius`,reset:!0},groundProjectionHeight:{uniform:`groundProjectionHeight`,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`}},ko={bounces:`maxBounces`,adaptiveSampling:`useAdaptiveSampling`,debugMode:`visMode`},Ao=class extends r.EventDispatcher{constructor(e=H){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=Oo[e];a&&(this._applyRoute(a,t,i),(n===void 0?a.reset??!0:n)&&this._resetCallback?.(),r||this.dispatchEvent({type:B.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=Oo[r];a&&(this._applyRoute(a,i,e),(a.reset??!0)&&(n=!0),t||this.dispatchEvent({type:B.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=Oo[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(Oo))t in e&&this._values.set(t,e[t]);for(let[t,n]of Object.entries(ko))t in e&&this._values.set(n,e[t])}},jo=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:B.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()}},Mo=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(),this.sceneHelpers?.visible&&this.sceneHelpers.update()}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],n.distance=e.distance??0,n.penumbra=e.penumbra??0,n.decay=e.decay??2):e.type===`PointLight`&&(n.distance=e.distance??0,n.decay=e.decay??2);return(e.type===`SpotLight`||e.type===`DirectionalLight`)&&e.userData?.gobo&&(n.gobo=e.userData.gobo.name,n.goboIntensity=e.userData.gobo.intensity,n.goboInverted=!!e.userData.gobo.inverted,e.type===`DirectionalLight`&&(n.goboScale=e.userData.gobo.scale??5)),e.type===`SpotLight`&&e.userData?.ies&&(n.ies=e.userData.ies.name,n.iesIntensity=e.userData.ies.intensity??1,n.fixtureLumens=e.userData.ies.fixtureLumens??null),n}},No=class{constructor(e,t={}){this.pathTracer=e,this._onReset=t.onReset||null,this.texture=null,this.entries=[],this._size=256}async loadLibrary(e,{size:t=256}={}){if(!Array.isArray(e)||e.length===0)return[];this._size=t;let n=await Promise.all(e.map(e=>Po(e.url))),i=t,a=t,o=n.length,s=new Uint8Array(i*a*o*4),c=document.createElement(`canvas`);c.width=i,c.height=a;let l=c.getContext(`2d`,{willReadFrequently:!0});for(let e=0;e<o;e++){l.clearRect(0,0,i,a),l.drawImage(n[e],0,0,i,a);let t=l.getImageData(0,0,i,a);s.set(t.data,e*i*a*4)}let u=new r.DataArrayTexture(s,i,a,o);u.minFilter=r.LinearFilter,u.magFilter=r.LinearFilter,u.format=r.RGBAFormat,u.type=r.UnsignedByteType,u.generateMipmaps=!1,u.needsUpdate=!0;let d=this.texture;return this.texture=u,this.entries=e.map((e,t)=>({name:e.name,index:t})),this.pathTracer.goboMaps=u,this.pathTracer.shaderBuilder?.updateGoboMaps?.(u),d?.dispose?.(),this.entries}getEntries(){return this.entries.slice()}setLightGobo(e,t,n={}){let{intensity:r=1,inverted:i=!1,scale:a=5}=n,o=this._findGoboLight(e);if(!o)return!1;if(o.userData=o.userData||{},t==null)delete o.userData.gobo;else{let e=this.entries.find(e=>e.name===t);if(!e)return console.warn(`GoboManager: unknown gobo "${t}"`),!1;o.userData.gobo={name:e.name,index:e.index,intensity:Fo(r),inverted:!!i,scale:Math.max(1e-4,a)}}return this.pathTracer.updateLights(),this._onReset?.(),!0}setLightGoboInverted(e,t){let n=this._findGoboLight(e);return n?.userData?.gobo?(n.userData.gobo.inverted=!!t,this.pathTracer.updateLights(),this._onReset?.(),!0):!1}setLightGoboScale(e,t){let n=this._findGoboLight(e);return n?.userData?.gobo?(n.userData.gobo.scale=Math.max(1e-4,t),this.pathTracer.updateLights(),this._onReset?.(),!0):!1}getLightGobo(e){return this._findGoboLight(e)?.userData?.gobo||null}setSpotLightGobo(e,t,n=1,r=!1){return this.setLightGobo(e,t,{intensity:n,inverted:r})}setSpotLightGoboInverted(e,t){return this.setLightGoboInverted(e,t)}getSpotLightGobo(e){return this.getLightGobo(e)}dispose(){this.texture?.dispose?.(),this.texture=null,this.entries=[],this.pathTracer=null,this._onReset=null}_findGoboLight(e){let t=this.pathTracer?.scene?.getObjectByProperty?.(`uuid`,e);return t&&(t.isSpotLight||t.isDirectionalLight)?t:null}_findSpotLight(e){let t=this.pathTracer?.scene?.getObjectByProperty?.(`uuid`,e);return t&&t.isSpotLight?t:null}};function Po(e){return new Promise((t,n)=>{let r=new Image;r.crossOrigin=`anonymous`,r.onload=()=>t(r),r.onerror=()=>n(Error(`Failed to load gobo image: ${e}`)),r.src=e})}function Fo(e){return Math.max(0,Math.min(1,e))}function Io(e,t=`ies`){let n=e.search(/TILT\s*=/i);if(n<0)throw Error(`IES (${t}): missing TILT line`);let r=e.indexOf(`
717
- `,n);if(r<0)throw Error(`IES (${t}): truncated TILT line`);let i=e.slice(n,r).match(/TILT\s*=\s*(\w+)/i),a=i?i[1].toUpperCase():`NONE`,o=e.slice(r);if(a===`INCLUDE`){let e=Bo(o),t=2+2*Number(e[1]);o=Vo(o,t)}let s=Bo(o),c=0,l=()=>Number(s[c++]),u=l(),d=l(),f=l(),p=l(),m=l(),h=l();l(),l(),l(),l();let g=l();if(l(),l(),!Number.isFinite(p)||p<=0)throw Error(`IES (${t}): invalid vertical angle count ${p}`);if(!Number.isFinite(m)||m<=0)throw Error(`IES (${t}): invalid horizontal angle count ${m}`);let _=Array(p);for(let e=0;e<p;e++)_[e]=l();let v=Array(m);for(let e=0;e<m;e++)v[e]=l();let y=Array(p);for(let e=0;e<p;e++)y[e]=new Float32Array(m);let b=f*g,x=0;for(let e=0;e<m;e++)for(let t=0;t<p;t++){let n=l()*b;y[t][e]=n,n>x&&(x=n)}return{verticalAngles:_,horizontalAngles:v,candela:y,maxCandela:x,lumens:d*u,photometricType:h,name:t}}function Lo(e,t,n){let r=new Uint8Array(t*n),{verticalAngles:i,horizontalAngles:a,candela:o,maxCandela:s}=e;if(s<=0)return r;let c=i[i.length-1],l=a[a.length-1],u=a[0],d=a.length===1||l===u;for(let e=0;e<n;e++){let f=(e+.5)/n*c,p=Ho(i,f),m=Math.min(p+1,i.length-1),h=i[m]-i[p],g=h>0?(f-i[p])/h:0;for(let n=0;n<t;n++){let i;if(d)i=Uo(o[p][0],o[m][0],g);else{let e=u+(n+.5)/t*(l-u),r=Ho(a,e),s=Math.min(r+1,a.length-1),c=a[s]-a[r],d=c>0?(e-a[r])/c:0,f=o[p][r],h=o[p][s],_=o[m][r],v=o[m][s];i=Uo(Uo(f,h,d),Uo(_,v,d),g)}let c=Math.min(1,Math.max(0,i/s));r[e*t+n]=Math.round(c*255)}}return r}function Ro(e,t=.1){let{verticalAngles:n,horizontalAngles:r,candela:i,maxCandela:a}=e,o=Math.PI/4;if(a<=0||!n?.length)return o;let s=a*t,c=r.length,l=n[n.length-1],u=!1;for(let e=0;e<n.length;e++){let t=0;for(let n=0;n<c;n++)t+=i[e][n];if(t/=c,t>=s&&(u=!0),u&&t<s){l=n[e];break}}let d=l*Math.PI/180;return Math.min(Math.max(d,5*Math.PI/180),89*Math.PI/180)}function zo(e,t,n=.7){let{verticalAngles:r,horizontalAngles:i,candela:a,maxCandela:o}=e;if(o<=0||!r?.length||t<=0)return 0;let s=o*n,c=i.length,l=0;for(let e=0;e<r.length;e++){let t=0;for(let n=0;n<c;n++)t+=a[e][n];if(t/=c,t>=s)l=r[e];else break}let u=t*180/Math.PI,d=u>0?1-l/u:0;return Math.min(Math.max(d,0),1)}function Bo(e){return e.split(/\s+/).filter(e=>e.length>0)}function Vo(e,t){let n=/\S+/g,r=0;for(;n.exec(e)!==null;)if(r++,r===t)return e.slice(n.lastIndex);return``}function Ho(e,t){if(t<=e[0])return 0;if(t>=e[e.length-1])return e.length-1;let n=0,r=e.length-1;for(;r-n>1;){let i=n+r>>1;e[i]<=t?n=i:r=i}return n}function Uo(e,t,n){return e+(t-e)*n}var Wo=class{constructor(e,t={}){this.pathTracer=e,this._onReset=t.onReset||null,this.texture=null,this.entries=[],this._gridWidth=128,this._gridHeight=128}async loadLibrary(e,{gridWidth:t=128,gridHeight:n=128}={}){if(!Array.isArray(e)||e.length===0)return[];this._gridWidth=t,this._gridHeight=n;let i=(await Promise.all(e.map(async e=>{try{let r=await fetch(e.url);if(!r.ok)throw Error(`HTTP ${r.status}`);let i=Io(await r.text(),e.name);return{it:e,profile:i,grid:Lo(i,t,n)}}catch(t){return console.warn(`IESManager: failed to load "${e.name}": ${t.message}`),null}}))).filter(e=>e!==null);if(i.length===0)return[];let a=i.length,o=t*n,s=new Uint8Array(o*4*a),c=[];for(let e=0;e<a;e++){let t=i[e].grid,n=e*o*4;for(let e=0;e<o;e++){let r=t[e];s[n+e*4+0]=r,s[n+e*4+1]=r,s[n+e*4+2]=r,s[n+e*4+3]=255}let r=i[e].profile,a=Ro(r);c.push({name:i[e].it.name,index:e,maxCandela:r.maxCandela,photometricType:r.photometricType,suggestedAngle:a,suggestedPenumbra:zo(r,a),lumens:r.lumens})}let l=new r.DataArrayTexture(s,t,n,a);l.format=r.RGBAFormat,l.type=r.UnsignedByteType,l.minFilter=r.LinearFilter,l.magFilter=r.LinearFilter,l.generateMipmaps=!1,l.needsUpdate=!0;let u=this.texture;return this.texture=l,this.entries=c,this.pathTracer.iesProfiles=l,this.pathTracer.shaderBuilder?.updateIESProfiles?.(l),u?.dispose?.(),this.entries.map(({name:e,index:t})=>({name:e,index:t}))}getEntries(){return this.entries.slice()}setSpotLightProfile(e,t,n=1,{applyAutoCone:r=!0}={}){let i=this._findSpotLight(e),a={applied:!1,suggestedAngle:null,suggestedPenumbra:null,suggestedDecay:null,fixtureLumens:null};if(!i)return a;i.userData=i.userData||{};let o=null,s=null,c=null,l=null;if(t==null)delete i.userData.ies;else{let e=this.entries.find(e=>e.name===t);if(!e)return console.warn(`IESManager: unknown profile "${t}"`),a;l=Number.isFinite(e.lumens)?e.lumens:null,i.userData.ies={name:e.name,index:e.index,intensity:Go(n),fixtureLumens:l},r&&(Number.isFinite(e.suggestedAngle)&&(i.angle=e.suggestedAngle,o=e.suggestedAngle),Number.isFinite(e.suggestedPenumbra)&&(i.penumbra=e.suggestedPenumbra,s=e.suggestedPenumbra),i.decay=2,c=2)}return this.pathTracer.updateLights(),this._onReset?.(),{applied:!0,suggestedAngle:o,suggestedPenumbra:s,suggestedDecay:c,fixtureLumens:l}}getSpotLightProfile(e){return this._findSpotLight(e)?.userData?.ies||null}dispose(){this.texture?.dispose?.(),this.texture=null,this.entries=[],this.pathTracer=null,this._onReset=null}_findSpotLight(e){let t=this.pathTracer?.scene?.getObjectByProperty?.(`uuid`,e);return t&&t.isSpotLight?t:null}};function Go(e){return Math.max(0,Math.min(1,e))}var Q=e=>Math.min(Math.max(e,0),1);function Ko(e,t,n,r,i){i[0]=Q(e),i[1]=Q(t),i[2]=Q(n)}function qo(e,t,n,r,i){i[0]=Q(e*r),i[1]=Q(t*r),i[2]=Q(n*r)}function Jo(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 Yo(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 Xo(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 Zo(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 Qo(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 $o=new Map([[r.NoToneMapping,Ko],[r.LinearToneMapping,qo],[r.ReinhardToneMapping,Jo],[r.CineonToneMapping,Yo],[r.ACESFilmicToneMapping,Xo],[r.AgXToneMapping,Zo],[r.NeutralToneMapping,Qo]]),es=1/2.2;function ts(e){return e<=.0031308?12.92*e:1.055*e**(1/2.4)-.055}var ns=.2126,rs=.7152,is=.0722;function as(e,t){if(t===1)return;let n=e[0]*ns+e[1]*rs+e[2]*is;e[0]=n+(e[0]-n)*t,e[1]=n+(e[1]-n)*t,e[2]=n+(e[2]-n)*t}var os=null,ss=null;async function cs(){if(!os){let[e,t]=await Promise.all([import(`oidn-web`),import(`@tensorflow/tfjs-core`)]);os=e.initUNetFromURL,ss=t.engine}return os}function ls(){if(ss)try{let e=ss();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),us={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}},ds=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={...us.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 cs())(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}=Ya(),{QUALITY_MODELS:t}=us;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(us.QUALITY_MODELS,e))throw Error(`Invalid quality setting: ${e}. Must be one of: ${Object.keys(us.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=$o.get(this.getToneMapping())||$o.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,as($,l),a=$[0],o=$[1],c=$[2]),u(a,o,c,1,$),t.data[r]=ts($[0])*255+.5|0,t.data[r+1]=ts($[1])*255+.5|0,t.data[r+2]=ts($[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=$o.get(this.getToneMapping())||$o.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,as($,d),t=$[0],n=$[1],r=$[2]),f(t,n,r,1,$),l.data[e]=ts($[0])*255+.5|0,l.data[e+1]=ts($[1])*255+.5|0,l.data[e+2]=ts($[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(),ls(),this._destroyGPUInputBuffers(),this.output?.parentNode&&this.output.remove(),this.unet=null,this.ctx=null,this.state.abortController=null,this.removeAllListeners?.(),console.log(`OIDNDenoiser disposed`)}},fs=``+(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),ps={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 ms(){let{upscalerModelBaseUrl:e}=Ya(),t={};for(let n in ps){t[n]={};for(let r in ps[n])t[n][r]=e+ps[n][r]}return t}var hs={get QUALITY_PRESETS(){return ms()},TILE_SIZE:512,TILE_OVERLAP:16,SESSION_OPTIONS:{executionProviders:[{name:`webgpu`,preferredLayout:`NCHW`}],graphOptimizationLevel:`all`}},gs=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||hs.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=hs.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(fs,{type:`module`})}catch(e){if(e.name!==`SecurityError`)throw e;this._worker=await Ue(fs)}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}=Ya();this._worker.addEventListener(`message`,r),this._worker.postMessage({type:`load`,url:t,sessionOptions:hs.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=$o.get(this.getToneMapping())||$o.get(r.ACESFilmicToneMapping),this._hdrExposure=this.getExposure(),this._hdrSaturation=this.getSaturation(),this._tmOut=new Float32Array(3));let s=hs.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,as(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]**+es,l[c+d]=this._tmOut[1]**+es,l[2*c+d]=this._tmOut[2]**+es}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=$o.get(this.getToneMapping())||$o.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,as(d,u),r=d[0],i=d[1],a=d[2]),c(r,i,a,1,d),s[t]=d[0]**+es*255+.5|0,s[t+1]=d[1]**+es*255+.5|0,s[t+2]=d[2]**+es*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(!hs.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`)}},_s=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 ds(this.denoiserCanvas,this.renderer,this.scene,this.camera,{...H,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=H.enableOIDN,this._denoiserStartHandler=()=>this.dispatchEvent({type:B.DENOISING_START}),this._denoiserEndHandler=()=>this.dispatchEvent({type:B.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 gs(this.denoiserCanvas,this.renderer,{scaleFactor:H.upscalerScale||2,quality:H.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=H.enableUpscaler||!1,this._upscalerResChangedHandler=e=>this.dispatchEvent({type:`resolution_changed`,width:e.width,height:e.height}),this._upscalerStartHandler=()=>this.dispatchEvent({type:B.UPSCALING_START}),this._upscalerProgressHandler=e=>this.dispatchEvent({type:B.UPSCALING_PROGRESS,progress:e.progress}),this._upscalerEndHandler=()=>this.dispatchEvent({type:B.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?.setUniform(`adaptiveSamplingMin`,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:demodulated`,`asvgf:gradient`,`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),this._stages.bilateralFilter?.updateParameters(t),this._stages.variance&&t.varianceBoost!==void 0&&(this._stages.variance.varianceBoost.value=t.varianceBoost))}},vs=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}},ys=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}},bs=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 vs;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(B.RENDER_COMPLETE,()=>s.hide()),this._wireDenoiserTileEvents(s,r);let c=new ys(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)}},xs=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._clipsCache=null,this._savedTimeScale=1,this.onFinished=null,this.wakeCallback=null}init(e,t,n,i){if(this.dispose(),!i||i.length===0)return;this._scene=e,this._mixerRoot=t,this._meshes=n,this.mixer=new r.AnimationMixer(t);let a=i.map(e=>this.mixer.clipAction(e)),o=(e,t)=>e.name===t||e.getObjectByName(t)!==void 0;!a.some(e=>e.getClip().tracks.some(e=>{let n=e.name.split(`.`)[0];return o(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,a=i.map(e=>this.mixer.clipAction(e))),this.actions=a,this.mixer.addEventListener(`finished`,()=>{this.isPlaying=!1,this.timer.reset(),this.onFinished&&this.onFinished()}),this._meshTriRanges=[],this._skinnedCache=[];let s=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:s,count:i,uniqueVerts:a,indices:r}),this._skinnedCache.push(new Float32Array(a*3)),s+=i}this._posBuffer=new Float32Array(s*9);let c=n.filter(e=>e.isSkinnedMesh).length;console.debug(`[AnimationManager] Init: ${i.length} clips, ${n.length} meshes (${c} skinned), ${s} 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:B.ANIMATION_STARTED})}}pause(){this.mixer&&(this.mixer.timeScale=0,this.timer.reset(),this.isPlaying=!1,this.dispatchEvent({type:B.ANIMATION_PAUSED}))}resume(){this.mixer&&(this.mixer.timeScale=this._savedTimeScale||1,this.timer.reset(),this.isPlaying=!0,this.wakeCallback?.(),this.dispatchEvent({type:B.ANIMATION_STARTED}))}stop(){this.mixer&&(this.mixer.stopAllAction(),this.mixer.timeScale=this._savedTimeScale||1,this.timer.reset(),this.isPlaying=!1,this.dispatchEvent({type:B.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}},Ss=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){this._meshes=e,this._meshTriRanges=[],this._skinnedCache=[],this._normalCache=[];let t=0;for(let n of e){let e=n.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:t,count:a,uniqueVerts:o,indices:i}),this._skinnedCache.push(new Float32Array(o*3)),this._normalCache.push(new Float32Array(o*3)),t+=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:B.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:B.OBJECT_TRANSFORM_START}):(this._recomputeAndRefit(),this._app.dispatchEvent({type:B.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}},Cs=new WeakMap,ws=class extends r.EventDispatcher{constructor(e,t={}){super();try{Cs.get(e)?.dispose()}catch(e){console.warn(`PathTracerApp: prior canvas owner dispose failed`,e)}Cs.set(e,this),this.canvas=e,this._autoResize=t.autoResize!==!1,this._container=t.container||null,this.settings=new Ao(H),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.goboManager=null,this.iesManager=null,this.denoisingManager=null,this.overlayManager=null,this.interactionManager=null,this.transformManager=null,this.animationManager=new xs,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 wo,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:B.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(),de({timeElapsed:this.completion.timeElapsed,samples:fe(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:B.RENDER_COMPLETE}))}this._renderHelperOverlay(),this.dispatchEvent({type:B.FRAME})}}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:B.RENDER_RESET})}dispose(){if(!this._disposed){if(this._disposed=!0,this.dispatchEvent({type:B.DISPOSE}),this.stopAnimation(),clearTimeout(this._resizeDebounceTimer),this._resizeDebounceTimer=null,this._removeTrackedListeners(),le(null),this.interactionManager?.deselect?.(),this.transformManager?.detach?.(),this.animationManager?.dispose(),this.transformManager?.dispose(),this.overlayManager?.dispose(),this.lightManager?.dispose(),this.goboManager?.dispose(),this.iesManager?.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])ge(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 oa(`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)`),V({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`),V({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&&(V({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(),ue(),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?Me:Ne;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(le(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.outputColorSpace=t.SRGBColorSpace,this.renderer.toneMapping=r.ACESFilmicToneMapping,this.renderer.toneMappingExposure=1,this.renderer.setPixelRatio(1)}_initCameraManager(){this.cameraManager=new jo(this.canvas)}_initScenes(){this.scene=new r.Scene,this.meshScene=new r.Scene,this._sceneHelpers=new b}_initAssetPipeline(){this._sdf=new Ga,this.assetLoader=new Do(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 Co(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 To({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 Mo(this.scene,this._sceneHelpers,this.stages.pathTracer,{onReset:()=>this.reset()}),this.goboManager=new No(this.stages.pathTracer,{onReset:()=>this.reset()}),this.iesManager=new Wo(this.stages.pathTracer,{onReset:()=>this.reset()}),this._setupDenoisingManager(),this._setupOverlayManager(),this.transformManager=new Ss({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,B.AUTO_FOCUS_UPDATED,e=>this.dispatchEvent(e)),this._forwardEvents(this.denoisingManager,[B.DENOISING_START,B.DENOISING_END,B.UPSCALING_START,B.UPSCALING_PROGRESS,B.UPSCALING_END,`resolution_changed`]),this._setupAutoExposureListener(),this.animationManager.wakeCallback=()=>this.wake(),this._forwardEvents(this.animationManager,[B.ANIMATION_STARTED,B.ANIMATION_PAUSED,B.ANIMATION_STOPPED]),this._addTrackedListener(this.animationManager,B.ANIMATION_PAUSED,()=>{this._animRefitInFlight=!1}),this._addTrackedListener(this.animationManager,B.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),ue()}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.animationManager.onFinished=()=>{this._animRefitInFlight=!1,this.dispatchEvent({type:B.ANIMATION_FINISHED})}}this.transformManager?.setMeshData(this._sdf.meshes)}_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 Qa(this.renderer,{pathTracer:this.stages.pathTracer}),this.stages.motionVector=new $a(this.renderer,this.cameraManager.camera,{pathTracer:this.stages.pathTracer}),this.stages.ssrc=new yo(this.renderer,{enabled:!1}),this.stages.asvgf=new eo(this.renderer,{enabled:!1}),this.stages.variance=new no(this.renderer,{enabled:!1}),this.stages.bilateralFilter=new io(this.renderer,{enabled:!1}),this.stages.adaptiveSampling=new so(this.renderer,{adaptiveSamplingMax:e,enabled:t}),this.stages.edgeFilter=new co(this.renderer,{enabled:!1}),this.stages.autoExposure=new go(this.renderer,{enabled:H.autoExposure??!1}),this.stages.compositor=new bo(this.renderer,{saturation:this.settings.get(`saturation`)??H.saturation})}_setupDenoisingManager(){this.denoisingManager=new _s({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:B.RENDER_RESET}),this.wake())}_setupAutoExposureListener(){this.stages.autoExposure&&this.stages.autoExposure.on(`autoexposure:updated`,e=>{this.dispatchEvent({type:B.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 bs(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))}},Ts=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=Me.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:B.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:B.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&&(de({samples:fe(t)}),await new Promise(e=>setTimeout(e,0)))}_waitForDenoise(e){return new Promise(t=>{let n,r=()=>{e.removeEventListener(B.DENOISING_END,i),clearTimeout(n)},i=()=>{r(),t()};n=setTimeout(()=>{console.warn(`VideoRenderManager: Denoise timed out, skipping`),r(),t()},3e4),e.addEventListener(B.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=xs,e.BVH_LEAF_MARKERS=ke,e.CAMERA_PRESETS=Ee,e.CAMERA_RANGES=we,e.CameraManager=jo,e.DEFAULT_TEXTURE_MATRIX=je,e.DenoisingManager=_s,e.ENGINE_DEFAULTS=H,e.EngineEvents=B,e.GoboManager=No,e.IESManager=Wo,e.INTERACTIVE_RENDER_CONFIG=Ne,e.InteractionManager=To,e.LightManager=Mo,e.MEMORY_CONSTANTS=Pe,e.OverlayManager=bs,e.PRODUCTION_RENDER_CONFIG=Me,e.PathTracerApp=ws,e.PipelineContext=xo,e.RenderPipeline=Co,e.RenderSettings=Ao,e.RenderStage=z,e.SKY_PRESETS=Te,e.StageExecutionMode=R,e.TEXTURE_CONSTANTS=Ae,e.TRIANGLE_DATA_LAYOUT=U,e.TransformManager=Ss,e.VideoRenderManager=Ts,e.configureAssets=Ja,e.getAssetConfig=Ya});
716
+ `),_o=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)(uo,`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=Gt((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)(fo)).div((0,n.float)(po)).mul((0,n.float)(uo)).floor().clamp(0,(0,n.float)(uo-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)(ho)));(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)(uo,({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)(uo,({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)(fo).add((0,n.float)(t).add(.5).mul((0,n.float)(mo)));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=go(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 vo({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=an(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 yo({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),_=an(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 bo=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=vo({...e,writeCacheTex:this._cacheTexA,writePrevNDTex:this._prevNDTexA,framesSinceReset:this._framesSinceReset}),n=vo({...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=yo({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)}},xo=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,Bt)),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(`bilateralFiltering: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}},So=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={}}},Co=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):[]}},wo=class{constructor(e,t,n){this.renderer=e,this.width=t,this.height=n,this.stages=[],this.context=new So,this.eventBus=new Co,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()}},To=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}},Eo=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}},Z={STRING:`string`,NUMBER:`number`,WORD:`word`,LBRACKET:`[`,RBRACKET:`]`},Do=e=>e===` `||e===` `||e===`
717
+ `||e===`\r`||e===`\f`,Oo=e=>e>=`0`&&e<=`9`,ko=(e,t,n)=>!!(Oo(e)||e===`.`&&Oo(t)||(e===`-`||e===`+`)&&(Oo(t)||t===`.`&&Oo(n)));function Ao(e){let t=[],n=e.length,r=0;for(;r<n;){let i=e[r];if(Do(i)){r++;continue}if(i===`#`){for(;r<n&&e[r]!==`
718
+ `;)r++;continue}if(i===`[`){t.push({type:Z.LBRACKET}),r++;continue}if(i===`]`){t.push({type:Z.RBRACKET}),r++;continue}if(i===`"`){r++;let i=r;for(;r<n&&e[r]!==`"`;)r++;if(r>=n)throw Error(`PBRT tokenizer: unterminated string literal`);t.push({type:Z.STRING,value:e.slice(i,r)}),r++;continue}if(ko(i,e[r+1],e[r+2])){let i=r;for(r++;r<n;){let t=e[r];if(t>=`0`&&t<=`9`||t===`.`||t===`e`||t===`E`||t===`-`||t===`+`)r++;else break}let a=e.slice(i,r),o=Number(a);if(Number.isNaN(o))throw Error(`PBRT tokenizer: invalid number "${a}"`);t.push({type:Z.NUMBER,value:o});continue}{let i=r;for(;r<n&&!Do(e[r])&&e[r]!==`"`&&e[r]!==`[`&&e[r]!==`]`&&e[r]!==`#`;)r++;t.push({type:Z.WORD,value:e.slice(i,r)})}}return t}function jo(){return[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1]}function Mo(e,t){let n=e[0],r=e[1],i=e[2],a=e[3],o=e[4],s=e[5],c=e[6],l=e[7],u=e[8],d=e[9],f=e[10],p=e[11],m=e[12],h=e[13],g=e[14],_=e[15],v=t[0],y=t[1],b=t[2],x=t[3],S=t[4],C=t[5],w=t[6],T=t[7],E=t[8],D=t[9],O=t[10],k=t[11],A=t[12],j=t[13],M=t[14],N=t[15];return[n*v+o*y+u*b+m*x,r*v+s*y+d*b+h*x,i*v+c*y+f*b+g*x,a*v+l*y+p*b+_*x,n*S+o*C+u*w+m*T,r*S+s*C+d*w+h*T,i*S+c*C+f*w+g*T,a*S+l*C+p*w+_*T,n*E+o*D+u*O+m*k,r*E+s*D+d*O+h*k,i*E+c*D+f*O+g*k,a*E+l*D+p*O+_*k,n*A+o*j+u*M+m*N,r*A+s*j+d*M+h*N,i*A+c*j+f*M+g*N,a*A+l*j+p*M+_*N]}function No(e,t,n){return[1,0,0,0,0,1,0,0,0,0,1,0,e,t,n,1]}function Po(e,t,n){return[e,0,0,0,0,t,0,0,0,0,n,0,0,0,0,1]}function Fo(e,t,n,r){let i=Math.hypot(t,n,r)||1;t/=i,n/=i,r/=i;let a=e*Math.PI/180,o=Math.cos(a),s=Math.sin(a),c=1-o,l=c*t*t+o,u=c*t*n-s*r,d=c*t*r+s*n,f=c*t*n+s*r,p=c*n*n+o,m=c*n*r-s*t;return[l,f,c*t*r-s*n,0,u,p,c*n*r+s*t,0,d,m,c*r*r+o,0,0,0,0,1]}function Io(e,t){return[e[0]-t[0],e[1]-t[1],e[2]-t[2]]}function Lo(e,t){return[e[1]*t[2]-e[2]*t[1],e[2]*t[0]-e[0]*t[2],e[0]*t[1]-e[1]*t[0]]}function Ro(e){let t=Math.hypot(e[0],e[1],e[2])||1;return[e[0]/t,e[1]/t,e[2]/t]}function zo(e,t,n){let r=Ro(Io(t,e)),i=Ro(Lo(Ro(n),r)),a=Lo(r,i);return[i[0],i[1],i[2],0,a[0],a[1],a[2],0,r[0],r[1],r[2],0,e[0],e[1],e[2],1]}function Bo(e){let t=e[0],n=e[1],r=e[2],i=e[3],a=e[4],o=e[5],s=e[6],c=e[7],l=e[8],u=e[9],d=e[10],f=e[11],p=e[12],m=e[13],h=e[14],g=e[15],_=u*h*c-m*d*c+m*s*f-o*h*f-u*s*g+o*d*g,v=p*d*c-l*h*c-p*s*f+a*h*f+l*s*g-a*d*g,y=l*m*c-p*u*c+p*o*f-a*m*f-l*o*g+a*u*g,b=p*u*s-l*m*s-p*o*d+a*m*d+l*o*h-a*u*h,x=t*_+n*v+r*y+i*b;if(x===0)return jo();let S=1/x;return[_*S,(m*d*i-u*h*i-m*r*f+n*h*f+u*r*g-n*d*g)*S,(o*h*i-m*s*i+m*r*c-n*h*c-o*r*g+n*s*g)*S,(u*s*i-o*d*i-u*r*c+n*d*c+o*r*f-n*s*f)*S,v*S,(l*h*i-p*d*i+p*r*f-t*h*f-l*r*g+t*d*g)*S,(p*s*i-a*h*i-p*r*c+t*h*c+a*r*g-t*s*g)*S,(a*d*i-l*s*i+l*r*c-t*d*c-a*r*f+t*s*f)*S,y*S,(p*u*i-l*m*i-p*n*f+t*m*f+l*n*g-t*u*g)*S,(a*m*i-p*o*i+p*n*c-t*m*c-a*n*g+t*o*g)*S,(l*o*i-a*u*i-l*n*c+t*u*c+a*n*f-t*o*f)*S,b*S,(l*m*r-p*u*r+p*n*d-t*m*d-l*n*h+t*u*h)*S,(p*o*r-a*m*r-p*n*s+t*m*s+a*n*h-t*o*h)*S,(a*u*r-l*o*r+l*n*s-t*u*s-a*n*d+t*o*d)*S]}var Vo=class{constructor(e={}){this.resolveInclude=e.resolveInclude||(()=>{throw Error(`PBRTParser: Include used but no resolveInclude provided`)}),this.ir={film:null,camera:null,namedMaterials:new Map,namedTextures:new Map,shapes:[],lights:[],instances:[],objects:new Map,warnings:[]},this.ctm=jo(),this.state={material:null,areaLight:null,reverseOrientation:!1},this.attributeStack=[],this.transformStack=[],this.coordSystems=new Map,this.currentObject=null,this.objectBeginCTM=null,this.dirStack=[``],this.tokens=[],this.pos=0,this._warnedUnknown=new Set}parse(e,t=``){return this.dirStack=[t],this._run(Ao(e)),this.ir}_peek(){return this.tokens[this.pos]}_next(){return this.tokens[this.pos++]}_expectNumber(e){let t=this._next();if(!t||t.type!==Z.NUMBER)throw Error(`PBRT parser: expected number for ${e}, got ${t?t.value:`EOF`}`);return t.value}_expectString(e){let t=this._next();if(!t||t.type!==Z.STRING)throw Error(`PBRT parser: expected string for ${e}, got ${t?t.value:`EOF`}`);return t.value}_readNumbers(e){let t=[];for(let n=0;n<e;n++)t.push(this._expectNumber(`matrix/transform`));return t}_readBracketedOrBareNumbers(e){if(this._peek()&&this._peek().type===Z.LBRACKET){this._next();let e=[];for(;this._peek()&&this._peek().type!==Z.RBRACKET;)e.push(this._expectNumber(`transform element`));return this._next(),e}return this._readNumbers(e)}_parseParams(){let e={};for(;this._peek()&&this._peek().type===Z.STRING;){let t=this._next().value.trim().split(/\s+/),n=t[0],r=t[1]===void 0?t[0]:t[1];e[r]={type:n,value:this._parseParamValue()}}return e}_parseParamValue(){let e=[];if(this._peek()&&this._peek().type===Z.LBRACKET){for(this._next();this._peek()&&this._peek().type!==Z.RBRACKET;)e.push(this._coerceValueToken(this._next()));this._next()}else e.push(this._coerceValueToken(this._next()));return e}_coerceValueToken(e){if(!e)throw Error(`PBRT parser: unexpected EOF in parameter value`);if(e.type===Z.NUMBER||e.type===Z.STRING)return e.value;if(e.type===Z.WORD)return e.value===`true`?!0:e.value===`false`?!1:e.value;throw Error(`PBRT parser: unexpected token in parameter value: ${e.type}`)}_run(e){let t=this.tokens,n=this.pos;for(this.tokens=e,this.pos=0;this.pos<this.tokens.length;){let e=this._next();if(e.type!==Z.WORD)throw Error(`PBRT parser: expected directive, got ${e.type} ${e.value??``}`);this._directive(e.value)}this.tokens=t,this.pos=n}_directive(e){switch(e){case`Identity`:this.ctm=jo();break;case`Translate`:{let[e,t,n]=this._readNumbers(3);this.ctm=Mo(this.ctm,No(e,t,n));break}case`Scale`:{let[e,t,n]=this._readNumbers(3);this.ctm=Mo(this.ctm,Po(e,t,n));break}case`Rotate`:{let[e,t,n,r]=this._readNumbers(4);this.ctm=Mo(this.ctm,Fo(e,t,n,r));break}case`LookAt`:{let e=this._readNumbers(9),t=zo([e[0],e[1],e[2]],[e[3],e[4],e[5]],[e[6],e[7],e[8]]);this.ctm=Mo(this.ctm,Bo(t));break}case`Transform`:this.ctm=this._readBracketedOrBareNumbers(16);break;case`ConcatTransform`:{let e=this._readBracketedOrBareNumbers(16);this.ctm=Mo(this.ctm,e);break}case`CoordinateSystem`:this.coordSystems.set(this._expectString(`CoordinateSystem`),this.ctm.slice());break;case`CoordSysTransform`:{let e=this.coordSystems.get(this._expectString(`CoordSysTransform`));e&&(this.ctm=e.slice());break}case`Camera`:{let e=this._expectString(`Camera type`),t=this._parseParams();this.ir.camera={type:e,params:t,cameraToWorld:Bo(this.ctm)};break}case`Film`:{this._expectString(`Film type`);let e=this._parseParams();this.ir.film={xresolution:this._num(e.xresolution,1280),yresolution:this._num(e.yresolution,720),filename:this._str(e.filename,null)};break}case`Integrator`:case`Sampler`:case`PixelFilter`:case`Filter`:case`Accelerator`:case`ColorSpace`:case`Option`:this._skipTypeAndParams();break;case`WorldBegin`:this.ctm=jo(),this.state={material:null,areaLight:null,reverseOrientation:!1};break;case`WorldEnd`:break;case`AttributeBegin`:this.attributeStack.push({ctm:this.ctm.slice(),material:this.state.material,areaLight:this.state.areaLight,reverseOrientation:this.state.reverseOrientation});break;case`AttributeEnd`:{let e=this.attributeStack.pop();e&&(this.ctm=e.ctm,this.state={material:e.material,areaLight:e.areaLight,reverseOrientation:e.reverseOrientation});break}case`TransformBegin`:this.transformStack.push(this.ctm.slice());break;case`TransformEnd`:{let e=this.transformStack.pop();e&&(this.ctm=e);break}case`ReverseOrientation`:this.state.reverseOrientation=!this.state.reverseOrientation;break;case`Attribute`:this._expectString(`Attribute target`),this._parseParams();break;case`ActiveTransform`:this._next();break;case`TransformTimes`:this._readNumbers(2);break;case`MediumInterface`:this._peek()&&this._peek().type===Z.STRING&&this._next(),this._peek()&&this._peek().type===Z.STRING&&this._next();break;case`MakeNamedMedium`:this._skipNamedAndParams();break;case`Material`:{let e=this._expectString(`Material type`),t=this._parseParams();this.state.material={type:e,params:t};break}case`MakeNamedMaterial`:{let e=this._expectString(`MakeNamedMaterial name`),t=this._parseParams(),n=this._str(t.type,`diffuse`);this.ir.namedMaterials.set(e,{type:n,params:t});break}case`NamedMaterial`:{let e=this._expectString(`NamedMaterial name`),t=this.ir.namedMaterials.get(e);this.state.material=t||{type:`diffuse`,params:{},_missingRef:e},t||this._warn(`NamedMaterial "${e}" referenced before definition`);break}case`Texture`:{let e=this._expectString(`Texture name`),t=this._expectString(`Texture data type`),n=this._expectString(`Texture class`),r=this._parseParams();this.ir.namedTextures.set(e,{dataType:t,class:n,params:r});break}case`AreaLightSource`:{let e=this._expectString(`AreaLightSource type`),t=this._parseParams();this.state.areaLight={type:e,params:t};break}case`LightSource`:{let e=this._expectString(`LightSource type`),t=this._parseParams();this.ir.lights.push({type:e,params:t,ctm:this.ctm.slice()});break}case`Shape`:{let e={type:this._expectString(`Shape type`),params:this._parseParams(),ctm:this.ctm.slice(),material:this.state.material,areaLight:this.state.areaLight,reverseOrientation:this.state.reverseOrientation};this._emitShape(e);break}case`ObjectBegin`:{let e=this._expectString(`ObjectBegin name`);this.attributeStack.push({ctm:this.ctm.slice(),material:this.state.material,areaLight:this.state.areaLight,reverseOrientation:this.state.reverseOrientation}),this.currentObject=e,this.objectBeginCTM=this.ctm.slice(),this.ir.objects.has(e)||this.ir.objects.set(e,[]);break}case`ObjectEnd`:{this.currentObject=null,this.objectBeginCTM=null;let e=this.attributeStack.pop();e&&(this.ctm=e.ctm,this.state={material:e.material,areaLight:e.areaLight,reverseOrientation:e.reverseOrientation});break}case`ObjectInstance`:{let e=this._expectString(`ObjectInstance name`);this.ir.instances.push({name:e,ctm:this.ctm.slice()});break}case`Include`:case`Import`:{let t=this._expectString(e);this._include(t);break}default:this._warnUnknown(e),this._parseParams();break}}_emitShape(e){this.currentObject===null?this.ir.shapes.push(e):(e.relativeCTM=Mo(Bo(this.objectBeginCTM),e.ctm),this.ir.objects.get(this.currentObject).push(e))}_include(e){let t=this.resolveInclude(e,this.dirStack[this.dirStack.length-1]);if(t==null){this._warn(`Include target not found: ${e}`);return}let n=e.includes(`/`)?e.slice(0,e.lastIndexOf(`/`)):``;this.dirStack.push(n),this._run(Ao(t)),this.dirStack.pop()}_skipTypeAndParams(){this._peek()&&this._peek().type===Z.STRING&&this._next(),this._parseParams()}_skipNamedAndParams(){this._peek()&&this._peek().type===Z.STRING&&this._next(),this._parseParams()}_num(e,t){return e&&e.value.length?e.value[0]:t}_str(e,t){return e&&e.value.length?e.value[0]:t}_warn(e){this.ir.warnings.push(e)}_warnUnknown(e){this._warnedUnknown.has(e)||(this._warnedUnknown.add(e),this._warn(`Unsupported directive ignored: ${e}`))}},Ho={au:[1,.78,.34],gold:[1,.78,.34],cu:[.95,.64,.54],copper:[.95,.64,.54],ag:[.97,.96,.91],silver:[.97,.96,.91],al:[.91,.92,.92],aluminium:[.91,.92,.92],aluminum:[.91,.92,.92],mgo:[.9,.9,.9],tio2:[.9,.9,.9]},Uo=[.92,.92,.92];function Wo(e){let t=Math.max(1e3,Math.min(4e4,e))/100,n,r,i;t<=66?(n=255,r=99.47*Math.log(t)-161.12):(n=329.7*(t-60)**-.1332,r=288.12*(t-60)**-.0755),i=t>=66?255:t<=19?0:138.52*Math.log(t-10)-305.04;let a=e=>Math.max(0,Math.min(255,e))/255;return[a(n)**2.2,a(r)**2.2,a(i)**2.2]}function Go(e,t,n){let r=e[t];return r&&typeof r.value[0]==`number`?r.value[0]:n}function Ko(e,t,n){let r=e[t];return r&&typeof r.value[0]==`string`?r.value[0]:n}async function qo(e,t,n,r=null){let i=e[t];if(!i)return{rgb:r,texture:null};if(i.type===`texture`){let e=i.value[0],t=await n.resolveNamedTexture(e);return t&&t.texture?{rgb:t.constant??null,texture:t.texture}:t&&t.constant?{rgb:t.constant,texture:null}:(n.warn(`texture "${e}" could not be resolved`),{rgb:r,texture:null})}if(i.type===`rgb`||i.type===`color`)return{rgb:[i.value[0],i.value[1],i.value[2]],texture:null};if(i.type===`float`){let e=i.value[0];return{rgb:[e,e,e],texture:null}}if(i.type===`blackbody`)return{rgb:Wo(i.value[0]),texture:null};if(i.type===`spectrum`){if(typeof i.value[0]==`string`){let e=Jo(i.value[0]);return e&&Ho[e]?{rgb:Ho[e].slice(),texture:null}:(n.warn(`named spectrum "${i.value[0]}" approximated to gray`),{rgb:[.5,.5,.5],texture:null})}let e=0,t=0;for(let n=1;n<i.value.length;n+=2)e+=i.value[n],t++;let r=t?e/t:.5;return{rgb:[r,r,r],texture:null}}return{rgb:r,texture:null}}function Jo(e){let t=e.toLowerCase().match(/metal-([a-z]+)/);if(t)return t[1];for(let t of Object.keys(Ho))if(e.toLowerCase().includes(t))return t;return null}function Yo(e,t){if(e.roughness&&typeof e.roughness.value[0]==`number`)return e.roughness.value[0];let n=Go(e,`uroughness`,null),r=Go(e,`vroughness`,null);return n!==null&&r!==null?(n+r)/2:n===null?t:n}async function Xo(e,t){let n=e?.type||`diffuse`,i=e?.params||{},a=new r.MeshPhysicalMaterial({side:r.DoubleSide,roughness:1,metalness:0}),o=e=>{e&&a.color.setRGB(e[0],e[1],e[2])},s=e=>{o(e.rgb),e.texture&&(a.map=e.texture,e.rgb||a.color.setRGB(1,1,1))};switch(n){case`diffuse`:s(await qo(i,`reflectance`,t,[.5,.5,.5])),a.roughness=1,a.metalness=0;break;case`conductor`:case`metal`:{let e=await qo(i,`reflectance`,t,null),n=i.eta,r=i.k,c=n&&n.type===`spectrum`&&typeof n.value[0]==`string`;if(e.rgb||e.texture)s(e);else if(n&&r&&!c){let e=(await qo(i,`eta`,t,[.2,.92,1.1])).rgb,n=(await qo(i,`k`,t,[3.9,2.45,2.14])).rgb,r=(e,t)=>((e-1)**2+t**2)/((e+1)**2+t**2);o([r(e[0],n[0]),r(e[1],n[1]),r(e[2],n[2])])}else o(n?(await qo(i,`eta`,t,Uo)).rgb||Uo:Ho.cu);a.metalness=1,a.roughness=Yo(i,.1);break}case`dielectric`:case`thindielectric`:a.transmission=1,a.metalness=0,a.color.setRGB(1,1,1),a.ior=Go(i,`eta`,1.5),a.roughness=Yo(i,0),a.thickness=n===`thindielectric`?0:Go(i,`thickness`,0);break;case`coateddiffuse`:s(await qo(i,`reflectance`,t,[.5,.5,.5])),a.roughness=.6,a.metalness=0,a.clearcoat=1,a.clearcoatRoughness=Yo(i,0);break;case`diffusetransmission`:{let e=await qo(i,`transmittance`,t,[.25,.25,.25]);s(await qo(i,`reflectance`,t,[.25,.25,.25])),a.transmission=e.rgb?(e.rgb[0]+e.rgb[1]+e.rgb[2])/3:.5,a.roughness=1,a.ior=1;break}case`interface`:case`none`:case``:a.transmission=1,a.ior=1,a.roughness=0,a.color.setRGB(1,1,1);break;case`mix`:{let e=i.materials?.value||[],n=Math.max(0,Math.min(1,Go(i,`amount`,.5))),o=e[0]?t.namedMaterials?.get(e[0]):null,s=e[1]?t.namedMaterials?.get(e[1]):null;if(o&&s){let[e,r]=await Promise.all([Xo(o,t),Xo(s,t)]),i=(e,t)=>e*(1-n)+t*n;a.color.lerpColors(e.color,r.color,n),a.roughness=i(e.roughness,r.roughness),a.metalness=i(e.metalness,r.metalness),a.ior=i(e.ior??1.5,r.ior??1.5),a.transmission=i(e.transmission??0,r.transmission??0),a.thickness=i(e.thickness??0,r.thickness??0),a.clearcoat=i(e.clearcoat??0,r.clearcoat??0),a.clearcoatRoughness=i(e.clearcoatRoughness??0,r.clearcoatRoughness??0),a.emissive.lerpColors(e.emissive,r.emissive,n),a.emissiveIntensity=i(e.emissiveIntensity??0,r.emissiveIntensity??0),a.map=(n<.5?e.map:r.map)||null;break}t.warn(`material "mix" — could not resolve inner materials [${e.join(`, `)}], falling back to diffuse`),a.color.set(new r.Color(.6,.6,.6));break}case`subsurface`:case`hair`:case`measured`:t.warn(`material "${n}" not supported — using diffuse approximation`),o((await qo(i,`reflectance`,t,[.5,.5,.5])).rgb),a.roughness=1;break;default:t.warn(`unknown material "${n}" — using neutral diffuse`),a.color.set(new r.Color(.6,.6,.6));break}return a.roughness=Math.max(0,Math.min(1,a.roughness)),a}var Zo=[1,0,0,0,0,1,0,0,0,0,-1,0,0,0,0,1],Qo=class{constructor(e={}){this.resolvePLY=e.resolvePLY||(async()=>null),this.resolveImage=e.resolveImage||(async()=>null),this.resolveEnvironment=e.resolveEnvironment||e.resolveImage||(async()=>null),this.convertHandedness=e.convertHandedness===!0,this.warnings=[],this.report=[],this._materialCache=new Map,this._textureCache=new Map}warn(e){this.warnings.push(e)}async build(e){this.ir=e;let t=new r.Group;t.name=`PBRTScene`;for(let n=0;n<e.shapes.length;n++){let r=await this._buildShapeMesh(e.shapes[n],e.shapes[n].ctm,`shape_${n}`);r&&t.add(r)}await this._buildInstances(e,t);let n=null;e.camera&&(n=this._buildCamera(e.camera,e.film),n&&t.add(n));let i=await this._buildEnvironment(e.lights);return this._reportUnsupportedLights(e.lights),{group:t,camera:n,environment:i,report:this.report,warnings:this.warnings.concat(e.warnings||[])}}async _buildInstances(e,t){let n=0;for(let r of e.instances){let i=e.objects.get(r.name);if(!i){this.warn(`ObjectInstance "${r.name}" has no template`);continue}for(let e of i){let i=Mo(r.ctm,e.relativeCTM||e.ctm),a=await this._buildShapeMesh(e,i,`instance_${n++}`);a&&t.add(a)}}}async _buildShapeMesh(e,t,n){let[i,a]=await Promise.all([this._buildGeometry(e),this._getMaterial(e)]);if(!i)return null;let o=!!i.getAttribute(`uv`),s=a;a.map&&!o&&(this.warn(`${n} (${e.type}, "${e.material?.type||`diffuse`}") has a texture map but no UVs — dropping map, using base color`),s=a.clone(),s.map=null);let c=new r.Mesh(i,s);c.name=n;let l=this.convertHandedness?Mo(Zo,t):t;new r.Matrix4().fromArray(l).decompose(c.position,c.quaternion,c.scale),c.updateMatrix(),i.computeBoundingBox();let u=i.boundingBox?i.boundingBox.clone().applyMatrix4(c.matrix).getSize(new r.Vector3):new r.Vector3;return this.report.push({mesh:n,shape:e.type,material:e.material?.type||`diffuse`,color:`#`+s.color.getHexString(),map:s.map?`yes`:`-`,uv:o?`yes`:`NO`,normals:i.getAttribute(`normal`)?`yes`:`NO`,emissive:s.emissiveIntensity>0?`#${s.emissive.getHexString()}×${s.emissiveIntensity}`:`-`,size:`${u.x.toFixed(2)}×${u.y.toFixed(2)}×${u.z.toFixed(2)}`,tris:i.index?i.index.count/3:i.getAttribute(`position`).count/3}),c}async _buildGeometry(e){switch(e.type){case`trianglemesh`:return this._triangleMesh(e.params);case`bilinearmesh`:return this._bilinearMesh(e.params);case`plymesh`:return this._plyMesh(e.params);case`sphere`:return this._sphere(e.params);case`disk`:return this._disk(e.params);default:return this.warn(`shape "${e.type}" not supported — skipped`),null}}_triangleMesh(e){let t=e.P?.value;if(!t||t.length<9)return this.warn(`trianglemesh missing P`),null;let n=new r.BufferGeometry;n.setAttribute(`position`,new r.Float32BufferAttribute(Float32Array.from(t),3));let i=e.N?.value;i&&i.length===t.length&&n.setAttribute(`normal`,new r.Float32BufferAttribute(Float32Array.from(i),3));let a=(e.uv||e.st)?.value;a&&a.length===t.length/3*2&&n.setAttribute(`uv`,new r.Float32BufferAttribute(Float32Array.from(a),2));let o=e.indices?.value;return o&&o.length&&n.setIndex(o),i||n.computeVertexNormals(),n}_bilinearMesh(e){let t=e.P?.value,n=e.indices?.value;if(!t||!n)return this.warn(`bilinearmesh missing P/indices`),null;let i=[];for(let e=0;e+3<n.length;e+=4){let[t,r,a,o]=[n[e],n[e+1],n[e+2],n[e+3]];i.push(t,r,a,t,a,o)}let a=new r.BufferGeometry;return a.setAttribute(`position`,new r.Float32BufferAttribute(Float32Array.from(t),3)),a.setIndex(i),a.computeVertexNormals(),a}async _plyMesh(e){let t=Ko(e,`filename`,null);if(!t)return this.warn(`plymesh missing filename`),null;try{let e=await this.resolvePLY(t);return e?(e.getAttribute(`normal`)||e.computeVertexNormals(),e):(this.warn(`plymesh file not found: ${t}`),null)}catch(e){return this.warn(`failed to load plymesh ${t}: ${e.message}`),null}}_sphere(e){return new r.SphereGeometry(Go(e,`radius`,1),48,32)}_disk(e){let t=Go(e,`radius`,1),n=Go(e,`innerradius`,0),i=Go(e,`height`,0),a=[],o=[];for(let e=0;e<48;e++){let r=e/48*Math.PI*2,s=(e+1)/48*Math.PI*2,c=a.length/3;a.push(Math.cos(r)*n,Math.sin(r)*n,i),a.push(Math.cos(r)*t,Math.sin(r)*t,i),a.push(Math.cos(s)*t,Math.sin(s)*t,i),a.push(Math.cos(s)*n,Math.sin(s)*n,i),o.push(c,c+1,c+2,c,c+2,c+3)}let s=new r.BufferGeometry;return s.setAttribute(`position`,new r.Float32BufferAttribute(Float32Array.from(a),3)),s.setIndex(o),s.computeVertexNormals(),s}async _getMaterial(e){let t=this._materialCache.get(e.material);if(t||(t=new Map,this._materialCache.set(e.material,t)),t.has(e.areaLight))return t.get(e.areaLight);let n={resolveNamedTexture:e=>this._resolveNamedTexture(e),namedMaterials:this.ir.namedMaterials,warn:e=>this.warn(e)},r=await Xo(e.material,n);return e.areaLight&&await this._applyAreaLight(r,e.areaLight,n),t.set(e.areaLight,r),r}async _applyAreaLight(e,t,n){let r=await qo(t.params,`L`,n,[1,1,1]),i=Go(t.params,`scale`,1),a=r.rgb||[1,1,1];e.emissive.setRGB(a[0],a[1],a[2]),e.emissiveIntensity=i}async _resolveNamedTexture(e){if(this._textureCache.has(e))return this._textureCache.get(e);let t=this.ir.namedTextures.get(e),n=null;if(!t)this.warn(`named texture "${e}" not defined`);else if(t.class===`imagemap`){let r=Ko(t.params,`filename`,null);if(r)try{let t=await this.resolveImage(r);t?n={texture:t}:this.warn(`image not found for texture "${e}": ${r}`)}catch(t){this.warn(`failed to load texture "${e}" (${r}): ${t.message}`)}}else if(t.class===`constant`){let e=t.params.value;e&&e.type===`rgb`?n={constant:[e.value[0],e.value[1],e.value[2]]}:e&&(n={constant:[e.value[0],e.value[0],e.value[0]]})}else t.class===`scale`?n=await this._resolveScaleTexture(e,t):this.warn(`texture class "${t.class}" not supported (texture "${e}")`);return this._textureCache.set(e,n),n}async _resolveScaleTexture(e,t){let n=t.params.tex,r=null;if(n?.type===`texture`&&typeof n.value[0]==`string`)r=await this._resolveNamedTexture(n.value[0]);else if(n?.type===`rgb`||n?.type===`color`)r={constant:[n.value[0],n.value[1],n.value[2]]};else if(n?.type===`float`){let e=n.value[0];r={constant:[e,e,e]}}let i=t.params.scale,a=[1,1,1];if(i?.type===`rgb`||i?.type===`color`)a=[i.value[0],i.value[1],i.value[2]];else if(i?.type===`float`){let e=i.value[0];a=[e,e,e]}if(r?.texture){let e=r.constant||[1,1,1];return{texture:r.texture,constant:[e[0]*a[0],e[1]*a[1],e[2]*a[2]]}}let o=r?.constant||[1,1,1];return{constant:[o[0]*a[0],o[1]*a[1],o[2]*a[2]]}}_buildCamera(e,t){let n=new r.Matrix4().fromArray(e.cameraToWorld).elements,i=new r.Vector3(n[12],n[13],n[14]),a=new r.Vector3(n[8],n[9],n[10]),o=new r.Vector3(n[4],n[5],n[6]);this.convertHandedness&&(i.z*=-1,a.z*=-1,o.z*=-1);let s=i.clone().add(a),c=t&&t.yresolution?t.xresolution/t.yresolution:16/9,l=new r.PerspectiveCamera(this._verticalFov(e.params,c),c,.01,1e4);return l.name=`PBRT Camera`,l.up.copy(o.normalize()),l.position.copy(i),l.lookAt(s),l.updateMatrixWorld(!0),l}_verticalFov(e,t){let n=Go(e,`fov`,90);if(t>=1)return n;let r=n*Math.PI/180;return 2*Math.atan(Math.tan(r/2)/t)*180/Math.PI}async _buildEnvironment(e){let t=e.find(e=>e.type===`infinite`);if(!t)return null;let n=Go(t.params,`scale`,1),i=Ko(t.params,`filename`,null);if(i)try{let e=await this.resolveEnvironment(i);if(e)return e.mapping=r.EquirectangularReflectionMapping,{texture:e};this.warn(`infinite-light image not found: ${i}`)}catch(e){this.warn(`failed to load infinite-light image ${i}: ${e.message}`)}let a=((await qo(t.params,`L`,{resolveNamedTexture:async()=>null,warn:e=>this.warn(e)},[1,1,1])).rgb||[1,1,1]).map(e=>e*n),o=new Float32Array(8);for(let e=0;e<2;e++)o[e*4+0]=a[0],o[e*4+1]=a[1],o[e*4+2]=a[2],o[e*4+3]=1;let s=new r.DataTexture(o,2,1,r.RGBAFormat,r.FloatType);return s.mapping=r.EquirectangularReflectionMapping,s.minFilter=r.LinearFilter,s.magFilter=r.LinearFilter,s.needsUpdate=!0,{texture:s}}_reportUnsupportedLights(e){for(let t of e)t.type!==`infinite`&&this.warn(`light "${t.type}" not supported (only infinite lights and emissive area lights are mapped)`)}},$o=new TextDecoder;function es(e){let t=e.replace(/\\/g,`/`).split(`/`),n=[];for(let e of t)e===``||e===`.`||(e===`..`?n.pop():n.push(e));return n.join(`/`)}function ts(e,t){return!e||t.startsWith(`/`)?es(t):es(`${e}/${t}`)}var ns=class{constructor(e){this.byPath=new Map,this.byBase=new Map;for(let t in e){let n=es(t).toLowerCase(),r={norm:n,bytes:e[t]};this.byPath.set(n,r);let i=n.split(`/`).pop(),a=this.byBase.get(i);a?a.push(r):this.byBase.set(i,[r])}}find(e){let t=es(e).toLowerCase();if(this.byPath.has(t))return this.byPath.get(t).bytes;let n=this.byBase.get(t.split(`/`).pop());return n?(n.find(e=>e.norm.endsWith(`/`+t))||n[0]).bytes:null}};function rs(e){let t=Object.keys(e).filter(e=>e.toLowerCase().endsWith(`.pbrt`));if(t.length===0)return null;let n=t.filter(e=>/(^|\/)(scene|main)\.pbrt$/i.test(e)),r=n.length?n:t;return r.sort((e,t)=>{let n=e.split(`/`).length,r=t.split(`/`).length;return n===r?e.length-t.length:n-r}),r[0]}async function is(e){let{vfs:t,plyParser:n,imageFromBytes:r,envFromBytes:i,convertHandedness:a}=e,o=new ns(t),s=e.entryPath||rs(t);if(!s)throw Error(`PBRT loader: no .pbrt file found in archive`);let c=o.find(s);if(!c)throw Error(`PBRT loader: entry "${s}" not readable`);let l=s.includes(`/`)?s.slice(0,s.lastIndexOf(`/`)):``,u=new Vo({resolveInclude:(e,t)=>{let n=o.find(ts(t,e))||o.find(e);return n?$o.decode(n):null}}).parse($o.decode(c),l),d=e=>e.buffer.slice(e.byteOffset,e.byteOffset+e.byteLength);return{...await new Qo({convertHandedness:a,resolvePLY:async e=>{let t=o.find(e);return t?n(d(t)):null},resolveImage:async e=>{let t=o.find(e);return t?r(t,e):null},resolveEnvironment:async e=>{let t=o.find(e);return t?(i||r)(t,e):null}}).build(u),entryPath:s}}var as={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`}},os=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 as[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 rs(r)?await this.loadPBRTFromZip(r,t):await this.processObjMtlPairsInZip(r,t)||await this.findAndLoadModelFromZip(r,t)}catch(e){throw console.error(`Error loading ZIP archive:`,e),e}}async loadPBRTFromZip(e,t){if(B({isLoading:!0,status:`Parsing PBRT scene...`,progress:5}),!this.loaderCache.ply){let{PLYLoader:e}=await import(`three/examples/jsm/loaders/PLYLoader.js`);this.loaderCache.ply=new e}let{group:n,environment:r,report:i,warnings:a,entryPath:o}=await is({vfs:e,plyParser:e=>this.loaderCache.ply.parse(e),imageFromBytes:(e,t)=>this._pbrtTextureFromBytes(e,t),envFromBytes:async(e,t)=>{let n=t.split(`.`).pop().toLowerCase(),r=URL.createObjectURL(new Blob([e]));try{return await this.loadEnvironmentByExtension(r,n)}finally{URL.revokeObjectURL(r)}}});return i&&i.length&&typeof console.table==`function`&&(console.groupCollapsed(`PBRT loader: ${i.length} mesh(es) from "${o}"`),console.table(i),console.groupEnd()),a&&a.length&&(console.warn(`PBRT loader: ${a.length} warning(s) parsing "${o}"`),a.forEach(e=>console.warn(` •`,e))),r?.texture&&(r.texture.generateMipmaps=!0,this.applyEnvironmentToScene(r.texture)),n.name=o||t,this.releaseTargetModel(),this.targetModel=n,B({isLoading:!0,status:`Processing PBRT geometry...`,progress:10}),await this.onModelLoad(this.targetModel),this.dispatchEvent({type:`load`,model:n,filename:`${o} (from ZIP)`}),n}async _pbrtTextureFromBytes(e,t){let n=t.split(`.`).pop().toLowerCase(),i;if(n===`exr`||n===`hdr`){let t=n===`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));i=await this._loadViaObjectURL(t,e)}else if(n===`tga`){if(!this.loaderCache.tga){let{TGALoader:e}=await import(`three/examples/jsm/loaders/TGALoader.js`);this.loaderCache.tga=new e}i=await this._loadViaObjectURL(this.loaderCache.tga,e),i.colorSpace=r.SRGBColorSpace}else i=new r.Texture(await createImageBitmap(new Blob([e]))),i.colorSpace=r.SRGBColorSpace;return i.wrapS=i.wrapT=r.RepeatWrapping,i.needsUpdate=!0,i}async _loadViaObjectURL(e,t){let n=URL.createObjectURL(new Blob([t]));try{return await e.loadAsync(n)}finally{URL.revokeObjectURL(n)}}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(as[n]&&as[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}=Xa(),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 sa(`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(as))r.type===e&&(t[n]=r);return t}return as}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}},ss={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},groundProjectionEnabled:{uniform:`groundProjectionEnabled`,reset:!0},groundProjectionRadius:{uniform:`groundProjectionRadius`,reset:!0},groundProjectionHeight:{uniform:`groundProjectionHeight`,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`}},cs={bounces:`maxBounces`,adaptiveSampling:`useAdaptiveSampling`,debugMode:`visMode`},ls=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=ss[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=ss[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=ss[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(ss))t in e&&this._values.set(t,e[t]);for(let[t,n]of Object.entries(cs))t in e&&this._values.set(n,e[t])}},us=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=ke.SMOOTHING_FACTOR?`auto`:`manual`,this.afScreenPoint={x:.5,y:.5},this.afSmoothingFactor=ke.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=ke.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>ke.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>ke.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()}},ds=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(),this.sceneHelpers?.visible&&this.sceneHelpers.update()}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],n.distance=e.distance??0,n.penumbra=e.penumbra??0,n.decay=e.decay??2):e.type===`PointLight`&&(n.distance=e.distance??0,n.decay=e.decay??2);return(e.type===`SpotLight`||e.type===`DirectionalLight`)&&e.userData?.gobo&&(n.gobo=e.userData.gobo.name,n.goboIntensity=e.userData.gobo.intensity,n.goboInverted=!!e.userData.gobo.inverted,e.type===`DirectionalLight`&&(n.goboScale=e.userData.gobo.scale??5)),e.type===`SpotLight`&&e.userData?.ies&&(n.ies=e.userData.ies.name,n.iesIntensity=e.userData.ies.intensity??1,n.fixtureLumens=e.userData.ies.fixtureLumens??null),n}},fs=class{constructor(e,t={}){this.pathTracer=e,this._onReset=t.onReset||null,this.texture=null,this.entries=[],this._size=256}async loadLibrary(e,{size:t=256}={}){if(!Array.isArray(e)||e.length===0)return[];this._size=t;let n=await Promise.all(e.map(e=>ps(e.url))),i=t,a=t,o=n.length,s=new Uint8Array(i*a*o*4),c=document.createElement(`canvas`);c.width=i,c.height=a;let l=c.getContext(`2d`,{willReadFrequently:!0});for(let e=0;e<o;e++){l.clearRect(0,0,i,a),l.drawImage(n[e],0,0,i,a);let t=l.getImageData(0,0,i,a);s.set(t.data,e*i*a*4)}let u=new r.DataArrayTexture(s,i,a,o);u.minFilter=r.LinearFilter,u.magFilter=r.LinearFilter,u.format=r.RGBAFormat,u.type=r.UnsignedByteType,u.generateMipmaps=!1,u.needsUpdate=!0;let d=this.texture;return this.texture=u,this.entries=e.map((e,t)=>({name:e.name,index:t})),this.pathTracer.goboMaps=u,this.pathTracer.shaderBuilder?.updateGoboMaps?.(u),d?.dispose?.(),this.entries}getEntries(){return this.entries.slice()}setLightGobo(e,t,n={}){let{intensity:r=1,inverted:i=!1,scale:a=5}=n,o=this._findGoboLight(e);if(!o)return!1;if(o.userData=o.userData||{},t==null)delete o.userData.gobo;else{let e=this.entries.find(e=>e.name===t);if(!e)return console.warn(`GoboManager: unknown gobo "${t}"`),!1;o.userData.gobo={name:e.name,index:e.index,intensity:ms(r),inverted:!!i,scale:Math.max(1e-4,a)}}return this.pathTracer.updateLights(),this._onReset?.(),!0}setLightGoboInverted(e,t){let n=this._findGoboLight(e);return n?.userData?.gobo?(n.userData.gobo.inverted=!!t,this.pathTracer.updateLights(),this._onReset?.(),!0):!1}setLightGoboScale(e,t){let n=this._findGoboLight(e);return n?.userData?.gobo?(n.userData.gobo.scale=Math.max(1e-4,t),this.pathTracer.updateLights(),this._onReset?.(),!0):!1}getLightGobo(e){return this._findGoboLight(e)?.userData?.gobo||null}setSpotLightGobo(e,t,n=1,r=!1){return this.setLightGobo(e,t,{intensity:n,inverted:r})}setSpotLightGoboInverted(e,t){return this.setLightGoboInverted(e,t)}getSpotLightGobo(e){return this.getLightGobo(e)}dispose(){this.texture?.dispose?.(),this.texture=null,this.entries=[],this.pathTracer=null,this._onReset=null}_findGoboLight(e){let t=this.pathTracer?.scene?.getObjectByProperty?.(`uuid`,e);return t&&(t.isSpotLight||t.isDirectionalLight)?t:null}_findSpotLight(e){let t=this.pathTracer?.scene?.getObjectByProperty?.(`uuid`,e);return t&&t.isSpotLight?t:null}};function ps(e){return new Promise((t,n)=>{let r=new Image;r.crossOrigin=`anonymous`,r.onload=()=>t(r),r.onerror=()=>n(Error(`Failed to load gobo image: ${e}`)),r.src=e})}function ms(e){return Math.max(0,Math.min(1,e))}function hs(e,t=`ies`){let n=e.search(/TILT\s*=/i);if(n<0)throw Error(`IES (${t}): missing TILT line`);let r=e.indexOf(`
719
+ `,n);if(r<0)throw Error(`IES (${t}): truncated TILT line`);let i=e.slice(n,r).match(/TILT\s*=\s*(\w+)/i),a=i?i[1].toUpperCase():`NONE`,o=e.slice(r);if(a===`INCLUDE`){let e=ys(o),t=2+2*Number(e[1]);o=bs(o,t)}let s=ys(o),c=0,l=()=>Number(s[c++]),u=l(),d=l(),f=l(),p=l(),m=l(),h=l();l(),l(),l(),l();let g=l();if(l(),l(),!Number.isFinite(p)||p<=0)throw Error(`IES (${t}): invalid vertical angle count ${p}`);if(!Number.isFinite(m)||m<=0)throw Error(`IES (${t}): invalid horizontal angle count ${m}`);let _=Array(p);for(let e=0;e<p;e++)_[e]=l();let v=Array(m);for(let e=0;e<m;e++)v[e]=l();let y=Array(p);for(let e=0;e<p;e++)y[e]=new Float32Array(m);let b=f*g,x=0;for(let e=0;e<m;e++)for(let t=0;t<p;t++){let n=l()*b;y[t][e]=n,n>x&&(x=n)}return{verticalAngles:_,horizontalAngles:v,candela:y,maxCandela:x,lumens:d*u,photometricType:h,name:t}}function gs(e,t,n){let r=new Uint8Array(t*n),{verticalAngles:i,horizontalAngles:a,candela:o,maxCandela:s}=e;if(s<=0)return r;let c=i[i.length-1],l=a[a.length-1],u=a[0],d=a.length===1||l===u;for(let e=0;e<n;e++){let f=(e+.5)/n*c,p=xs(i,f),m=Math.min(p+1,i.length-1),h=i[m]-i[p],g=h>0?(f-i[p])/h:0;for(let n=0;n<t;n++){let i;if(d)i=Ss(o[p][0],o[m][0],g);else{let e=u+(n+.5)/t*(l-u),r=xs(a,e),s=Math.min(r+1,a.length-1),c=a[s]-a[r],d=c>0?(e-a[r])/c:0,f=o[p][r],h=o[p][s],_=o[m][r],v=o[m][s];i=Ss(Ss(f,h,d),Ss(_,v,d),g)}let c=Math.min(1,Math.max(0,i/s));r[e*t+n]=Math.round(c*255)}}return r}function _s(e,t=.1){let{verticalAngles:n,horizontalAngles:r,candela:i,maxCandela:a}=e,o=Math.PI/4;if(a<=0||!n?.length)return o;let s=a*t,c=r.length,l=n[n.length-1],u=!1;for(let e=0;e<n.length;e++){let t=0;for(let n=0;n<c;n++)t+=i[e][n];if(t/=c,t>=s&&(u=!0),u&&t<s){l=n[e];break}}let d=l*Math.PI/180;return Math.min(Math.max(d,5*Math.PI/180),89*Math.PI/180)}function vs(e,t,n=.7){let{verticalAngles:r,horizontalAngles:i,candela:a,maxCandela:o}=e;if(o<=0||!r?.length||t<=0)return 0;let s=o*n,c=i.length,l=0;for(let e=0;e<r.length;e++){let t=0;for(let n=0;n<c;n++)t+=a[e][n];if(t/=c,t>=s)l=r[e];else break}let u=t*180/Math.PI,d=u>0?1-l/u:0;return Math.min(Math.max(d,0),1)}function ys(e){return e.split(/\s+/).filter(e=>e.length>0)}function bs(e,t){let n=/\S+/g,r=0;for(;n.exec(e)!==null;)if(r++,r===t)return e.slice(n.lastIndex);return``}function xs(e,t){if(t<=e[0])return 0;if(t>=e[e.length-1])return e.length-1;let n=0,r=e.length-1;for(;r-n>1;){let i=n+r>>1;e[i]<=t?n=i:r=i}return n}function Ss(e,t,n){return e+(t-e)*n}var Cs=class{constructor(e,t={}){this.pathTracer=e,this._onReset=t.onReset||null,this.texture=null,this.entries=[],this._gridWidth=128,this._gridHeight=128}async loadLibrary(e,{gridWidth:t=128,gridHeight:n=128}={}){if(!Array.isArray(e)||e.length===0)return[];this._gridWidth=t,this._gridHeight=n;let i=(await Promise.all(e.map(async e=>{try{let r=await fetch(e.url);if(!r.ok)throw Error(`HTTP ${r.status}`);let i=hs(await r.text(),e.name);return{it:e,profile:i,grid:gs(i,t,n)}}catch(t){return console.warn(`IESManager: failed to load "${e.name}": ${t.message}`),null}}))).filter(e=>e!==null);if(i.length===0)return[];let a=i.length,o=t*n,s=new Uint8Array(o*4*a),c=[];for(let e=0;e<a;e++){let t=i[e].grid,n=e*o*4;for(let e=0;e<o;e++){let r=t[e];s[n+e*4+0]=r,s[n+e*4+1]=r,s[n+e*4+2]=r,s[n+e*4+3]=255}let r=i[e].profile,a=_s(r);c.push({name:i[e].it.name,index:e,maxCandela:r.maxCandela,photometricType:r.photometricType,suggestedAngle:a,suggestedPenumbra:vs(r,a),lumens:r.lumens})}let l=new r.DataArrayTexture(s,t,n,a);l.format=r.RGBAFormat,l.type=r.UnsignedByteType,l.minFilter=r.LinearFilter,l.magFilter=r.LinearFilter,l.generateMipmaps=!1,l.needsUpdate=!0;let u=this.texture;return this.texture=l,this.entries=c,this.pathTracer.iesProfiles=l,this.pathTracer.shaderBuilder?.updateIESProfiles?.(l),u?.dispose?.(),this.entries.map(({name:e,index:t})=>({name:e,index:t}))}getEntries(){return this.entries.slice()}setSpotLightProfile(e,t,n=1,{applyAutoCone:r=!0}={}){let i=this._findSpotLight(e),a={applied:!1,suggestedAngle:null,suggestedPenumbra:null,suggestedDecay:null,fixtureLumens:null};if(!i)return a;i.userData=i.userData||{};let o=null,s=null,c=null,l=null;if(t==null)delete i.userData.ies;else{let e=this.entries.find(e=>e.name===t);if(!e)return console.warn(`IESManager: unknown profile "${t}"`),a;l=Number.isFinite(e.lumens)?e.lumens:null,i.userData.ies={name:e.name,index:e.index,intensity:ws(n),fixtureLumens:l},r&&(Number.isFinite(e.suggestedAngle)&&(i.angle=e.suggestedAngle,o=e.suggestedAngle),Number.isFinite(e.suggestedPenumbra)&&(i.penumbra=e.suggestedPenumbra,s=e.suggestedPenumbra),i.decay=2,c=2)}return this.pathTracer.updateLights(),this._onReset?.(),{applied:!0,suggestedAngle:o,suggestedPenumbra:s,suggestedDecay:c,fixtureLumens:l}}getSpotLightProfile(e){return this._findSpotLight(e)?.userData?.ies||null}dispose(){this.texture?.dispose?.(),this.texture=null,this.entries=[],this.pathTracer=null,this._onReset=null}_findSpotLight(e){let t=this.pathTracer?.scene?.getObjectByProperty?.(`uuid`,e);return t&&t.isSpotLight?t:null}};function ws(e){return Math.max(0,Math.min(1,e))}var Q=e=>Math.min(Math.max(e,0),1);function Ts(e,t,n,r,i){i[0]=Q(e),i[1]=Q(t),i[2]=Q(n)}function Es(e,t,n,r,i){i[0]=Q(e*r),i[1]=Q(t*r),i[2]=Q(n*r)}function Ds(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 Os(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 ks(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 As(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 js(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 Ms=new Map([[r.NoToneMapping,Ts],[r.LinearToneMapping,Es],[r.ReinhardToneMapping,Ds],[r.CineonToneMapping,Os],[r.ACESFilmicToneMapping,ks],[r.AgXToneMapping,As],[r.NeutralToneMapping,js]]),Ns=1/2.2;function Ps(e){return e<=.0031308?12.92*e:1.055*e**(1/2.4)-.055}var Fs=.2126,Is=.7152,Ls=.0722;function Rs(e,t){if(t===1)return;let n=e[0]*Fs+e[1]*Is+e[2]*Ls;e[0]=n+(e[0]-n)*t,e[1]=n+(e[1]-n)*t,e[2]=n+(e[2]-n)*t}var zs=null,Bs=null;async function Vs(){if(!zs){let[e,t]=await Promise.all([import(`oidn-web`),import(`@tensorflow/tfjs-core`)]);zs=e.initUNetFromURL,Bs=t.engine}return zs}function Hs(){if(Bs)try{let e=Bs();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),Us={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}},Ws=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={...Us.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 Vs())(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}=Xa(),{QUALITY_MODELS:t}=Us;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(Us.QUALITY_MODELS,e))throw Error(`Invalid quality setting: ${e}. Must be one of: ${Object.keys(Us.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=Ms.get(this.getToneMapping())||Ms.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,Rs($,l),a=$[0],o=$[1],c=$[2]),u(a,o,c,1,$),t.data[r]=Ps($[0])*255+.5|0,t.data[r+1]=Ps($[1])*255+.5|0,t.data[r+2]=Ps($[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=Ms.get(this.getToneMapping())||Ms.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,Rs($,d),t=$[0],n=$[1],r=$[2]),f(t,n,r,1,$),l.data[e]=Ps($[0])*255+.5|0,l.data[e+1]=Ps($[1])*255+.5|0,l.data[e+2]=Ps($[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(),Hs(),this._destroyGPUInputBuffers(),this.output?.parentNode&&this.output.remove(),this.unet=null,this.ctx=null,this.state.abortController=null,this.removeAllListeners?.(),console.log(`OIDNDenoiser disposed`)}},Gs=``+(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),Ks={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 qs(){let{upscalerModelBaseUrl:e}=Xa(),t={};for(let n in Ks){t[n]={};for(let r in Ks[n])t[n][r]=e+Ks[n][r]}return t}var Js={get QUALITY_PRESETS(){return qs()},TILE_SIZE:512,TILE_OVERLAP:16,SESSION_OPTIONS:{executionProviders:[{name:`webgpu`,preferredLayout:`NCHW`}],graphOptimizationLevel:`all`}},Ys=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||Js.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=Js.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(Gs,{type:`module`})}catch(e){if(e.name!==`SecurityError`)throw e;this._worker=await We(Gs)}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}=Xa();this._worker.addEventListener(`message`,r),this._worker.postMessage({type:`load`,url:t,sessionOptions:Js.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=Ms.get(this.getToneMapping())||Ms.get(r.ACESFilmicToneMapping),this._hdrExposure=this.getExposure(),this._hdrSaturation=this.getSaturation(),this._tmOut=new Float32Array(3));let s=Js.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,Rs(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]**+Ns,l[c+d]=this._tmOut[1]**+Ns,l[2*c+d]=this._tmOut[2]**+Ns}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=Ms.get(this.getToneMapping())||Ms.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,Rs(d,u),r=d[0],i=d[1],a=d[2]),c(r,i,a,1,d),s[t]=d[0]**+Ns*255+.5|0,s[t+1]=d[1]**+Ns*255+.5|0,s[t+2]=d[2]**+Ns*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(!Js.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`)}},Xs=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 Ws(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 Ys(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?.setUniform(`adaptiveSamplingMin`,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:demodulated`,`asvgf:gradient`,`variance:output`,`bilateralFiltering:output`,`edgeFiltering:output`,`ssrc:output`].forEach(t=>e.removeTexture(t))}_applyASVGFPreset(e){let t=we[e];t&&(this._stages.asvgf?.updateParameters(t),this._stages.bilateralFilter?.updateParameters(t),this._stages.variance&&t.varianceBoost!==void 0&&(this._stages.variance.varianceBoost.value=t.varianceBoost))}},Zs=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}},Qs=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}},$s=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 Zs;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 Qs(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)}},ec=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._clipsCache=null,this._savedTimeScale=1,this.onFinished=null,this.wakeCallback=null}init(e,t,n,i){if(this.dispose(),!i||i.length===0)return;this._scene=e,this._mixerRoot=t,this._meshes=n,this.mixer=new r.AnimationMixer(t);let a=i.map(e=>this.mixer.clipAction(e)),o=(e,t)=>e.name===t||e.getObjectByName(t)!==void 0;!a.some(e=>e.getClip().tracks.some(e=>{let n=e.name.split(`.`)[0];return o(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,a=i.map(e=>this.mixer.clipAction(e))),this.actions=a,this.mixer.addEventListener(`finished`,()=>{this.isPlaying=!1,this.timer.reset(),this.onFinished&&this.onFinished()}),this._meshTriRanges=[],this._skinnedCache=[];let s=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:s,count:i,uniqueVerts:a,indices:r}),this._skinnedCache.push(new Float32Array(a*3)),s+=i}this._posBuffer=new Float32Array(s*9);let c=n.filter(e=>e.isSkinnedMesh).length;console.debug(`[AnimationManager] Init: ${i.length} clips, ${n.length} meshes (${c} skinned), ${s} 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}},tc=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){this._meshes=e,this._meshTriRanges=[],this._skinnedCache=[],this._normalCache=[];let t=0;for(let n of e){let e=n.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:t,count:a,uniqueVerts:o,indices:i}),this._skinnedCache.push(new Float32Array(o*3)),this._normalCache.push(new Float32Array(o*3)),t+=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}},nc=new WeakMap,rc=class extends r.EventDispatcher{constructor(e,t={}){super();try{nc.get(e)?.dispose()}catch(e){console.warn(`PathTracerApp: prior canvas owner dispose failed`,e)}nc.set(e,this),this.canvas=e,this._autoResize=t.autoResize!==!1,this._container=t.container||null,this.settings=new ls(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.goboManager=null,this.iesManager=null,this.denoisingManager=null,this.overlayManager=null,this.interactionManager=null,this.transformManager=null,this.animationManager=new ec,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 To,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})}}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.goboManager?.dispose(),this.iesManager?.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 sa(`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?Ne:Pe;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.outputColorSpace=t.SRGBColorSpace,this.renderer.toneMapping=r.ACESFilmicToneMapping,this.renderer.toneMappingExposure=1,this.renderer.setPixelRatio(1)}_initCameraManager(){this.cameraManager=new us(this.canvas)}_initScenes(){this.scene=new r.Scene,this.meshScene=new r.Scene,this._sceneHelpers=new b}_initAssetPipeline(){this._sdf=new Ka,this.assetLoader=new os(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 wo(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 Eo({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 ds(this.scene,this._sceneHelpers,this.stages.pathTracer,{onReset:()=>this.reset()}),this.goboManager=new fs(this.stages.pathTracer,{onReset:()=>this.reset()}),this.iesManager=new Cs(this.stages.pathTracer,{onReset:()=>this.reset()}),this._setupDenoisingManager(),this._setupOverlayManager(),this.transformManager=new tc({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.animationManager.onFinished=()=>{this._animRefitInFlight=!1,this.dispatchEvent({type:z.ANIMATION_FINISHED})}}this.transformManager?.setMeshData(this._sdf.meshes)}_createStages(){let e=this.settings.get(`adaptiveSamplingMax`),t=this.settings.get(`useAdaptiveSampling`);this.stages.pathTracer=new Qa(this.renderer,this.scene,this.cameraManager.camera),this.stages.normalDepth=new $a(this.renderer,{pathTracer:this.stages.pathTracer}),this.stages.motionVector=new eo(this.renderer,this.cameraManager.camera,{pathTracer:this.stages.pathTracer}),this.stages.ssrc=new bo(this.renderer,{enabled:!1}),this.stages.asvgf=new to(this.renderer,{enabled:!1}),this.stages.variance=new ro(this.renderer,{enabled:!1}),this.stages.bilateralFilter=new ao(this.renderer,{enabled:!1}),this.stages.adaptiveSampling=new co(this.renderer,{adaptiveSamplingMax:e,enabled:t}),this.stages.edgeFilter=new lo(this.renderer,{enabled:!1}),this.stages.autoExposure=new _o(this.renderer,{enabled:V.autoExposure??!1}),this.stages.compositor=new xo(this.renderer,{saturation:this.settings.get(`saturation`)??V.saturation})}_setupDenoisingManager(){this.denoisingManager=new Xs({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 $s(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))}},ic=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=Ne.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=ke,e.ASVGF_QUALITY_PRESETS=we,e.AUTO_FOCUS_MODES=Oe,e.AnimationManager=ec,e.BVH_LEAF_MARKERS=Ae,e.CAMERA_PRESETS=De,e.CAMERA_RANGES=Te,e.CameraManager=us,e.DEFAULT_TEXTURE_MATRIX=Me,e.DenoisingManager=Xs,e.ENGINE_DEFAULTS=V,e.EngineEvents=z,e.GoboManager=fs,e.IESManager=Cs,e.INTERACTIVE_RENDER_CONFIG=Pe,e.InteractionManager=Eo,e.LightManager=ds,e.MEMORY_CONSTANTS=Fe,e.OverlayManager=$s,e.PRODUCTION_RENDER_CONFIG=Ne,e.PathTracerApp=rc,e.PipelineContext=So,e.RenderPipeline=wo,e.RenderSettings=ls,e.RenderStage=R,e.SKY_PRESETS=Ee,e.StageExecutionMode=L,e.TEXTURE_CONSTANTS=je,e.TRIANGLE_DATA_LAYOUT=H,e.TransformManager=tc,e.VideoRenderManager=ic,e.configureAssets=Ya,e.getAssetConfig=Xa});
718
720
  //# sourceMappingURL=rayzee.umd.js.map