/** * @license * Copyright 2010-2025 Three.js Authors * SPDX-License-Identifier: MIT */ import{Color as e,Vector2 as t,Vector3 as r,Vector4 as s,Matrix2 as i,Matrix3 as n,Matrix4 as a,EventDispatcher as o,MathUtils as u,WebGLCoordinateSystem as l,WebGPUCoordinateSystem as d,ColorManagement as c,SRGBTransfer as h,NoToneMapping as p,StaticDrawUsage as g,InterleavedBuffer as m,InterleavedBufferAttribute as f,DynamicDrawUsage as y,NoColorSpace as b,Texture as x,UnsignedIntType as T,IntType as _,NearestFilter as v,Sphere as N,BackSide as S,DoubleSide as E,Euler as w,CubeTexture as A,CubeReflectionMapping as R,CubeRefractionMapping as C,TangentSpaceNormalMap as M,ObjectSpaceNormalMap as P,InstancedInterleavedBuffer as B,InstancedBufferAttribute as F,DataArrayTexture as L,FloatType as I,FramebufferTexture as D,LinearMipmapLinearFilter as V,DepthTexture as U,Material as O,NormalBlending as k,LineBasicMaterial as G,LineDashedMaterial as z,NoBlending as H,MeshNormalMaterial as $,SRGBColorSpace as W,WebGLCubeRenderTarget as j,BoxGeometry as q,Mesh as X,Scene as K,LinearFilter as Y,CubeCamera as Q,EquirectangularReflectionMapping as Z,EquirectangularRefractionMapping as J,AddOperation as ee,MixOperation as te,MultiplyOperation as re,MeshBasicMaterial as se,MeshLambertMaterial as ie,MeshPhongMaterial as ne,OrthographicCamera as ae,PerspectiveCamera as oe,RenderTarget as ue,LinearSRGBColorSpace as le,RGBAFormat as de,HalfFloatType as ce,CubeUVReflectionMapping as he,BufferGeometry as pe,BufferAttribute as ge,MeshStandardMaterial as me,MeshPhysicalMaterial as fe,MeshToonMaterial as ye,MeshMatcapMaterial as be,SpriteMaterial as xe,PointsMaterial as Te,ShadowMaterial as _e,Uint32BufferAttribute as ve,Uint16BufferAttribute as Ne,arrayNeedsUint32 as Se,Camera as Ee,DepthStencilFormat as we,DepthFormat as Ae,UnsignedInt248Type as Re,UnsignedByteType as Ce,Plane as Me,Object3D as Pe,LinearMipMapLinearFilter as Be,Float32BufferAttribute as Fe,UVMapping as Le,VSMShadowMap as Ie,LessCompare as De,RGFormat as Ve,BasicShadowMap as Ue,SphereGeometry as Oe,LinearMipmapNearestFilter as ke,NearestMipmapLinearFilter as Ge,Float16BufferAttribute as ze,REVISION as He,ArrayCamera as $e,PlaneGeometry as We,FrontSide as je,CustomBlending as qe,AddEquation as Xe,ZeroFactor as Ke,CylinderGeometry as Ye,Quaternion as Qe,WebXRController as Ze,RAD2DEG as Je,PCFShadowMap as et,FrustumArray as tt,Frustum as rt,DataTexture as st,RedIntegerFormat as it,RedFormat as nt,ShortType as at,ByteType as ot,UnsignedShortType as ut,RGIntegerFormat as lt,RGBIntegerFormat as dt,RGBFormat as ct,RGBAIntegerFormat as ht,warnOnce as pt,createCanvasElement as gt,ReverseSubtractEquation as mt,SubtractEquation as ft,OneMinusDstAlphaFactor as yt,OneMinusDstColorFactor as bt,OneMinusSrcAlphaFactor as xt,OneMinusSrcColorFactor as Tt,DstAlphaFactor as _t,DstColorFactor as vt,SrcAlphaSaturateFactor as Nt,SrcAlphaFactor as St,SrcColorFactor as Et,OneFactor as wt,CullFaceNone as At,CullFaceBack as Rt,CullFaceFront as Ct,MultiplyBlending as Mt,SubtractiveBlending as Pt,AdditiveBlending as Bt,NotEqualDepth as Ft,GreaterDepth as Lt,GreaterEqualDepth as It,EqualDepth as Dt,LessEqualDepth as Vt,LessDepth as Ut,AlwaysDepth as Ot,NeverDepth as kt,UnsignedShort4444Type as Gt,UnsignedShort5551Type as zt,UnsignedInt5999Type as Ht,UnsignedInt101111Type as $t,AlphaFormat as Wt,RGB_S3TC_DXT1_Format as jt,RGBA_S3TC_DXT1_Format as qt,RGBA_S3TC_DXT3_Format as Xt,RGBA_S3TC_DXT5_Format as Kt,RGB_PVRTC_4BPPV1_Format as Yt,RGB_PVRTC_2BPPV1_Format as Qt,RGBA_PVRTC_4BPPV1_Format as Zt,RGBA_PVRTC_2BPPV1_Format as Jt,RGB_ETC1_Format as er,RGB_ETC2_Format as tr,RGBA_ETC2_EAC_Format as rr,RGBA_ASTC_4x4_Format as sr,RGBA_ASTC_5x4_Format as ir,RGBA_ASTC_5x5_Format as nr,RGBA_ASTC_6x5_Format as ar,RGBA_ASTC_6x6_Format as or,RGBA_ASTC_8x5_Format as ur,RGBA_ASTC_8x6_Format as lr,RGBA_ASTC_8x8_Format as dr,RGBA_ASTC_10x5_Format as cr,RGBA_ASTC_10x6_Format as hr,RGBA_ASTC_10x8_Format as pr,RGBA_ASTC_10x10_Format as gr,RGBA_ASTC_12x10_Format as mr,RGBA_ASTC_12x12_Format as fr,RGBA_BPTC_Format as yr,RED_RGTC1_Format as br,SIGNED_RED_RGTC1_Format as xr,RED_GREEN_RGTC2_Format as Tr,SIGNED_RED_GREEN_RGTC2_Format as _r,MirroredRepeatWrapping as vr,ClampToEdgeWrapping as Nr,RepeatWrapping as Sr,NearestMipmapNearestFilter as Er,NotEqualCompare as wr,GreaterCompare as Ar,GreaterEqualCompare as Rr,EqualCompare as Cr,LessEqualCompare as Mr,AlwaysCompare as Pr,NeverCompare as Br,LinearTransfer as Fr,getByteLength as Lr,NotEqualStencilFunc as Ir,GreaterStencilFunc as Dr,GreaterEqualStencilFunc as Vr,EqualStencilFunc as Ur,LessEqualStencilFunc as Or,LessStencilFunc as kr,AlwaysStencilFunc as Gr,NeverStencilFunc as zr,DecrementWrapStencilOp as Hr,IncrementWrapStencilOp as $r,DecrementStencilOp as Wr,IncrementStencilOp as jr,InvertStencilOp as qr,ReplaceStencilOp as Xr,ZeroStencilOp as Kr,KeepStencilOp as Yr,MaxEquation as Qr,MinEquation as Zr,SpotLight as Jr,PointLight as es,DirectionalLight as ts,RectAreaLight as rs,AmbientLight as ss,HemisphereLight as is,LightProbe as ns,LinearToneMapping as as,ReinhardToneMapping as os,CineonToneMapping as us,ACESFilmicToneMapping as ls,AgXToneMapping as ds,NeutralToneMapping as cs,Group as hs,Loader as ps,FileLoader as gs,MaterialLoader as ms,ObjectLoader as fs}from"./three.core.min.js";export{AdditiveAnimationBlendMode,AnimationAction,AnimationClip,AnimationLoader,AnimationMixer,AnimationObjectGroup,AnimationUtils,ArcCurve,ArrowHelper,AttachedBindMode,Audio,AudioAnalyser,AudioContext,AudioListener,AudioLoader,AxesHelper,BasicDepthPacking,BatchedMesh,Bone,BooleanKeyframeTrack,Box2,Box3,Box3Helper,BoxHelper,BufferGeometryLoader,Cache,CameraHelper,CanvasTexture,CapsuleGeometry,CatmullRomCurve3,CircleGeometry,Clock,ColorKeyframeTrack,CompressedArrayTexture,CompressedCubeTexture,CompressedTexture,CompressedTextureLoader,ConeGeometry,ConstantAlphaFactor,ConstantColorFactor,Controls,CubeTextureLoader,CubicBezierCurve,CubicBezierCurve3,CubicInterpolant,CullFaceFrontBack,Curve,CurvePath,CustomToneMapping,Cylindrical,Data3DTexture,DataTextureLoader,DataUtils,DefaultLoadingManager,DetachedBindMode,DirectionalLightHelper,DiscreteInterpolant,DodecahedronGeometry,DynamicCopyUsage,DynamicReadUsage,EdgesGeometry,EllipseCurve,ExtrudeGeometry,Fog,FogExp2,GLBufferAttribute,GLSL1,GLSL3,GridHelper,HemisphereLightHelper,IcosahedronGeometry,ImageBitmapLoader,ImageLoader,ImageUtils,InstancedBufferGeometry,InstancedMesh,Int16BufferAttribute,Int32BufferAttribute,Int8BufferAttribute,Interpolant,InterpolateDiscrete,InterpolateLinear,InterpolateSmooth,InterpolationSamplingMode,InterpolationSamplingType,KeyframeTrack,LOD,LatheGeometry,Layers,Light,Line,Line3,LineCurve,LineCurve3,LineLoop,LineSegments,LinearInterpolant,LinearMipMapNearestFilter,LoaderUtils,LoadingManager,LoopOnce,LoopPingPong,LoopRepeat,MOUSE,MeshDepthMaterial,MeshDistanceMaterial,NearestMipMapLinearFilter,NearestMipMapNearestFilter,NormalAnimationBlendMode,NumberKeyframeTrack,OctahedronGeometry,OneMinusConstantAlphaFactor,OneMinusConstantColorFactor,PCFSoftShadowMap,Path,PlaneHelper,PointLightHelper,Points,PolarGridHelper,PolyhedronGeometry,PositionalAudio,PropertyBinding,PropertyMixer,QuadraticBezierCurve,QuadraticBezierCurve3,QuaternionKeyframeTrack,QuaternionLinearInterpolant,RGBADepthPacking,RGBDepthPacking,RGB_BPTC_SIGNED_Format,RGB_BPTC_UNSIGNED_Format,RGDepthPacking,RawShaderMaterial,Ray,Raycaster,RenderTarget3D,RingGeometry,ShaderMaterial,Shape,ShapeGeometry,ShapePath,ShapeUtils,Skeleton,SkeletonHelper,SkinnedMesh,Source,Spherical,SphericalHarmonics3,SplineCurve,SpotLightHelper,Sprite,StaticCopyUsage,StaticReadUsage,StereoCamera,StreamCopyUsage,StreamDrawUsage,StreamReadUsage,StringKeyframeTrack,TOUCH,TetrahedronGeometry,TextureLoader,TextureUtils,Timer,TimestampQuery,TorusGeometry,TorusKnotGeometry,Triangle,TriangleFanDrawMode,TriangleStripDrawMode,TrianglesDrawMode,TubeGeometry,Uint8BufferAttribute,Uint8ClampedBufferAttribute,Uniform,UniformsGroup,VectorKeyframeTrack,VideoFrameTexture,VideoTexture,WebGL3DRenderTarget,WebGLArrayRenderTarget,WebGLRenderTarget,WireframeGeometry,WrapAroundEnding,ZeroCurvatureEnding,ZeroSlopeEnding}from"./three.core.min.js";const ys=["alphaMap","alphaTest","anisotropy","anisotropyMap","anisotropyRotation","aoMap","aoMapIntensity","attenuationColor","attenuationDistance","bumpMap","clearcoat","clearcoatMap","clearcoatNormalMap","clearcoatNormalScale","clearcoatRoughness","color","dispersion","displacementMap","emissive","emissiveIntensity","emissiveMap","envMap","envMapIntensity","gradientMap","ior","iridescence","iridescenceIOR","iridescenceMap","iridescenceThicknessMap","lightMap","lightMapIntensity","map","matcap","metalness","metalnessMap","normalMap","normalScale","opacity","roughness","roughnessMap","sheen","sheenColor","sheenColorMap","sheenRoughnessMap","shininess","specular","specularColor","specularColorMap","specularIntensity","specularIntensityMap","specularMap","thickness","transmission","transmissionMap"],bs=new WeakMap;class xs{constructor(e){this.renderObjects=new WeakMap,this.hasNode=this.containsNode(e),this.hasAnimation=!0===e.object.isSkinnedMesh,this.refreshUniforms=ys,this.renderId=0}firstInitialization(e){return!1===this.renderObjects.has(e)&&(this.getRenderObjectData(e),!0)}needsVelocity(e){const t=e.getMRT();return null!==t&&t.has("velocity")}getRenderObjectData(e){let t=this.renderObjects.get(e);if(void 0===t){const{geometry:r,material:s,object:i}=e;if(t={material:this.getMaterialData(s),geometry:{id:r.id,attributes:this.getAttributesData(r.attributes),indexVersion:r.index?r.index.version:null,drawRange:{start:r.drawRange.start,count:r.drawRange.count}},worldMatrix:i.matrixWorld.clone()},i.center&&(t.center=i.center.clone()),i.morphTargetInfluences&&(t.morphTargetInfluences=i.morphTargetInfluences.slice()),null!==e.bundle&&(t.version=e.bundle.version),t.material.transmission>0){const{width:r,height:s}=e.context;t.bufferWidth=r,t.bufferHeight=s}t.lights=this.getLightsData(e.lightsNode.getLights()),this.renderObjects.set(e,t)}return t}getAttributesData(e){const t={};for(const r in e){const s=e[r];t[r]={version:s.version}}return t}containsNode(e){const t=e.material;for(const e in t)if(t[e]&&t[e].isNode)return!0;return null!==e.renderer.overrideNodes.modelViewMatrix||null!==e.renderer.overrideNodes.modelNormalViewMatrix}getMaterialData(e){const t={};for(const r of this.refreshUniforms){const s=e[r];null!=s&&("object"==typeof s&&void 0!==s.clone?!0===s.isTexture?t[r]={id:s.id,version:s.version}:t[r]=s.clone():t[r]=s)}return t}equals(e,t){const{object:r,material:s,geometry:i}=e,n=this.getRenderObjectData(e);if(!0!==n.worldMatrix.equals(r.matrixWorld))return n.worldMatrix.copy(r.matrixWorld),!1;const a=n.material;for(const e in a){const t=a[e],r=s[e];if(void 0!==t.equals){if(!1===t.equals(r))return t.copy(r),!1}else if(!0===r.isTexture){if(t.id!==r.id||t.version!==r.version)return t.id=r.id,t.version=r.version,!1}else if(t!==r)return a[e]=r,!1}if(a.transmission>0){const{width:t,height:r}=e.context;if(n.bufferWidth!==t||n.bufferHeight!==r)return n.bufferWidth=t,n.bufferHeight=r,!1}const o=n.geometry,u=i.attributes,l=o.attributes,d=Object.keys(l),c=Object.keys(u);if(o.id!==i.id)return o.id=i.id,!1;if(d.length!==c.length)return n.geometry.attributes=this.getAttributesData(u),!1;for(const e of d){const t=l[e],r=u[e];if(void 0===r)return delete l[e],!1;if(t.version!==r.version)return t.version=r.version,!1}const h=i.index,p=o.indexVersion,g=h?h.version:null;if(p!==g)return o.indexVersion=g,!1;if(o.drawRange.start!==i.drawRange.start||o.drawRange.count!==i.drawRange.count)return o.drawRange.start=i.drawRange.start,o.drawRange.count=i.drawRange.count,!1;if(n.morphTargetInfluences){let e=!1;for(let t=0;t>>16,2246822507),r^=Math.imul(s^s>>>13,3266489909),s=Math.imul(s^s>>>16,2246822507),s^=Math.imul(r^r>>>13,3266489909),4294967296*(2097151&s)+(r>>>0)}const _s=e=>Ts(e),vs=e=>Ts(e),Ns=(...e)=>Ts(e);function Ss(e,t=!1){const r=[];!0===e.isNode&&(r.push(e.id),e=e.getSelf());for(const{property:s,childNode:i}of Es(e))r.push(Ts(s.slice(0,-4)),i.getCacheKey(t));return Ts(r)}function*Es(e,t=!1){for(const r in e){if(!0===r.startsWith("_"))continue;const s=e[r];if(!0===Array.isArray(s))for(let e=0;ee.charCodeAt(0)).buffer}var Us=Object.freeze({__proto__:null,arrayBufferToBase64:Ds,base64ToArrayBuffer:Vs,getByteBoundaryFromType:Bs,getCacheKey:Ss,getDataFromObject:Is,getLengthFromType:Ms,getMemoryLengthFromType:Ps,getNodeChildren:Es,getTypeFromLength:Rs,getTypedArrayFromType:Cs,getValueFromType:Ls,getValueType:Fs,hash:Ns,hashArray:vs,hashString:_s});const Os={VERTEX:"vertex",FRAGMENT:"fragment"},ks={NONE:"none",FRAME:"frame",RENDER:"render",OBJECT:"object"},Gs={BOOLEAN:"bool",INTEGER:"int",FLOAT:"float",VECTOR2:"vec2",VECTOR3:"vec3",VECTOR4:"vec4",MATRIX2:"mat2",MATRIX3:"mat3",MATRIX4:"mat4"},zs={READ_ONLY:"readOnly",WRITE_ONLY:"writeOnly",READ_WRITE:"readWrite"},Hs=["fragment","vertex"],$s=["setup","analyze","generate"],Ws=[...Hs,"compute"],js=["x","y","z","w"],qs={analyze:"setup",generate:"analyze"};let Xs=0;class Ks extends o{static get type(){return"Node"}constructor(e=null){super(),this.nodeType=e,this.updateType=ks.NONE,this.updateBeforeType=ks.NONE,this.updateAfterType=ks.NONE,this.uuid=u.generateUUID(),this.version=0,this.global=!1,this.parents=!1,this.isNode=!0,this._cacheKey=null,this._cacheKeyVersion=0,Object.defineProperty(this,"id",{value:Xs++})}set needsUpdate(e){!0===e&&this.version++}get type(){return this.constructor.type}onUpdate(e,t){return this.updateType=t,this.update=e.bind(this.getSelf()),this}onFrameUpdate(e){return this.onUpdate(e,ks.FRAME)}onRenderUpdate(e){return this.onUpdate(e,ks.RENDER)}onObjectUpdate(e){return this.onUpdate(e,ks.OBJECT)}onReference(e){return this.updateReference=e.bind(this.getSelf()),this}getSelf(){return this.self||this}updateReference(){return this}isGlobal(){return this.global}*getChildren(){for(const{childNode:e}of Es(this))yield e}dispose(){this.dispatchEvent({type:"dispose"})}traverse(e){e(this);for(const t of this.getChildren())t.traverse(e)}getCacheKey(e=!1){return!0!==(e=e||this.version!==this._cacheKeyVersion)&&null!==this._cacheKey||(this._cacheKey=Ns(Ss(this,e),this.customCacheKey()),this._cacheKeyVersion=this.version),this._cacheKey}customCacheKey(){return 0}getScope(){return this}getHash(){return this.uuid}getUpdateType(){return this.updateType}getUpdateBeforeType(){return this.updateBeforeType}getUpdateAfterType(){return this.updateAfterType}getElementType(e){const t=this.getNodeType(e);return e.getElementType(t)}getMemberType(){return"void"}getNodeType(e){const t=e.getNodeProperties(this);return t.outputNode?t.outputNode.getNodeType(e):this.nodeType}getShared(e){const t=this.getHash(e);return e.getNodeFromHash(t)||this}getArrayCount(){return null}setup(e){const t=e.getNodeProperties(this);let r=0;for(const e of this.getChildren())t["node"+r++]=e;return t.outputNode||null}analyze(e,t=null){const r=e.increaseUsage(this);if(!0===this.parents){const r=e.getDataFromNode(this,"any");r.stages=r.stages||{},r.stages[e.shaderStage]=r.stages[e.shaderStage]||[],r.stages[e.shaderStage].push(t)}if(1===r){const t=e.getNodeProperties(this);for(const r of Object.values(t))r&&!0===r.isNode&&r.build(e,this)}}generate(e,t){const{outputNode:r}=e.getNodeProperties(this);if(r&&!0===r.isNode)return r.build(e,t)}updateBefore(){console.warn("Abstract function.")}updateAfter(){console.warn("Abstract function.")}update(){console.warn("Abstract function.")}build(e,t=null){const r=this.getShared(e);if(this!==r)return r.build(e,t);const s=e.getDataFromNode(this);s.buildStages=s.buildStages||{},s.buildStages[e.buildStage]=!0;const i=qs[e.buildStage];if(i&&!0!==s.buildStages[i]){const t=e.getBuildStage();e.setBuildStage(i),this.build(e),e.setBuildStage(t)}e.addNode(this),e.addChain(this);let n=null;const a=e.getBuildStage();if("setup"===a){this.updateReference(e);const t=e.getNodeProperties(this);if(!0!==t.initialized){t.initialized=!0,t.outputNode=this.setup(e)||t.outputNode||null;for(const r of Object.values(t))if(r&&!0===r.isNode){if(!0===r.parents){const t=e.getNodeProperties(r);t.parents=t.parents||[],t.parents.push(this)}r.build(e)}}n=t.outputNode}else if("analyze"===a)this.analyze(e,t);else if("generate"===a){if(1===this.generate.length){const r=this.getNodeType(e),s=e.getDataFromNode(this);n=s.snippet,void 0===n?void 0===s.generated?(s.generated=!0,n=this.generate(e)||"",s.snippet=n):(console.warn("THREE.Node: Recursion detected.",this),n="/* Recursion detected. */"):void 0!==s.flowCodes&&void 0!==e.context.nodeBlock&&e.addFlowCodeHierarchy(this,e.context.nodeBlock),n=e.format(n,r,t)}else n=this.generate(e,t)||"";""===n&&null!==t&&"void"!==t&&"OutputType"!==t&&(console.error(`THREE.TSL: Invalid generated code, expected a "${t}".`),n=e.generateConst(t))}return e.removeChain(this),e.addSequentialNode(this),n}getSerializeChildren(){return Es(this)}serialize(e){const t=this.getSerializeChildren(),r={};for(const{property:s,index:i,childNode:n}of t)void 0!==i?(void 0===r[s]&&(r[s]=Number.isInteger(i)?[]:{}),r[s][i]=n.toJSON(e.meta).uuid):r[s]=n.toJSON(e.meta).uuid;Object.keys(r).length>0&&(e.inputNodes=r)}deserialize(e){if(void 0!==e.inputNodes){const t=e.meta.nodes;for(const r in e.inputNodes)if(Array.isArray(e.inputNodes[r])){const s=[];for(const i of e.inputNodes[r])s.push(t[i]);this[r]=s}else if("object"==typeof e.inputNodes[r]){const s={};for(const i in e.inputNodes[r]){const n=e.inputNodes[r][i];s[i]=t[n]}this[r]=s}else{const s=e.inputNodes[r];this[r]=t[s]}}}toJSON(e){const{uuid:t,type:r}=this,s=void 0===e||"string"==typeof e;s&&(e={textures:{},images:{},nodes:{}});let i=e.nodes[t];function n(e){const t=[];for(const r in e){const s=e[r];delete s.metadata,t.push(s)}return t}if(void 0===i&&(i={uuid:t,type:r,meta:e,metadata:{version:4.7,type:"Node",generator:"Node.toJSON"}},!0!==s&&(e.nodes[i.uuid]=i),this.serialize(i),delete i.meta),s){const t=n(e.textures),r=n(e.images),s=n(e.nodes);t.length>0&&(i.textures=t),r.length>0&&(i.images=r),s.length>0&&(i.nodes=s)}return i}}class Ys extends Ks{static get type(){return"ArrayElementNode"}constructor(e,t){super(),this.node=e,this.indexNode=t,this.isArrayElementNode=!0}getNodeType(e){return this.node.getElementType(e)}generate(e){const t=this.indexNode.getNodeType(e);return`${this.node.build(e)}[ ${this.indexNode.build(e,!e.isVector(t)&&e.isInteger(t)?t:"uint")} ]`}}class Qs extends Ks{static get type(){return"ConvertNode"}constructor(e,t){super(),this.node=e,this.convertTo=t}getNodeType(e){const t=this.node.getNodeType(e);let r=null;for(const s of this.convertTo.split("|"))null!==r&&e.getTypeLength(t)!==e.getTypeLength(s)||(r=s);return r}serialize(e){super.serialize(e),e.convertTo=this.convertTo}deserialize(e){super.deserialize(e),this.convertTo=e.convertTo}generate(e,t){const r=this.node,s=this.getNodeType(e),i=r.build(e,s);return e.format(i,s,t)}}class Zs extends Ks{static get type(){return"TempNode"}constructor(e=null){super(e),this.isTempNode=!0}hasDependencies(e){return e.getDataFromNode(this).usageCount>1}build(e,t){if("generate"===e.getBuildStage()){const r=e.getVectorType(this.getNodeType(e,t)),s=e.getDataFromNode(this);if(void 0!==s.propertyName)return e.format(s.propertyName,r,t);if("void"!==r&&"void"!==t&&this.hasDependencies(e)){const i=super.build(e,r),n=e.getVarFromNode(this,null,r),a=e.getPropertyName(n);return e.addLineFlowCode(`${a} = ${i}`,this),s.snippet=i,s.propertyName=a,e.format(s.propertyName,r,t)}}return super.build(e,t)}}class Js extends Zs{static get type(){return"JoinNode"}constructor(e=[],t=null){super(t),this.nodes=e}getNodeType(e){return null!==this.nodeType?e.getVectorType(this.nodeType):e.getTypeFromLength(this.nodes.reduce((t,r)=>t+e.getTypeLength(r.getNodeType(e)),0))}generate(e,t){const r=this.getNodeType(e),s=e.getTypeLength(r),i=this.nodes,n=e.getComponentType(r),a=[];let o=0;for(const t of i){if(o>=s){console.error(`THREE.TSL: Length of parameters exceeds maximum length of function '${r}()' type.`);break}let i,u=t.getNodeType(e),l=e.getTypeLength(u);o+l>s&&(console.error(`THREE.TSL: Length of '${r}()' data exceeds maximum length of output type.`),l=s-o,u=e.getTypeFromLength(l)),o+=l,i=t.build(e,u);const d=e.getComponentType(u);d!==n&&(i=e.format(i,d,n)),a.push(i)}const u=`${e.getType(r)}( ${a.join(", ")} )`;return e.format(u,r,t)}}const ei=js.join("");class ti extends Ks{static get type(){return"SplitNode"}constructor(e,t="x"){super(),this.node=e,this.components=t,this.isSplitNode=!0}getVectorLength(){let e=this.components.length;for(const t of this.components)e=Math.max(js.indexOf(t)+1,e);return e}getComponentType(e){return e.getComponentType(this.node.getNodeType(e))}getNodeType(e){return e.getTypeFromLength(this.components.length,this.getComponentType(e))}generate(e,t){const r=this.node,s=e.getTypeLength(r.getNodeType(e));let i=null;if(s>1){let n=null;this.getVectorLength()>=s&&(n=e.getTypeFromLength(this.getVectorLength(),this.getComponentType(e)));const a=r.build(e,n);i=this.components.length===s&&this.components===ei.slice(0,this.components.length)?e.format(a,n,t):e.format(`${a}.${this.components}`,this.getNodeType(e),t)}else i=r.build(e,t);return i}serialize(e){super.serialize(e),e.components=this.components}deserialize(e){super.deserialize(e),this.components=e.components}}class ri extends Zs{static get type(){return"SetNode"}constructor(e,t,r){super(),this.sourceNode=e,this.components=t,this.targetNode=r}getNodeType(e){return this.sourceNode.getNodeType(e)}generate(e){const{sourceNode:t,components:r,targetNode:s}=this,i=this.getNodeType(e),n=e.getComponentType(s.getNodeType(e)),a=e.getTypeFromLength(r.length,n),o=s.build(e,a),u=t.build(e,i),l=e.getTypeLength(i),d=[];for(let e=0;ee.replace(/r|s/g,"x").replace(/g|t/g,"y").replace(/b|p/g,"z").replace(/a|q/g,"w"),hi=e=>ci(e).split("").sort().join(""),pi={setup(e,t){const r=t.shift();return e(Oi(r),...t)},get(e,t,r){if("string"==typeof t&&void 0===e[t]){if(!0!==e.isStackNode&&"assign"===t)return(...e)=>(ui.assign(r,...e),r);if(li.has(t)){const s=li.get(t);return e.isStackNode?(...e)=>r.add(s(...e)):(...e)=>s(r,...e)}if("toVarIntent"===t)return()=>r;if("self"===t)return e;if(t.endsWith("Assign")&&li.has(t.slice(0,t.length-6))){const s=li.get(t.slice(0,t.length-6));return e.isStackNode?(...e)=>r.assign(e[0],s(...e)):(...e)=>r.assign(s(r,...e))}if(!0===/^[xyzwrgbastpq]{1,4}$/.test(t))return t=ci(t),Vi(new ti(r,t));if(!0===/^set[XYZWRGBASTPQ]{1,4}$/.test(t))return t=hi(t.slice(3).toLowerCase()),r=>Vi(new ri(e,t,Vi(r)));if(!0===/^flip[XYZWRGBASTPQ]{1,4}$/.test(t))return t=hi(t.slice(4).toLowerCase()),()=>Vi(new si(Vi(e),t));if("width"===t||"height"===t||"depth"===t)return"width"===t?t="x":"height"===t?t="y":"depth"===t&&(t="z"),Vi(new ti(e,t));if(!0===/^\d+$/.test(t))return Vi(new Ys(r,new ai(Number(t),"uint")));if(!0===/^get$/.test(t))return e=>Vi(new oi(r,e))}return Reflect.get(e,t,r)},set:(e,t,r,s)=>"string"!=typeof t||void 0!==e[t]||!0!==/^[xyzwrgbastpq]{1,4}$/.test(t)&&"width"!==t&&"height"!==t&&"depth"!==t&&!0!==/^\d+$/.test(t)?Reflect.set(e,t,r,s):(s[t].assign(r),!0)},gi=new WeakMap,mi=new WeakMap,fi=function(e,t=null){for(const r in e)e[r]=Vi(e[r],t);return e},yi=function(e,t=null){const r=e.length;for(let s=0;so?(console.error(`THREE.TSL: "${r}" parameter length exceeds limit.`),t.slice(0,o)):t}return null===t?n=(...t)=>i(new e(...ki(l(t)))):null!==r?(r=Vi(r),n=(...s)=>i(new e(t,...ki(l(s)),r))):n=(...r)=>i(new e(t,...ki(l(r)))),n.setParameterLength=(...e)=>(1===e.length?a=o=e[0]:2===e.length&&([a,o]=e),n),n.setName=e=>(u=e,n),n},xi=function(e,...t){return Vi(new e(...ki(t)))};class Ti extends Ks{constructor(e,t){super(),this.shaderNode=e,this.rawInputs=t,this.isShaderCallNodeInternal=!0}getNodeType(e){return this.shaderNode.nodeType||this.getOutputNode(e).getNodeType(e)}getMemberType(e,t){return this.getOutputNode(e).getMemberType(e,t)}call(e){const{shaderNode:t,rawInputs:r}=this,s=e.getNodeProperties(t),i=e.getClosestSubBuild(t.subBuilds)||"",n=i||"default";if(s[n])return s[n];const a=e.subBuildFn;e.subBuildFn=i;let o=null;if(t.layout){let s=mi.get(e.constructor);void 0===s&&(s=new WeakMap,mi.set(e.constructor,s));let i=s.get(t);void 0===i&&(i=Vi(e.buildFunctionNode(t)),s.set(t,i)),e.addInclude(i);const n=r?function(e){let t;Oi(e);t=e[0]&&(e[0].isNode||Object.getPrototypeOf(e[0])!==Object.prototype)?[...e]:e[0];return t}(r):null;o=Vi(i.call(n))}else{const s=new Proxy(e,{get:(e,t,r)=>{let s;return s=Symbol.iterator===t?function*(){yield}:Reflect.get(e,t,r),s}}),i=r?function(e){let t=0;return Oi(e),new Proxy(e,{get:(r,s,i)=>{let n;if("length"===s)return n=e.length,n;if(Symbol.iterator===s)n=function*(){for(const t of e)yield Vi(t)};else{if(e.length>0)if(Object.getPrototypeOf(e[0])===Object.prototype){const r=e[0];n=void 0===r[s]?r[t++]:Reflect.get(r,s,i)}else e[0]instanceof Ks&&(n=void 0===e[s]?e[t++]:Reflect.get(e,s,i));else n=Reflect.get(r,s,i);n=Vi(n)}return n}})}(r):null,n=Array.isArray(r)?r.length>0:null!==r,a=t.jsFunc,u=n||a.length>1?a(i,s):a(s);o=Vi(u)}return e.subBuildFn=a,t.once&&(s[n]=o),o}setupOutput(e){return e.addStack(),e.stack.outputNode=this.call(e),e.removeStack()}getOutputNode(e){const t=e.getNodeProperties(this),r=e.getSubBuildOutput(this);return t[r]=t[r]||this.setupOutput(e),t[r].subBuild=e.getClosestSubBuild(this),t[r]}build(e,t=null){let r=null;const s=e.getBuildStage(),i=e.getNodeProperties(this),n=e.getSubBuildOutput(this),a=this.getOutputNode(e);if("setup"===s){const t=e.getSubBuildProperty("initialized",this);if(!0!==i[t]&&(i[t]=!0,i[n]=this.getOutputNode(e),i[n].build(e),this.shaderNode.subBuilds))for(const t of e.chaining){const r=e.getDataFromNode(t,"any");r.subBuilds=r.subBuilds||new Set;for(const e of this.shaderNode.subBuilds)r.subBuilds.add(e)}r=i[n]}else"analyze"===s?a.build(e,t):"generate"===s&&(r=a.build(e,t)||"");return r}}class _i extends Ks{constructor(e,t){super(t),this.jsFunc=e,this.layout=null,this.global=!0,this.once=!1}setLayout(e){return this.layout=e,this}call(e=null){return Vi(new Ti(this,e))}setup(){return this.call()}}const vi=[!1,!0],Ni=[0,1,2,3],Si=[-1,-2],Ei=[.5,1.5,1/3,1e-6,1e6,Math.PI,2*Math.PI,1/Math.PI,2/Math.PI,1/(2*Math.PI),Math.PI/2],wi=new Map;for(const e of vi)wi.set(e,new ai(e));const Ai=new Map;for(const e of Ni)Ai.set(e,new ai(e,"uint"));const Ri=new Map([...Ai].map(e=>new ai(e.value,"int")));for(const e of Si)Ri.set(e,new ai(e,"int"));const Ci=new Map([...Ri].map(e=>new ai(e.value)));for(const e of Ei)Ci.set(e,new ai(e));for(const e of Ei)Ci.set(-e,new ai(-e));const Mi={bool:wi,uint:Ai,ints:Ri,float:Ci},Pi=new Map([...wi,...Ci]),Bi=(e,t)=>Pi.has(e)?Pi.get(e):!0===e.isNode?e:new ai(e,t),Fi=function(e,t=null){return(...r)=>{for(const t of r)if(void 0===t)return console.error(`THREE.TSL: Invalid parameter for the type "${e}".`),Vi(new ai(0,e));if((0===r.length||!["bool","float","int","uint"].includes(e)&&r.every(e=>{const t=typeof e;return"object"!==t&&"function"!==t}))&&(r=[Ls(e,...r)]),1===r.length&&null!==t&&t.has(r[0]))return Ui(t.get(r[0]));if(1===r.length){const t=Bi(r[0],e);return t.nodeType===e?Ui(t):Ui(new Qs(t,e))}const s=r.map(e=>Bi(e));return Ui(new Js(s,e))}},Li=e=>"object"==typeof e&&null!==e?e.value:e,Ii=e=>null!=e?e.nodeType||e.convertTo||("string"==typeof e?e:null):null;function Di(e,t){return new Proxy(new _i(e,t),pi)}const Vi=(e,t=null)=>function(e,t=null){const r=Fs(e);if("node"===r){let t=gi.get(e);return void 0===t&&(t=new Proxy(e,pi),gi.set(e,t),gi.set(t,t)),t}return null===t&&("float"===r||"boolean"===r)||r&&"shader"!==r&&"string"!==r?Vi(Bi(e,t)):"shader"===r?e.isFn?e:ji(e):e}(e,t),Ui=(e,t=null)=>Vi(e,t).toVarIntent(),Oi=(e,t=null)=>new fi(e,t),ki=(e,t=null)=>new yi(e,t),Gi=(e,t=null,r=null,s=null)=>new bi(e,t,r,s),zi=(e,...t)=>new xi(e,...t),Hi=(e,t=null,r=null,s={})=>new bi(e,t,r,{intent:!0,...s});let $i=0;class Wi extends Ks{constructor(e,t=null){super();let r=null;null!==t&&("object"==typeof t?r=t.return:("string"==typeof t?r=t:console.error("THREE.TSL: Invalid layout type."),t=null)),this.shaderNode=new Di(e,r),null!==t&&this.setLayout(t),this.isFn=!0}setLayout(e){const t=this.shaderNode.nodeType;if("object"!=typeof e.inputs){const r={name:"fn"+$i++,type:t,inputs:[]};for(const t in e)"return"!==t&&r.inputs.push({name:t,type:e[t]});e=r}return this.shaderNode.setLayout(e),this}getNodeType(e){return this.shaderNode.getNodeType(e)||"float"}call(...e){const t=this.shaderNode.call(e);return"void"===this.shaderNode.nodeType&&t.toStack(),t.toVarIntent()}once(e=null){return this.shaderNode.once=!0,this.shaderNode.subBuilds=e,this}generate(e){const t=this.getNodeType(e);return console.error('THREE.TSL: "Fn()" was declared but not invoked. Try calling it like "Fn()( ...params )".'),e.generateConst(t)}}function ji(e,t=null){const r=new Wi(e,t);return new Proxy(()=>{},{apply:(e,t,s)=>r.call(...s),get:(e,t,s)=>Reflect.get(r,t,s),set:(e,t,s,i)=>Reflect.set(r,t,s,i)})}const qi=e=>{ui=e},Xi=()=>ui,Ki=(...e)=>ui.If(...e);function Yi(e){return ui&&ui.add(e),e}di("toStack",Yi);const Qi=new Fi("color"),Zi=new Fi("float",Mi.float),Ji=new Fi("int",Mi.ints),en=new Fi("uint",Mi.uint),tn=new Fi("bool",Mi.bool),rn=new Fi("vec2"),sn=new Fi("ivec2"),nn=new Fi("uvec2"),an=new Fi("bvec2"),on=new Fi("vec3"),un=new Fi("ivec3"),ln=new Fi("uvec3"),dn=new Fi("bvec3"),cn=new Fi("vec4"),hn=new Fi("ivec4"),pn=new Fi("uvec4"),gn=new Fi("bvec4"),mn=new Fi("mat2"),fn=new Fi("mat3"),yn=new Fi("mat4");di("toColor",Qi),di("toFloat",Zi),di("toInt",Ji),di("toUint",en),di("toBool",tn),di("toVec2",rn),di("toIVec2",sn),di("toUVec2",nn),di("toBVec2",an),di("toVec3",on),di("toIVec3",un),di("toUVec3",ln),di("toBVec3",dn),di("toVec4",cn),di("toIVec4",hn),di("toUVec4",pn),di("toBVec4",gn),di("toMat2",mn),di("toMat3",fn),di("toMat4",yn);const bn=Gi(Ys).setParameterLength(2),xn=(e,t)=>Vi(new Qs(Vi(e),t));di("element",bn),di("convert",xn);di("append",e=>(console.warn("THREE.TSL: .append() has been renamed to .toStack()."),Yi(e)));class Tn extends Ks{static get type(){return"PropertyNode"}constructor(e,t=null,r=!1){super(e),this.name=t,this.varying=r,this.isPropertyNode=!0,this.global=!0}getHash(e){return this.name||super.getHash(e)}generate(e){let t;return!0===this.varying?(t=e.getVaryingFromNode(this,this.name),t.needsInterpolation=!0):t=e.getVarFromNode(this,this.name),e.getPropertyName(t)}}const _n=(e,t)=>Vi(new Tn(e,t)),vn=(e,t)=>Vi(new Tn(e,t,!0)),Nn=zi(Tn,"vec4","DiffuseColor"),Sn=zi(Tn,"vec3","EmissiveColor"),En=zi(Tn,"float","Roughness"),wn=zi(Tn,"float","Metalness"),An=zi(Tn,"float","Clearcoat"),Rn=zi(Tn,"float","ClearcoatRoughness"),Cn=zi(Tn,"vec3","Sheen"),Mn=zi(Tn,"float","SheenRoughness"),Pn=zi(Tn,"float","Iridescence"),Bn=zi(Tn,"float","IridescenceIOR"),Fn=zi(Tn,"float","IridescenceThickness"),Ln=zi(Tn,"float","AlphaT"),In=zi(Tn,"float","Anisotropy"),Dn=zi(Tn,"vec3","AnisotropyT"),Vn=zi(Tn,"vec3","AnisotropyB"),Un=zi(Tn,"color","SpecularColor"),On=zi(Tn,"float","SpecularF90"),kn=zi(Tn,"float","Shininess"),Gn=zi(Tn,"vec4","Output"),zn=zi(Tn,"float","dashSize"),Hn=zi(Tn,"float","gapSize"),$n=zi(Tn,"float","pointWidth"),Wn=zi(Tn,"float","IOR"),jn=zi(Tn,"float","Transmission"),qn=zi(Tn,"float","Thickness"),Xn=zi(Tn,"float","AttenuationDistance"),Kn=zi(Tn,"color","AttenuationColor"),Yn=zi(Tn,"float","Dispersion");class Qn extends Ks{static get type(){return"UniformGroupNode"}constructor(e,t=!1,r=1){super("string"),this.name=e,this.shared=t,this.order=r,this.isUniformGroup=!0}serialize(e){super.serialize(e),e.name=this.name,e.version=this.version,e.shared=this.shared}deserialize(e){super.deserialize(e),this.name=e.name,this.version=e.version,this.shared=e.shared}}const Zn=e=>new Qn(e),Jn=(e,t=0)=>new Qn(e,!0,t),ea=Jn("frame"),ta=Jn("render"),ra=Zn("object");class sa extends ii{static get type(){return"UniformNode"}constructor(e,t=null){super(e,t),this.isUniformNode=!0,this.name="",this.groupNode=ra}setName(e){return this.name=e,this}label(e){return console.warn('THREE.TSL: "label()" has been deprecated. Use "setName()" instead.'),this.setName(e)}setGroup(e){return this.groupNode=e,this}getGroup(){return this.groupNode}getUniformHash(e){return this.getHash(e)}onUpdate(e,t){const r=this.getSelf();return e=e.bind(r),super.onUpdate(t=>{const s=e(t,r);void 0!==s&&(this.value=s)},t)}getInputType(e){let t=super.getInputType(e);return"bool"===t&&(t="uint"),t}generate(e,t){const r=this.getNodeType(e),s=this.getUniformHash(e);let i=e.getNodeFromHash(s);void 0===i&&(e.setHashNode(this,s),i=this);const n=i.getInputType(e),a=e.getUniformFromNode(i,n,e.shaderStage,this.name||e.context.nodeName),o=e.getPropertyName(a);void 0!==e.context.nodeName&&delete e.context.nodeName;let u=o;if("bool"===r){const t=e.getDataFromNode(this);let s=t.propertyName;if(void 0===s){const i=e.getVarFromNode(this,null,"bool");s=e.getPropertyName(i),t.propertyName=s,u=e.format(o,n,r),e.addLineFlowCode(`${s} = ${u}`,this)}u=s}return e.format(u,r,t)}}const ia=(e,t)=>{const r=Ii(t||e);return r===e&&(e=Ls(r)),e=e&&!0===e.isNode?e.node&&e.node.value||e.value:e,Vi(new sa(e,r))};class na extends Zs{static get type(){return"ArrayNode"}constructor(e,t,r=null){super(e),this.count=t,this.values=r,this.isArrayNode=!0}getArrayCount(){return this.count}getNodeType(e){return null===this.nodeType&&(this.nodeType=this.values[0].getNodeType(e)),this.nodeType}getElementType(e){return this.getNodeType(e)}generate(e){const t=this.getNodeType(e);return e.generateArray(t,this.count,this.values)}}const aa=(...e)=>{let t;if(1===e.length){const r=e[0];t=new na(null,r.length,r)}else{const r=e[0],s=e[1];t=new na(r,s)}return Vi(t)};di("toArray",(e,t)=>aa(Array(t).fill(e)));class oa extends Zs{static get type(){return"AssignNode"}constructor(e,t){super(),this.targetNode=e,this.sourceNode=t,this.isAssignNode=!0}hasDependencies(){return!1}getNodeType(e,t){return"void"!==t?this.targetNode.getNodeType(e):"void"}needsSplitAssign(e){const{targetNode:t}=this;if(!1===e.isAvailable("swizzleAssign")&&t.isSplitNode&&t.components.length>1){const r=e.getTypeLength(t.node.getNodeType(e));return js.join("").slice(0,r)!==t.components}return!1}setup(e){const{targetNode:t,sourceNode:r}=this;e.getNodeProperties(t).assign=!0;const s=e.getNodeProperties(this);s.sourceNode=r,s.targetNode=t.context({assign:!0})}generate(e,t){const{targetNode:r,sourceNode:s}=e.getNodeProperties(this),i=this.needsSplitAssign(e),n=r.build(e),a=r.getNodeType(e),o=s.build(e,a),u=s.getNodeType(e),l=e.getDataFromNode(this);let d;if(!0===l.initialized)"void"!==t&&(d=n);else if(i){const s=e.getVarFromNode(this,null,a),i=e.getPropertyName(s);e.addLineFlowCode(`${i} = ${o}`,this);const u=r.node,l=u.node.context({assign:!0}).build(e);for(let t=0;t{const s=r.type;let i;return i="pointer"===s?"&"+t.build(e):t.build(e,s),i};if(Array.isArray(i)){if(i.length>s.length)console.error("THREE.TSL: The number of provided parameters exceeds the expected number of inputs in 'Fn()'."),i.length=s.length;else if(i.length(t=t.length>1||t[0]&&!0===t[0].isNode?ki(t):Oi(t[0]),Vi(new la(Vi(e),t)));di("call",da);const ca={"==":"equal","!=":"notEqual","<":"lessThan",">":"greaterThan","<=":"lessThanEqual",">=":"greaterThanEqual","%":"mod"};class ha extends Zs{static get type(){return"OperatorNode"}constructor(e,t,r,...s){if(super(),s.length>0){let i=new ha(e,t,r);for(let t=0;t>"===r||"<<"===r)return e.getIntegerType(n);if("!"===r||"&&"===r||"||"===r||"^^"===r)return"bool";if("=="===r||"!="===r||"<"===r||">"===r||"<="===r||">="===r){const t=Math.max(e.getTypeLength(n),e.getTypeLength(a));return t>1?`bvec${t}`:"bool"}if(e.isMatrix(n)){if("float"===a)return n;if(e.isVector(a))return e.getVectorFromMatrix(n);if(e.isMatrix(a))return n}else if(e.isMatrix(a)){if("float"===n)return a;if(e.isVector(n))return e.getVectorFromMatrix(a)}return e.getTypeLength(a)>e.getTypeLength(n)?a:n}generate(e,t){const r=this.op,{aNode:s,bNode:i}=this,n=this.getNodeType(e,t);let a=null,o=null;"void"!==n?(a=s.getNodeType(e),o=i?i.getNodeType(e):null,"<"===r||">"===r||"<="===r||">="===r||"=="===r||"!="===r?e.isVector(a)?o=a:e.isVector(o)?a=o:a!==o&&(a=o="float"):">>"===r||"<<"===r?(a=n,o=e.changeComponentType(o,"uint")):"%"===r?(a=n,o=e.isInteger(a)&&e.isInteger(o)?o:a):e.isMatrix(a)?"float"===o?o="float":e.isVector(o)?o=e.getVectorFromMatrix(a):e.isMatrix(o)||(a=o=n):a=e.isMatrix(o)?"float"===a?"float":e.isVector(a)?e.getVectorFromMatrix(o):o=n:o=n):a=o=n;const u=s.build(e,a),d=i?i.build(e,o):null,c=e.getFunctionOperator(r);if("void"!==t){const s=e.renderer.coordinateSystem===l;if("=="===r||"!="===r||"<"===r||">"===r||"<="===r||">="===r)return s&&e.isVector(a)?e.format(`${this.getOperatorMethod(e,t)}( ${u}, ${d} )`,n,t):e.format(`( ${u} ${r} ${d} )`,n,t);if("%"===r)return e.isInteger(o)?e.format(`( ${u} % ${d} )`,n,t):e.format(`${this.getOperatorMethod(e,n)}( ${u}, ${d} )`,n,t);if("!"===r||"~"===r)return e.format(`(${r}${u})`,a,t);if(c)return e.format(`${c}( ${u}, ${d} )`,n,t);if(e.isMatrix(a)&&"float"===o)return e.format(`( ${d} ${r} ${u} )`,n,t);if("float"===a&&e.isMatrix(o))return e.format(`${u} ${r} ${d}`,n,t);{let i=`( ${u} ${r} ${d} )`;return!s&&"bool"===n&&e.isVector(a)&&e.isVector(o)&&(i=`all${i}`),e.format(i,n,t)}}if("void"!==a)return c?e.format(`${c}( ${u}, ${d} )`,n,t):e.isMatrix(a)&&"float"===o?e.format(`${d} ${r} ${u}`,n,t):e.format(`${u} ${r} ${d}`,n,t)}serialize(e){super.serialize(e),e.op=this.op}deserialize(e){super.deserialize(e),this.op=e.op}}const pa=Hi(ha,"+").setParameterLength(2,1/0).setName("add"),ga=Hi(ha,"-").setParameterLength(2,1/0).setName("sub"),ma=Hi(ha,"*").setParameterLength(2,1/0).setName("mul"),fa=Hi(ha,"/").setParameterLength(2,1/0).setName("div"),ya=Hi(ha,"%").setParameterLength(2).setName("mod"),ba=Hi(ha,"==").setParameterLength(2).setName("equal"),xa=Hi(ha,"!=").setParameterLength(2).setName("notEqual"),Ta=Hi(ha,"<").setParameterLength(2).setName("lessThan"),_a=Hi(ha,">").setParameterLength(2).setName("greaterThan"),va=Hi(ha,"<=").setParameterLength(2).setName("lessThanEqual"),Na=Hi(ha,">=").setParameterLength(2).setName("greaterThanEqual"),Sa=Hi(ha,"&&").setParameterLength(2,1/0).setName("and"),Ea=Hi(ha,"||").setParameterLength(2,1/0).setName("or"),wa=Hi(ha,"!").setParameterLength(1).setName("not"),Aa=Hi(ha,"^^").setParameterLength(2).setName("xor"),Ra=Hi(ha,"&").setParameterLength(2).setName("bitAnd"),Ca=Hi(ha,"~").setParameterLength(2).setName("bitNot"),Ma=Hi(ha,"|").setParameterLength(2).setName("bitOr"),Pa=Hi(ha,"^").setParameterLength(2).setName("bitXor"),Ba=Hi(ha,"<<").setParameterLength(2).setName("shiftLeft"),Fa=Hi(ha,">>").setParameterLength(2).setName("shiftRight"),La=ji(([e])=>(e.addAssign(1),e)),Ia=ji(([e])=>(e.subAssign(1),e)),Da=ji(([e])=>{const t=Ji(e).toConst();return e.addAssign(1),t}),Va=ji(([e])=>{const t=Ji(e).toConst();return e.subAssign(1),t});di("add",pa),di("sub",ga),di("mul",ma),di("div",fa),di("mod",ya),di("equal",ba),di("notEqual",xa),di("lessThan",Ta),di("greaterThan",_a),di("lessThanEqual",va),di("greaterThanEqual",Na),di("and",Sa),di("or",Ea),di("not",wa),di("xor",Aa),di("bitAnd",Ra),di("bitNot",Ca),di("bitOr",Ma),di("bitXor",Pa),di("shiftLeft",Ba),di("shiftRight",Fa),di("incrementBefore",La),di("decrementBefore",Ia),di("increment",Da),di("decrement",Va);const Ua=(e,t)=>(console.warn('THREE.TSL: "modInt()" is deprecated. Use "mod( int( ... ) )" instead.'),ya(Ji(e),Ji(t)));di("modInt",Ua);class Oa extends Zs{static get type(){return"MathNode"}constructor(e,t,r=null,s=null){if(super(),(e===Oa.MAX||e===Oa.MIN)&&arguments.length>3){let i=new Oa(e,t,r);for(let t=2;tn&&i>a?t:n>a?r:a>i?s:t}getNodeType(e){const t=this.method;return t===Oa.LENGTH||t===Oa.DISTANCE||t===Oa.DOT?"float":t===Oa.CROSS?"vec3":t===Oa.ALL||t===Oa.ANY?"bool":t===Oa.EQUALS?e.changeComponentType(this.aNode.getNodeType(e),"bool"):this.getInputType(e)}setup(e){const{aNode:t,bNode:r,method:s}=this;let i=null;if(s===Oa.ONE_MINUS)i=ga(1,t);else if(s===Oa.RECIPROCAL)i=fa(1,t);else if(s===Oa.DIFFERENCE)i=co(ga(t,r));else if(s===Oa.TRANSFORM_DIRECTION){let s=t,n=r;e.isMatrix(s.getNodeType(e))?n=cn(on(n),0):s=cn(on(s),0);const a=ma(s,n).xyz;i=ro(a)}return null!==i?i:super.setup(e)}generate(e,t){if(e.getNodeProperties(this).outputNode)return super.generate(e,t);let r=this.method;const s=this.getNodeType(e),i=this.getInputType(e),n=this.aNode,a=this.bNode,o=this.cNode,u=e.renderer.coordinateSystem;if(r===Oa.NEGATE)return e.format("( - "+n.build(e,i)+" )",s,t);{const c=[];return r===Oa.CROSS?c.push(n.build(e,s),a.build(e,s)):u===l&&r===Oa.STEP?c.push(n.build(e,1===e.getTypeLength(n.getNodeType(e))?"float":i),a.build(e,i)):u!==l||r!==Oa.MIN&&r!==Oa.MAX?r===Oa.REFRACT?c.push(n.build(e,i),a.build(e,i),o.build(e,"float")):r===Oa.MIX?c.push(n.build(e,i),a.build(e,i),o.build(e,1===e.getTypeLength(o.getNodeType(e))?"float":i)):(u===d&&r===Oa.ATAN&&null!==a&&(r="atan2"),"fragment"===e.shaderStage||r!==Oa.DFDX&&r!==Oa.DFDY||(console.warn(`THREE.TSL: '${r}' is not supported in the ${e.shaderStage} stage.`),r="/*"+r+"*/"),c.push(n.build(e,i)),null!==a&&c.push(a.build(e,i)),null!==o&&c.push(o.build(e,i))):c.push(n.build(e,i),a.build(e,1===e.getTypeLength(a.getNodeType(e))?"float":i)),e.format(`${e.getMethod(r,s)}( ${c.join(", ")} )`,s,t)}}serialize(e){super.serialize(e),e.method=this.method}deserialize(e){super.deserialize(e),this.method=e.method}}Oa.ALL="all",Oa.ANY="any",Oa.RADIANS="radians",Oa.DEGREES="degrees",Oa.EXP="exp",Oa.EXP2="exp2",Oa.LOG="log",Oa.LOG2="log2",Oa.SQRT="sqrt",Oa.INVERSE_SQRT="inversesqrt",Oa.FLOOR="floor",Oa.CEIL="ceil",Oa.NORMALIZE="normalize",Oa.FRACT="fract",Oa.SIN="sin",Oa.COS="cos",Oa.TAN="tan",Oa.ASIN="asin",Oa.ACOS="acos",Oa.ATAN="atan",Oa.ABS="abs",Oa.SIGN="sign",Oa.LENGTH="length",Oa.NEGATE="negate",Oa.ONE_MINUS="oneMinus",Oa.DFDX="dFdx",Oa.DFDY="dFdy",Oa.ROUND="round",Oa.RECIPROCAL="reciprocal",Oa.TRUNC="trunc",Oa.FWIDTH="fwidth",Oa.TRANSPOSE="transpose",Oa.DETERMINANT="determinant",Oa.INVERSE="inverse",Oa.BITCAST="bitcast",Oa.EQUALS="equals",Oa.MIN="min",Oa.MAX="max",Oa.STEP="step",Oa.REFLECT="reflect",Oa.DISTANCE="distance",Oa.DIFFERENCE="difference",Oa.DOT="dot",Oa.CROSS="cross",Oa.POW="pow",Oa.TRANSFORM_DIRECTION="transformDirection",Oa.MIX="mix",Oa.CLAMP="clamp",Oa.REFRACT="refract",Oa.SMOOTHSTEP="smoothstep",Oa.FACEFORWARD="faceforward";const ka=Zi(1e-6),Ga=Zi(1e6),za=Zi(Math.PI),Ha=Zi(2*Math.PI),$a=Hi(Oa,Oa.ALL).setParameterLength(1),Wa=Hi(Oa,Oa.ANY).setParameterLength(1),ja=Hi(Oa,Oa.RADIANS).setParameterLength(1),qa=Hi(Oa,Oa.DEGREES).setParameterLength(1),Xa=Hi(Oa,Oa.EXP).setParameterLength(1),Ka=Hi(Oa,Oa.EXP2).setParameterLength(1),Ya=Hi(Oa,Oa.LOG).setParameterLength(1),Qa=Hi(Oa,Oa.LOG2).setParameterLength(1),Za=Hi(Oa,Oa.SQRT).setParameterLength(1),Ja=Hi(Oa,Oa.INVERSE_SQRT).setParameterLength(1),eo=Hi(Oa,Oa.FLOOR).setParameterLength(1),to=Hi(Oa,Oa.CEIL).setParameterLength(1),ro=Hi(Oa,Oa.NORMALIZE).setParameterLength(1),so=Hi(Oa,Oa.FRACT).setParameterLength(1),io=Hi(Oa,Oa.SIN).setParameterLength(1),no=Hi(Oa,Oa.COS).setParameterLength(1),ao=Hi(Oa,Oa.TAN).setParameterLength(1),oo=Hi(Oa,Oa.ASIN).setParameterLength(1),uo=Hi(Oa,Oa.ACOS).setParameterLength(1),lo=Hi(Oa,Oa.ATAN).setParameterLength(1,2),co=Hi(Oa,Oa.ABS).setParameterLength(1),ho=Hi(Oa,Oa.SIGN).setParameterLength(1),po=Hi(Oa,Oa.LENGTH).setParameterLength(1),go=Hi(Oa,Oa.NEGATE).setParameterLength(1),mo=Hi(Oa,Oa.ONE_MINUS).setParameterLength(1),fo=Hi(Oa,Oa.DFDX).setParameterLength(1),yo=Hi(Oa,Oa.DFDY).setParameterLength(1),bo=Hi(Oa,Oa.ROUND).setParameterLength(1),xo=Hi(Oa,Oa.RECIPROCAL).setParameterLength(1),To=Hi(Oa,Oa.TRUNC).setParameterLength(1),_o=Hi(Oa,Oa.FWIDTH).setParameterLength(1),vo=Hi(Oa,Oa.TRANSPOSE).setParameterLength(1),No=Hi(Oa,Oa.DETERMINANT).setParameterLength(1),So=Hi(Oa,Oa.INVERSE).setParameterLength(1),Eo=Hi(Oa,Oa.BITCAST).setParameterLength(2),wo=(e,t)=>(console.warn('THREE.TSL: "equals" is deprecated. Use "equal" inside a vector instead, like: "bvec*( equal( ... ) )"'),ba(e,t)),Ao=Hi(Oa,Oa.MIN).setParameterLength(2,1/0),Ro=Hi(Oa,Oa.MAX).setParameterLength(2,1/0),Co=Hi(Oa,Oa.STEP).setParameterLength(2),Mo=Hi(Oa,Oa.REFLECT).setParameterLength(2),Po=Hi(Oa,Oa.DISTANCE).setParameterLength(2),Bo=Hi(Oa,Oa.DIFFERENCE).setParameterLength(2),Fo=Hi(Oa,Oa.DOT).setParameterLength(2),Lo=Hi(Oa,Oa.CROSS).setParameterLength(2),Io=Hi(Oa,Oa.POW).setParameterLength(2),Do=Hi(Oa,Oa.POW,2).setParameterLength(1),Vo=Hi(Oa,Oa.POW,3).setParameterLength(1),Uo=Hi(Oa,Oa.POW,4).setParameterLength(1),Oo=Hi(Oa,Oa.TRANSFORM_DIRECTION).setParameterLength(2),ko=e=>ma(ho(e),Io(co(e),1/3)),Go=e=>Fo(e,e),zo=Hi(Oa,Oa.MIX).setParameterLength(3),Ho=(e,t=0,r=1)=>Vi(new Oa(Oa.CLAMP,Vi(e),Vi(t),Vi(r))),$o=e=>Ho(e),Wo=Hi(Oa,Oa.REFRACT).setParameterLength(3),jo=Hi(Oa,Oa.SMOOTHSTEP).setParameterLength(3),qo=Hi(Oa,Oa.FACEFORWARD).setParameterLength(3),Xo=ji(([e])=>{const t=Fo(e.xy,rn(12.9898,78.233)),r=ya(t,za);return so(io(r).mul(43758.5453))}),Ko=(e,t,r)=>zo(t,r,e),Yo=(e,t,r)=>jo(t,r,e),Qo=(e,t)=>Co(t,e),Zo=(e,t)=>(console.warn('THREE.TSL: "atan2" is overloaded. Use "atan" instead.'),lo(e,t)),Jo=qo,eu=Ja;di("all",$a),di("any",Wa),di("equals",wo),di("radians",ja),di("degrees",qa),di("exp",Xa),di("exp2",Ka),di("log",Ya),di("log2",Qa),di("sqrt",Za),di("inverseSqrt",Ja),di("floor",eo),di("ceil",to),di("normalize",ro),di("fract",so),di("sin",io),di("cos",no),di("tan",ao),di("asin",oo),di("acos",uo),di("atan",lo),di("abs",co),di("sign",ho),di("length",po),di("lengthSq",Go),di("negate",go),di("oneMinus",mo),di("dFdx",fo),di("dFdy",yo),di("round",bo),di("reciprocal",xo),di("trunc",To),di("fwidth",_o),di("atan2",Zo),di("min",Ao),di("max",Ro),di("step",Qo),di("reflect",Mo),di("distance",Po),di("dot",Fo),di("cross",Lo),di("pow",Io),di("pow2",Do),di("pow3",Vo),di("pow4",Uo),di("transformDirection",Oo),di("mix",Ko),di("clamp",Ho),di("refract",Wo),di("smoothstep",Yo),di("faceForward",qo),di("difference",Bo),di("saturate",$o),di("cbrt",ko),di("transpose",vo),di("determinant",No),di("inverse",So),di("rand",Xo);class tu extends Ks{static get type(){return"ConditionalNode"}constructor(e,t,r=null){super(),this.condNode=e,this.ifNode=t,this.elseNode=r}getNodeType(e){const{ifNode:t,elseNode:r}=e.getNodeProperties(this);if(void 0===t)return e.flowBuildStage(this,"setup"),this.getNodeType(e);const s=t.getNodeType(e);if(null!==r){const t=r.getNodeType(e);if(e.getTypeLength(t)>e.getTypeLength(s))return t}return s}setup(e){const t=this.condNode.cache(),r=this.ifNode.cache(),s=this.elseNode?this.elseNode.cache():null,i=e.context.nodeBlock;e.getDataFromNode(r).parentNodeBlock=i,null!==s&&(e.getDataFromNode(s).parentNodeBlock=i);const n=e.context.uniformFlow,a=e.getNodeProperties(this);a.condNode=t,a.ifNode=n?r:r.context({nodeBlock:r}),a.elseNode=s?n?s:s.context({nodeBlock:s}):null}generate(e,t){const r=this.getNodeType(e),s=e.getDataFromNode(this);if(void 0!==s.nodeProperty)return s.nodeProperty;const{condNode:i,ifNode:n,elseNode:a}=e.getNodeProperties(this),o=e.currentFunctionNode,u="void"!==t,l=u?_n(r).build(e):"";s.nodeProperty=l;const d=i.build(e,"bool");if(e.context.uniformFlow&&null!==a){const s=n.build(e,r),i=a.build(e,r),o=e.getTernary(d,s,i);return e.format(o,r,t)}e.addFlowCode(`\n${e.tab}if ( ${d} ) {\n\n`).addFlowTab();let c=n.build(e,r);if(c&&(u?c=l+" = "+c+";":(c="return "+c+";",null===o&&(console.warn("THREE.TSL: Return statement used in an inline 'Fn()'. Define a layout struct to allow return values."),c="// "+c))),e.removeFlowTab().addFlowCode(e.tab+"\t"+c+"\n\n"+e.tab+"}"),null!==a){e.addFlowCode(" else {\n\n").addFlowTab();let t=a.build(e,r);t&&(u?t=l+" = "+t+";":(t="return "+t+";",null===o&&(console.warn("THREE.TSL: Return statement used in an inline 'Fn()'. Define a layout struct to allow return values."),t="// "+t))),e.removeFlowTab().addFlowCode(e.tab+"\t"+t+"\n\n"+e.tab+"}\n\n")}else e.addFlowCode("\n\n");return e.format(l,r,t)}}const ru=Gi(tu).setParameterLength(2,3);di("select",ru);class su extends Ks{static get type(){return"ContextNode"}constructor(e,t={}){super(),this.isContextNode=!0,this.node=e,this.value=t}getScope(){return this.node.getScope()}getNodeType(e){return this.node.getNodeType(e)}getMemberType(e,t){return this.node.getMemberType(e,t)}analyze(e){const t=e.getContext();e.setContext({...e.context,...this.value}),this.node.build(e),e.setContext(t)}setup(e){const t=e.getContext();e.setContext({...e.context,...this.value}),this.node.build(e),e.setContext(t)}generate(e,t){const r=e.getContext();e.setContext({...e.context,...this.value});const s=this.node.build(e,t);return e.setContext(r),s}}const iu=Gi(su).setParameterLength(1,2),nu=e=>iu(e,{uniformFlow:!0}),au=(e,t)=>iu(e,{nodeName:t});function ou(e,t){return console.warn('THREE.TSL: "label()" has been deprecated. Use "setName()" instead.'),au(e,t)}di("context",iu),di("label",ou),di("uniformFlow",nu),di("setName",au);class uu extends Ks{static get type(){return"VarNode"}constructor(e,t=null,r=!1){super(),this.node=e,this.name=t,this.global=!0,this.isVarNode=!0,this.readOnly=r,this.parents=!0,this.intent=!1}setIntent(e){return this.intent=e,this}getIntent(){return this.intent}getMemberType(e,t){return this.node.getMemberType(e,t)}getElementType(e){return this.node.getElementType(e)}getNodeType(e){return this.node.getNodeType(e)}getArrayCount(e){return this.node.getArrayCount(e)}build(...e){if(!0===this.intent){if(!0!==e[0].getNodeProperties(this).assign)return this.node.build(...e)}return super.build(...e)}generate(e){const{node:t,name:r,readOnly:s}=this,{renderer:i}=e,n=!0===i.backend.isWebGPUBackend;let a=!1,o=!1;s&&(a=e.isDeterministic(t),o=n?s:a);const u=e.getVectorType(this.getNodeType(e)),l=t.build(e,u),d=e.getVarFromNode(this,r,u,void 0,o),c=e.getPropertyName(d);let h=c;if(o)if(n)h=a?`const ${c}`:`let ${c}`;else{const r=t.getArrayCount(e);h=`const ${e.getVar(d.type,c,r)}`}return e.addLineFlowCode(`${h} = ${l}`,this),c}}const lu=Gi(uu),du=(e,t=null)=>lu(e,t).toStack(),cu=(e,t=null)=>lu(e,t,!0).toStack(),hu=e=>null===Xi()?e:lu(e).setIntent(!0).toStack();di("toVar",du),di("toConst",cu),di("toVarIntent",hu);class pu extends Ks{static get type(){return"SubBuild"}constructor(e,t,r=null){super(r),this.node=e,this.name=t,this.isSubBuildNode=!0}getNodeType(e){if(null!==this.nodeType)return this.nodeType;e.addSubBuild(this.name);const t=this.node.getNodeType(e);return e.removeSubBuild(),t}build(e,...t){e.addSubBuild(this.name);const r=this.node.build(e,...t);return e.removeSubBuild(),r}}const gu=(e,t,r=null)=>Vi(new pu(Vi(e),t,r));class mu extends Ks{static get type(){return"VaryingNode"}constructor(e,t=null){super(),this.node=e,this.name=t,this.isVaryingNode=!0,this.interpolationType=null,this.interpolationSampling=null,this.global=!0}setInterpolation(e,t=null){return this.interpolationType=e,this.interpolationSampling=t,this}getHash(e){return this.name||super.getHash(e)}getNodeType(e){return this.node.getNodeType(e)}setupVarying(e){const t=e.getNodeProperties(this);let r=t.varying;if(void 0===r){const s=this.name,i=this.getNodeType(e),n=this.interpolationType,a=this.interpolationSampling;t.varying=r=e.getVaryingFromNode(this,s,i,n,a),t.node=gu(this.node,"VERTEX")}return r.needsInterpolation||(r.needsInterpolation="fragment"===e.shaderStage),r}setup(e){this.setupVarying(e),e.flowNodeFromShaderStage(Os.VERTEX,this.node)}analyze(e){this.setupVarying(e),e.flowNodeFromShaderStage(Os.VERTEX,this.node)}generate(e){const t=e.getSubBuildProperty("property",e.currentStack),r=e.getNodeProperties(this),s=this.setupVarying(e);if(void 0===r[t]){const i=this.getNodeType(e),n=e.getPropertyName(s,Os.VERTEX);e.flowNodeFromShaderStage(Os.VERTEX,r.node,i,n),r[t]=n}return e.getPropertyName(s)}}const fu=Gi(mu).setParameterLength(1,2),yu=e=>fu(e);di("toVarying",fu),di("toVertexStage",yu),di("varying",(...e)=>(console.warn("THREE.TSL: .varying() has been renamed to .toVarying()."),fu(...e))),di("vertexStage",(...e)=>(console.warn("THREE.TSL: .vertexStage() has been renamed to .toVertexStage()."),fu(...e)));const bu=ji(([e])=>{const t=e.mul(.9478672986).add(.0521327014).pow(2.4),r=e.mul(.0773993808),s=e.lessThanEqual(.04045);return zo(t,r,s)}).setLayout({name:"sRGBTransferEOTF",type:"vec3",inputs:[{name:"color",type:"vec3"}]}),xu=ji(([e])=>{const t=e.pow(.41666).mul(1.055).sub(.055),r=e.mul(12.92),s=e.lessThanEqual(.0031308);return zo(t,r,s)}).setLayout({name:"sRGBTransferOETF",type:"vec3",inputs:[{name:"color",type:"vec3"}]}),Tu="WorkingColorSpace";class _u extends Zs{static get type(){return"ColorSpaceNode"}constructor(e,t,r){super("vec4"),this.colorNode=e,this.source=t,this.target=r}resolveColorSpace(e,t){return t===Tu?c.workingColorSpace:"OutputColorSpace"===t?e.context.outputColorSpace||e.renderer.outputColorSpace:t}setup(e){const{colorNode:t}=this,r=this.resolveColorSpace(e,this.source),s=this.resolveColorSpace(e,this.target);let i=t;return!1!==c.enabled&&r!==s&&r&&s?(c.getTransfer(r)===h&&(i=cn(bu(i.rgb),i.a)),c.getPrimaries(r)!==c.getPrimaries(s)&&(i=cn(fn(c._getMatrix(new n,r,s)).mul(i.rgb),i.a)),c.getTransfer(s)===h&&(i=cn(xu(i.rgb),i.a)),i):i}}const vu=(e,t)=>Vi(new _u(Vi(e),Tu,t)),Nu=(e,t)=>Vi(new _u(Vi(e),t,Tu));di("workingToColorSpace",vu),di("colorSpaceToWorking",Nu);let Su=class extends Ys{static get type(){return"ReferenceElementNode"}constructor(e,t){super(e,t),this.referenceNode=e,this.isReferenceElementNode=!0}getNodeType(){return this.referenceNode.uniformType}generate(e){const t=super.generate(e),r=this.referenceNode.getNodeType(),s=this.getNodeType();return e.format(t,r,s)}};class Eu extends Ks{static get type(){return"ReferenceBaseNode"}constructor(e,t,r=null,s=null){super(),this.property=e,this.uniformType=t,this.object=r,this.count=s,this.properties=e.split("."),this.reference=r,this.node=null,this.group=null,this.updateType=ks.OBJECT}setGroup(e){return this.group=e,this}element(e){return Vi(new Su(this,Vi(e)))}setNodeType(e){const t=ia(null,e).getSelf();null!==this.group&&t.setGroup(this.group),this.node=t}getNodeType(e){return null===this.node&&(this.updateReference(e),this.updateValue()),this.node.getNodeType(e)}getValueFromReference(e=this.reference){const{properties:t}=this;let r=e[t[0]];for(let e=1;eVi(new wu(e,t,r));class Ru extends Zs{static get type(){return"ToneMappingNode"}constructor(e,t=Mu,r=null){super("vec3"),this.toneMapping=e,this.exposureNode=t,this.colorNode=r}customCacheKey(){return Ns(this.toneMapping)}setup(e){const t=this.colorNode||e.context.color,r=this.toneMapping;if(r===p)return t;let s=null;const i=e.renderer.library.getToneMappingFunction(r);return null!==i?s=cn(i(t.rgb,this.exposureNode),t.a):(console.error("ToneMappingNode: Unsupported Tone Mapping configuration.",r),s=t),s}}const Cu=(e,t,r)=>Vi(new Ru(e,Vi(t),Vi(r))),Mu=Au("toneMappingExposure","float");di("toneMapping",(e,t,r)=>Cu(t,r,e));class Pu extends ii{static get type(){return"BufferAttributeNode"}constructor(e,t=null,r=0,s=0){super(e,t),this.isBufferNode=!0,this.bufferType=t,this.bufferStride=r,this.bufferOffset=s,this.usage=g,this.instanced=!1,this.attribute=null,this.global=!0,e&&!0===e.isBufferAttribute&&(this.attribute=e,this.usage=e.usage,this.instanced=e.isInstancedBufferAttribute)}getHash(e){if(0===this.bufferStride&&0===this.bufferOffset){let t=e.globalCache.getData(this.value);return void 0===t&&(t={node:this},e.globalCache.setData(this.value,t)),t.node.uuid}return this.uuid}getNodeType(e){return null===this.bufferType&&(this.bufferType=e.getTypeFromAttribute(this.attribute)),this.bufferType}setup(e){if(null!==this.attribute)return;const t=this.getNodeType(e),r=this.value,s=e.getTypeLength(t),i=this.bufferStride||s,n=this.bufferOffset,a=!0===r.isInterleavedBuffer?r:new m(r,i),o=new f(a,s,n);a.setUsage(this.usage),this.attribute=o,this.attribute.isInstancedBufferAttribute=this.instanced}generate(e){const t=this.getNodeType(e),r=e.getBufferAttributeFromNode(this,t),s=e.getPropertyName(r);let i=null;if("vertex"===e.shaderStage||"compute"===e.shaderStage)this.name=s,i=s;else{i=fu(this).build(e,t)}return i}getInputType(){return"bufferAttribute"}setUsage(e){return this.usage=e,this.attribute&&!0===this.attribute.isBufferAttribute&&(this.attribute.usage=e),this}setInstanced(e){return this.instanced=e,this}}const Bu=(e,t=null,r=0,s=0)=>Vi(new Pu(e,t,r,s)),Fu=(e,t=null,r=0,s=0)=>Bu(e,t,r,s).setUsage(y),Lu=(e,t=null,r=0,s=0)=>Bu(e,t,r,s).setInstanced(!0),Iu=(e,t=null,r=0,s=0)=>Fu(e,t,r,s).setInstanced(!0);di("toAttribute",e=>Bu(e.value));class Du extends Ks{static get type(){return"ComputeNode"}constructor(e,t){super("void"),this.isComputeNode=!0,this.computeNode=e,this.workgroupSize=t,this.count=null,this.version=1,this.name="",this.updateBeforeType=ks.OBJECT,this.onInitFunction=null}setCount(e){return this.count=e,this}getCount(){return this.count}dispose(){this.dispatchEvent({type:"dispose"})}setName(e){return this.name=e,this}label(e){return console.warn('THREE.TSL: "label()" has been deprecated. Use "setName()" instead.'),this.setName(e)}onInit(e){return this.onInitFunction=e,this}updateBefore({renderer:e}){e.compute(this)}setup(e){const t=this.computeNode.build(e);if(t){e.getNodeProperties(this).outputComputeNode=t.outputNode,t.outputNode=null}return t}generate(e,t){const{shaderStage:r}=e;if("compute"===r){const t=this.computeNode.build(e,"void");""!==t&&e.addLineFlowCode(t,this)}else{const r=e.getNodeProperties(this).outputComputeNode;if(r)return r.build(e,t)}}}const Vu=(e,t=[64])=>{(0===t.length||t.length>3)&&console.error("THREE.TSL: compute() workgroupSize must have 1, 2, or 3 elements");for(let e=0;eVu(e,r).setCount(t);di("compute",Uu),di("computeKernel",Vu);class Ou extends Ks{static get type(){return"CacheNode"}constructor(e,t=!0){super(),this.node=e,this.parent=t,this.isCacheNode=!0}getNodeType(e){const t=e.getCache(),r=e.getCacheFromNode(this,this.parent);e.setCache(r);const s=this.node.getNodeType(e);return e.setCache(t),s}build(e,...t){const r=e.getCache(),s=e.getCacheFromNode(this,this.parent);e.setCache(s);const i=this.node.build(e,...t);return e.setCache(r),i}}const ku=(e,t)=>Vi(new Ou(Vi(e),t));di("cache",ku);class Gu extends Ks{static get type(){return"BypassNode"}constructor(e,t){super(),this.isBypassNode=!0,this.outputNode=e,this.callNode=t}getNodeType(e){return this.outputNode.getNodeType(e)}generate(e){const t=this.callNode.build(e,"void");return""!==t&&e.addLineFlowCode(t,this),this.outputNode.build(e)}}const zu=Gi(Gu).setParameterLength(2);di("bypass",zu);class Hu extends Ks{static get type(){return"RemapNode"}constructor(e,t,r,s=Zi(0),i=Zi(1)){super(),this.node=e,this.inLowNode=t,this.inHighNode=r,this.outLowNode=s,this.outHighNode=i,this.doClamp=!0}setup(){const{node:e,inLowNode:t,inHighNode:r,outLowNode:s,outHighNode:i,doClamp:n}=this;let a=e.sub(t).div(r.sub(t));return!0===n&&(a=a.clamp()),a.mul(i.sub(s)).add(s)}}const $u=Gi(Hu,null,null,{doClamp:!1}).setParameterLength(3,5),Wu=Gi(Hu).setParameterLength(3,5);di("remap",$u),di("remapClamp",Wu);class ju extends Ks{static get type(){return"ExpressionNode"}constructor(e="",t="void"){super(t),this.snippet=e}generate(e,t){const r=this.getNodeType(e),s=this.snippet;if("void"!==r)return e.format(s,r,t);e.addLineFlowCode(s,this)}}const qu=Gi(ju).setParameterLength(1,2),Xu=e=>(e?ru(e,qu("discard")):qu("discard")).toStack();di("discard",Xu);class Ku extends Zs{static get type(){return"RenderOutputNode"}constructor(e,t,r){super("vec4"),this.colorNode=e,this.toneMapping=t,this.outputColorSpace=r,this.isRenderOutputNode=!0}setup({context:e}){let t=this.colorNode||e.color;const r=(null!==this.toneMapping?this.toneMapping:e.toneMapping)||p,s=(null!==this.outputColorSpace?this.outputColorSpace:e.outputColorSpace)||b;return r!==p&&(t=t.toneMapping(r)),s!==b&&s!==c.workingColorSpace&&(t=t.workingToColorSpace(s)),t}}const Yu=(e,t=null,r=null)=>Vi(new Ku(Vi(e),t,r));di("renderOutput",Yu);class Qu extends Zs{static get type(){return"DebugNode"}constructor(e,t=null){super(),this.node=e,this.callback=t}getNodeType(e){return this.node.getNodeType(e)}setup(e){return this.node.build(e)}analyze(e){return this.node.build(e)}generate(e){const t=this.callback,r=this.node.build(e),s="--- TSL debug - "+e.shaderStage+" shader ---",i="-".repeat(s.length);let n="";return n+="// #"+s+"#\n",n+=e.flow.code.replace(/^\t/gm,"")+"\n",n+="/* ... */ "+r+" /* ... */\n",n+="// #"+i+"#\n",null!==t?t(e,n):console.log(n),r}}const Zu=(e,t=null)=>Vi(new Qu(Vi(e),t)).toStack();di("debug",Zu);class Ju extends Ks{static get type(){return"AttributeNode"}constructor(e,t=null){super(t),this.global=!0,this._attributeName=e}getHash(e){return this.getAttributeName(e)}getNodeType(e){let t=this.nodeType;if(null===t){const r=this.getAttributeName(e);if(e.hasGeometryAttribute(r)){const s=e.geometry.getAttribute(r);t=e.getTypeFromAttribute(s)}else t="float"}return t}setAttributeName(e){return this._attributeName=e,this}getAttributeName(){return this._attributeName}generate(e){const t=this.getAttributeName(e),r=this.getNodeType(e);if(!0===e.hasGeometryAttribute(t)){const s=e.geometry.getAttribute(t),i=e.getTypeFromAttribute(s),n=e.getAttribute(t,i);if("vertex"===e.shaderStage)return e.format(n.name,i,r);return fu(this).build(e,r)}return console.warn(`AttributeNode: Vertex attribute "${t}" not found on geometry.`),e.generateConst(r)}serialize(e){super.serialize(e),e.global=this.global,e._attributeName=this._attributeName}deserialize(e){super.deserialize(e),this.global=e.global,this._attributeName=e._attributeName}}const el=(e,t=null)=>Vi(new Ju(e,t)),tl=(e=0)=>el("uv"+(e>0?e:""),"vec2");class rl extends Ks{static get type(){return"TextureSizeNode"}constructor(e,t=null){super("uvec2"),this.isTextureSizeNode=!0,this.textureNode=e,this.levelNode=t}generate(e,t){const r=this.textureNode.build(e,"property"),s=null===this.levelNode?"0":this.levelNode.build(e,"int");return e.format(`${e.getMethod("textureDimensions")}( ${r}, ${s} )`,this.getNodeType(e),t)}}const sl=Gi(rl).setParameterLength(1,2);class il extends sa{static get type(){return"MaxMipLevelNode"}constructor(e){super(0),this._textureNode=e,this.updateType=ks.FRAME}get textureNode(){return this._textureNode}get texture(){return this._textureNode.value}update(){const e=this.texture,t=e.images,r=t&&t.length>0?t[0]&&t[0].image||t[0]:e.image;if(r&&void 0!==r.width){const{width:e,height:t}=r;this.value=Math.log2(Math.max(e,t))}}}const nl=Gi(il).setParameterLength(1),al=new x;class ol extends sa{static get type(){return"TextureNode"}constructor(e=al,t=null,r=null,s=null){super(e),this.isTextureNode=!0,this.uvNode=t,this.levelNode=r,this.biasNode=s,this.compareNode=null,this.depthNode=null,this.gradNode=null,this.sampler=!0,this.updateMatrix=!1,this.updateType=ks.NONE,this.referenceNode=null,this._value=e,this._matrixUniform=null,this.setUpdateMatrix(null===t)}set value(e){this.referenceNode?this.referenceNode.value=e:this._value=e}get value(){return this.referenceNode?this.referenceNode.value:this._value}getUniformHash(){return this.value.uuid}getNodeType(){return!0===this.value.isDepthTexture?"float":this.value.type===T?"uvec4":this.value.type===_?"ivec4":"vec4"}getInputType(){return"texture"}getDefaultUV(){return tl(this.value.channel)}updateReference(){return this.value}getTransformedUV(e){return null===this._matrixUniform&&(this._matrixUniform=ia(this.value.matrix)),this._matrixUniform.mul(on(e,1)).xy}setUpdateMatrix(e){return this.updateMatrix=e,this.updateType=e?ks.OBJECT:ks.NONE,this}setupUV(e,t){const r=this.value;return e.isFlipY()&&(r.image instanceof ImageBitmap&&!0===r.flipY||!0===r.isRenderTargetTexture||!0===r.isFramebufferTexture||!0===r.isDepthTexture)&&(t=this.sampler?t.flipY():t.setY(Ji(sl(this,this.levelNode).y).sub(t.y).sub(1))),t}setup(e){const t=e.getNodeProperties(this);t.referenceNode=this.referenceNode;const r=this.value;if(!r||!0!==r.isTexture)throw new Error("THREE.TSL: `texture( value )` function expects a valid instance of THREE.Texture().");let s=this.uvNode;null!==s&&!0!==e.context.forceUVContext||!e.context.getUV||(s=e.context.getUV(this,e)),s||(s=this.getDefaultUV()),!0===this.updateMatrix&&(s=this.getTransformedUV(s)),s=this.setupUV(e,s);let i=this.levelNode;null===i&&e.context.getTextureLevel&&(i=e.context.getTextureLevel(this)),t.uvNode=s,t.levelNode=i,t.biasNode=this.biasNode,t.compareNode=this.compareNode,t.gradNode=this.gradNode,t.depthNode=this.depthNode}generateUV(e,t){return t.build(e,!0===this.sampler?"vec2":"ivec2")}generateSnippet(e,t,r,s,i,n,a,o){const u=this.value;let l;return l=s?e.generateTextureLevel(u,t,r,s,n):i?e.generateTextureBias(u,t,r,i,n):o?e.generateTextureGrad(u,t,r,o,n):a?e.generateTextureCompare(u,t,r,a,n):!1===this.sampler?e.generateTextureLoad(u,t,r,n):e.generateTexture(u,t,r,n),l}generate(e,t){const r=this.value,s=e.getNodeProperties(this),i=super.generate(e,"property");if(/^sampler/.test(t))return i+"_sampler";if(e.isReference(t))return i;{const n=e.getDataFromNode(this);let a=n.propertyName;if(void 0===a){const{uvNode:t,levelNode:r,biasNode:o,compareNode:u,depthNode:l,gradNode:d}=s,c=this.generateUV(e,t),h=r?r.build(e,"float"):null,p=o?o.build(e,"float"):null,g=l?l.build(e,"int"):null,m=u?u.build(e,"float"):null,f=d?[d[0].build(e,"vec2"),d[1].build(e,"vec2")]:null,y=e.getVarFromNode(this);a=e.getPropertyName(y);const b=this.generateSnippet(e,i,c,h,p,g,m,f);e.addLineFlowCode(`${a} = ${b}`,this),n.snippet=b,n.propertyName=a}let o=a;const u=this.getNodeType(e);return e.needsToWorkingColorSpace(r)&&(o=Nu(qu(o,u),r.colorSpace).setup(e).build(e,u)),e.format(o,u,t)}}setSampler(e){return this.sampler=e,this}getSampler(){return this.sampler}uv(e){return console.warn("THREE.TextureNode: .uv() has been renamed. Use .sample() instead."),this.sample(e)}sample(e){const t=this.clone();return t.uvNode=Vi(e),t.referenceNode=this.getBase(),Vi(t)}load(e){return this.sample(e).setSampler(!1)}blur(e){const t=this.clone();t.biasNode=Vi(e).mul(nl(t)),t.referenceNode=this.getBase();const r=t.value;return!1===t.generateMipmaps&&(r&&!1===r.generateMipmaps||r.minFilter===v||r.magFilter===v)&&(console.warn("THREE.TSL: texture().blur() requires mipmaps and sampling. Use .generateMipmaps=true and .minFilter/.magFilter=THREE.LinearFilter in the Texture."),t.biasNode=null),Vi(t)}level(e){const t=this.clone();return t.levelNode=Vi(e),t.referenceNode=this.getBase(),Vi(t)}size(e){return sl(this,e)}bias(e){const t=this.clone();return t.biasNode=Vi(e),t.referenceNode=this.getBase(),Vi(t)}getBase(){return this.referenceNode?this.referenceNode.getBase():this.getSelf()}compare(e){const t=this.clone();return t.compareNode=Vi(e),t.referenceNode=this.getBase(),Vi(t)}grad(e,t){const r=this.clone();return r.gradNode=[Vi(e),Vi(t)],r.referenceNode=this.getBase(),Vi(r)}depth(e){const t=this.clone();return t.depthNode=Vi(e),t.referenceNode=this.getBase(),Vi(t)}serialize(e){super.serialize(e),e.value=this.value.toJSON(e.meta).uuid,e.sampler=this.sampler,e.updateMatrix=this.updateMatrix,e.updateType=this.updateType}deserialize(e){super.deserialize(e),this.value=e.meta.textures[e.value],this.sampler=e.sampler,this.updateMatrix=e.updateMatrix,this.updateType=e.updateType}update(){const e=this.value,t=this._matrixUniform;null!==t&&(t.value=e.matrix),!0===e.matrixAutoUpdate&&e.updateMatrix()}clone(){const e=new this.constructor(this.value,this.uvNode,this.levelNode,this.biasNode);return e.sampler=this.sampler,e.depthNode=this.depthNode,e.compareNode=this.compareNode,e.gradNode=this.gradNode,e}}const ul=Gi(ol).setParameterLength(1,4).setName("texture"),ll=(e=al,t=null,r=null,s=null)=>{let i;return e&&!0===e.isTextureNode?(i=Vi(e.clone()),i.referenceNode=e.getBase(),null!==t&&(i.uvNode=Vi(t)),null!==r&&(i.levelNode=Vi(r)),null!==s&&(i.biasNode=Vi(s))):i=ul(e,t,r,s),i},dl=(...e)=>ll(...e).setSampler(!1);class cl extends sa{static get type(){return"BufferNode"}constructor(e,t,r=0){super(e,t),this.isBufferNode=!0,this.bufferType=t,this.bufferCount=r}getElementType(e){return this.getNodeType(e)}getInputType(){return"buffer"}}const hl=(e,t,r)=>Vi(new cl(e,t,r));class pl extends Ys{static get type(){return"UniformArrayElementNode"}constructor(e,t){super(e,t),this.isArrayBufferElementNode=!0}generate(e){const t=super.generate(e),r=this.getNodeType(),s=this.node.getPaddedType();return e.format(t,s,r)}}class gl extends cl{static get type(){return"UniformArrayNode"}constructor(e,t=null){super(null),this.array=e,this.elementType=null===t?Fs(e[0]):t,this.paddedType=this.getPaddedType(),this.updateType=ks.RENDER,this.isArrayBufferNode=!0}getNodeType(){return this.paddedType}getElementType(){return this.elementType}getPaddedType(){const e=this.elementType;let t="vec4";return"mat2"===e?t="mat2":!0===/mat/.test(e)?t="mat4":"i"===e.charAt(0)?t="ivec4":"u"===e.charAt(0)&&(t="uvec4"),t}update(){const{array:e,value:t}=this,r=this.elementType;if("float"===r||"int"===r||"uint"===r)for(let r=0;rVi(new gl(e,t));const fl=Gi(class extends Ks{constructor(e){super("float"),this.name=e,this.isBuiltinNode=!0}generate(){return this.name}}).setParameterLength(1);let yl,bl;class xl extends Ks{static get type(){return"ScreenNode"}constructor(e){super(),this.scope=e,this.isViewportNode=!0}getNodeType(){return this.scope===xl.VIEWPORT?"vec4":"vec2"}getUpdateType(){let e=ks.NONE;return this.scope!==xl.SIZE&&this.scope!==xl.VIEWPORT||(e=ks.RENDER),this.updateType=e,e}update({renderer:e}){const t=e.getRenderTarget();this.scope===xl.VIEWPORT?null!==t?bl.copy(t.viewport):(e.getViewport(bl),bl.multiplyScalar(e.getPixelRatio())):null!==t?(yl.width=t.width,yl.height=t.height):e.getDrawingBufferSize(yl)}setup(){const e=this.scope;let r=null;return r=e===xl.SIZE?ia(yl||(yl=new t)):e===xl.VIEWPORT?ia(bl||(bl=new s)):rn(vl.div(_l)),r}generate(e){if(this.scope===xl.COORDINATE){let t=e.getFragCoord();if(e.isFlipY()){const r=e.getNodeProperties(_l).outputNode.build(e);t=`${e.getType("vec2")}( ${t}.x, ${r}.y - ${t}.y )`}return t}return super.generate(e)}}xl.COORDINATE="coordinate",xl.VIEWPORT="viewport",xl.SIZE="size",xl.UV="uv";const Tl=zi(xl,xl.UV),_l=zi(xl,xl.SIZE),vl=zi(xl,xl.COORDINATE),Nl=zi(xl,xl.VIEWPORT),Sl=Nl.zw,El=vl.sub(Nl.xy),wl=El.div(Sl),Al=ji(()=>(console.warn('THREE.TSL: "viewportResolution" is deprecated. Use "screenSize" instead.'),_l),"vec2").once()(),Rl=ia(0,"uint").setName("u_cameraIndex").setGroup(Jn("cameraIndex")).toVarying("v_cameraIndex"),Cl=ia("float").setName("cameraNear").setGroup(ta).onRenderUpdate(({camera:e})=>e.near),Ml=ia("float").setName("cameraFar").setGroup(ta).onRenderUpdate(({camera:e})=>e.far),Pl=ji(({camera:e})=>{let t;if(e.isArrayCamera&&e.cameras.length>0){const r=[];for(const t of e.cameras)r.push(t.projectionMatrix);t=ml(r).setGroup(ta).setName("cameraProjectionMatrices").element(e.isMultiViewCamera?fl("gl_ViewID_OVR"):Rl).toConst("cameraProjectionMatrix")}else t=ia("mat4").setName("cameraProjectionMatrix").setGroup(ta).onRenderUpdate(({camera:e})=>e.projectionMatrix);return t}).once()(),Bl=ji(({camera:e})=>{let t;if(e.isArrayCamera&&e.cameras.length>0){const r=[];for(const t of e.cameras)r.push(t.projectionMatrixInverse);t=ml(r).setGroup(ta).setName("cameraProjectionMatricesInverse").element(e.isMultiViewCamera?fl("gl_ViewID_OVR"):Rl).toConst("cameraProjectionMatrixInverse")}else t=ia("mat4").setName("cameraProjectionMatrixInverse").setGroup(ta).onRenderUpdate(({camera:e})=>e.projectionMatrixInverse);return t}).once()(),Fl=ji(({camera:e})=>{let t;if(e.isArrayCamera&&e.cameras.length>0){const r=[];for(const t of e.cameras)r.push(t.matrixWorldInverse);t=ml(r).setGroup(ta).setName("cameraViewMatrices").element(e.isMultiViewCamera?fl("gl_ViewID_OVR"):Rl).toConst("cameraViewMatrix")}else t=ia("mat4").setName("cameraViewMatrix").setGroup(ta).onRenderUpdate(({camera:e})=>e.matrixWorldInverse);return t}).once()(),Ll=ji(({camera:e})=>{let t;if(e.isArrayCamera&&e.cameras.length>0){const r=[];for(const t of e.cameras)r.push(t.matrixWorld);t=ml(r).setGroup(ta).setName("cameraWorldMatrices").element(e.isMultiViewCamera?fl("gl_ViewID_OVR"):Rl).toConst("cameraWorldMatrix")}else t=ia("mat4").setName("cameraWorldMatrix").setGroup(ta).onRenderUpdate(({camera:e})=>e.matrixWorld);return t}).once()(),Il=ji(({camera:e})=>{let t;if(e.isArrayCamera&&e.cameras.length>0){const r=[];for(const t of e.cameras)r.push(t.normalMatrix);t=ml(r).setGroup(ta).setName("cameraNormalMatrices").element(e.isMultiViewCamera?fl("gl_ViewID_OVR"):Rl).toConst("cameraNormalMatrix")}else t=ia("mat3").setName("cameraNormalMatrix").setGroup(ta).onRenderUpdate(({camera:e})=>e.normalMatrix);return t}).once()(),Dl=ji(({camera:e})=>{let t;if(e.isArrayCamera&&e.cameras.length>0){const s=[];for(let t=0,i=e.cameras.length;t{const r=e.cameras,s=t.array;for(let e=0,t=r.length;et.value.setFromMatrixPosition(e.matrixWorld));return t}).once()(),Vl=ji(({camera:e})=>{let t;if(e.isArrayCamera&&e.cameras.length>0){const r=[];for(const t of e.cameras)r.push(t.viewport);t=ml(r,"vec4").setGroup(ta).setName("cameraViewports").element(Rl).toConst("cameraViewport")}else t=cn(0,0,_l.x,_l.y).toConst("cameraViewport");return t}).once()(),Ul=new N;class Ol extends Ks{static get type(){return"Object3DNode"}constructor(e,t=null){super(),this.scope=e,this.object3d=t,this.updateType=ks.OBJECT,this.uniformNode=new sa(null)}getNodeType(){const e=this.scope;return e===Ol.WORLD_MATRIX?"mat4":e===Ol.POSITION||e===Ol.VIEW_POSITION||e===Ol.DIRECTION||e===Ol.SCALE?"vec3":e===Ol.RADIUS?"float":void 0}update(e){const t=this.object3d,s=this.uniformNode,i=this.scope;if(i===Ol.WORLD_MATRIX)s.value=t.matrixWorld;else if(i===Ol.POSITION)s.value=s.value||new r,s.value.setFromMatrixPosition(t.matrixWorld);else if(i===Ol.SCALE)s.value=s.value||new r,s.value.setFromMatrixScale(t.matrixWorld);else if(i===Ol.DIRECTION)s.value=s.value||new r,t.getWorldDirection(s.value);else if(i===Ol.VIEW_POSITION){const i=e.camera;s.value=s.value||new r,s.value.setFromMatrixPosition(t.matrixWorld),s.value.applyMatrix4(i.matrixWorldInverse)}else if(i===Ol.RADIUS){const r=e.object.geometry;null===r.boundingSphere&&r.computeBoundingSphere(),Ul.copy(r.boundingSphere).applyMatrix4(t.matrixWorld),s.value=Ul.radius}}generate(e){const t=this.scope;return t===Ol.WORLD_MATRIX?this.uniformNode.nodeType="mat4":t===Ol.POSITION||t===Ol.VIEW_POSITION||t===Ol.DIRECTION||t===Ol.SCALE?this.uniformNode.nodeType="vec3":t===Ol.RADIUS&&(this.uniformNode.nodeType="float"),this.uniformNode.build(e)}serialize(e){super.serialize(e),e.scope=this.scope}deserialize(e){super.deserialize(e),this.scope=e.scope}}Ol.WORLD_MATRIX="worldMatrix",Ol.POSITION="position",Ol.SCALE="scale",Ol.VIEW_POSITION="viewPosition",Ol.DIRECTION="direction",Ol.RADIUS="radius";const kl=Gi(Ol,Ol.DIRECTION).setParameterLength(1),Gl=Gi(Ol,Ol.WORLD_MATRIX).setParameterLength(1),zl=Gi(Ol,Ol.POSITION).setParameterLength(1),Hl=Gi(Ol,Ol.SCALE).setParameterLength(1),$l=Gi(Ol,Ol.VIEW_POSITION).setParameterLength(1),Wl=Gi(Ol,Ol.RADIUS).setParameterLength(1);class jl extends Ol{static get type(){return"ModelNode"}constructor(e){super(e)}update(e){this.object3d=e.object,super.update(e)}}const ql=zi(jl,jl.DIRECTION),Xl=zi(jl,jl.WORLD_MATRIX),Kl=zi(jl,jl.POSITION),Yl=zi(jl,jl.SCALE),Ql=zi(jl,jl.VIEW_POSITION),Zl=zi(jl,jl.RADIUS),Jl=ia(new n).onObjectUpdate(({object:e},t)=>t.value.getNormalMatrix(e.matrixWorld)),ed=ia(new a).onObjectUpdate(({object:e},t)=>t.value.copy(e.matrixWorld).invert()),td=ji(e=>e.renderer.overrideNodes.modelViewMatrix||rd).once()().toVar("modelViewMatrix"),rd=Fl.mul(Xl),sd=ji(e=>(e.context.isHighPrecisionModelViewMatrix=!0,ia("mat4").onObjectUpdate(({object:e,camera:t})=>e.modelViewMatrix.multiplyMatrices(t.matrixWorldInverse,e.matrixWorld)))).once()().toVar("highpModelViewMatrix"),id=ji(e=>{const t=e.context.isHighPrecisionModelViewMatrix;return ia("mat3").onObjectUpdate(({object:e,camera:r})=>(!0!==t&&e.modelViewMatrix.multiplyMatrices(r.matrixWorldInverse,e.matrixWorld),e.normalMatrix.getNormalMatrix(e.modelViewMatrix)))}).once()().toVar("highpModelNormalViewMatrix"),nd=el("position","vec3"),ad=nd.toVarying("positionLocal"),od=nd.toVarying("positionPrevious"),ud=ji(e=>Xl.mul(ad).xyz.toVarying(e.getSubBuildProperty("v_positionWorld")),"vec3").once(["POSITION"])(),ld=ji(()=>ad.transformDirection(Xl).toVarying("v_positionWorldDirection").normalize().toVar("positionWorldDirection"),"vec3").once(["POSITION"])(),dd=ji(e=>e.context.setupPositionView().toVarying("v_positionView"),"vec3").once(["POSITION"])(),cd=dd.negate().toVarying("v_positionViewDirection").normalize().toVar("positionViewDirection");class hd extends Ks{static get type(){return"FrontFacingNode"}constructor(){super("bool"),this.isFrontFacingNode=!0}generate(e){if("fragment"!==e.shaderStage)return"true";const{renderer:t,material:r}=e;return t.coordinateSystem===l&&r.side===S?"false":e.getFrontFacing()}}const pd=zi(hd),gd=Zi(pd).mul(2).sub(1),md=ji(([e],{material:t})=>{const r=t.side;return r===S?e=e.mul(-1):r===E&&(e=e.mul(gd)),e}),fd=el("normal","vec3"),yd=ji(e=>!1===e.geometry.hasAttribute("normal")?(console.warn('THREE.TSL: Vertex attribute "normal" not found on geometry.'),on(0,1,0)):fd,"vec3").once()().toVar("normalLocal"),bd=dd.dFdx().cross(dd.dFdy()).normalize().toVar("normalFlat"),xd=ji(e=>{let t;return t=!0===e.material.flatShading?bd:Ed(yd).toVarying("v_normalViewGeometry").normalize(),t},"vec3").once()().toVar("normalViewGeometry"),Td=ji(e=>{let t=xd.transformDirection(Fl);return!0!==e.material.flatShading&&(t=t.toVarying("v_normalWorldGeometry")),t.normalize().toVar("normalWorldGeometry")},"vec3").once()(),_d=ji(({subBuildFn:e,material:t,context:r})=>{let s;return"NORMAL"===e||"VERTEX"===e?(s=xd,!0!==t.flatShading&&(s=md(s))):s=r.setupNormal().context({getUV:null}),s},"vec3").once(["NORMAL","VERTEX"])().toVar("normalView"),vd=_d.transformDirection(Fl).toVar("normalWorld"),Nd=ji(({subBuildFn:e,context:t})=>{let r;return r="NORMAL"===e||"VERTEX"===e?_d:t.setupClearcoatNormal().context({getUV:null}),r},"vec3").once(["NORMAL","VERTEX"])().toVar("clearcoatNormalView"),Sd=ji(([e,t=Xl])=>{const r=fn(t),s=e.div(on(r[0].dot(r[0]),r[1].dot(r[1]),r[2].dot(r[2])));return r.mul(s).xyz}),Ed=ji(([e],t)=>{const r=t.renderer.overrideNodes.modelNormalViewMatrix;if(null!==r)return r.transformDirection(e);const s=Jl.mul(e);return Fl.transformDirection(s)}),wd=ji(()=>(console.warn('THREE.TSL: "transformedNormalView" is deprecated. Use "normalView" instead.'),_d)).once(["NORMAL","VERTEX"])(),Ad=ji(()=>(console.warn('THREE.TSL: "transformedNormalWorld" is deprecated. Use "normalWorld" instead.'),vd)).once(["NORMAL","VERTEX"])(),Rd=ji(()=>(console.warn('THREE.TSL: "transformedClearcoatNormalView" is deprecated. Use "clearcoatNormalView" instead.'),Nd)).once(["NORMAL","VERTEX"])(),Cd=new w,Md=new a,Pd=ia(0).onReference(({material:e})=>e).onObjectUpdate(({material:e})=>e.refractionRatio),Bd=ia(1).onReference(({material:e})=>e).onObjectUpdate(function({material:e,scene:t}){return e.envMap?e.envMapIntensity:t.environmentIntensity}),Fd=ia(new a).onReference(function(e){return e.material}).onObjectUpdate(function({material:e,scene:t}){const r=null!==t.environment&&null===e.envMap?t.environmentRotation:e.envMapRotation;return r?(Cd.copy(r),Md.makeRotationFromEuler(Cd)):Md.identity(),Md}),Ld=cd.negate().reflect(_d),Id=cd.negate().refract(_d,Pd),Dd=Ld.transformDirection(Fl).toVar("reflectVector"),Vd=Id.transformDirection(Fl).toVar("reflectVector"),Ud=new A;class Od extends ol{static get type(){return"CubeTextureNode"}constructor(e,t=null,r=null,s=null){super(e,t,r,s),this.isCubeTextureNode=!0}getInputType(){return"cubeTexture"}getDefaultUV(){const e=this.value;return e.mapping===R?Dd:e.mapping===C?Vd:(console.error('THREE.CubeTextureNode: Mapping "%s" not supported.',e.mapping),on(0,0,0))}setUpdateMatrix(){}setupUV(e,t){const r=this.value;return e.renderer.coordinateSystem!==d&&r.isRenderTargetTexture||(t=on(t.x.negate(),t.yz)),Fd.mul(t)}generateUV(e,t){return t.build(e,"vec3")}}const kd=Gi(Od).setParameterLength(1,4).setName("cubeTexture"),Gd=(e=Ud,t=null,r=null,s=null)=>{let i;return e&&!0===e.isCubeTextureNode?(i=Vi(e.clone()),i.referenceNode=e.getSelf(),null!==t&&(i.uvNode=Vi(t)),null!==r&&(i.levelNode=Vi(r)),null!==s&&(i.biasNode=Vi(s))):i=kd(e,t,r,s),i};class zd extends Ys{static get type(){return"ReferenceElementNode"}constructor(e,t){super(e,t),this.referenceNode=e,this.isReferenceElementNode=!0}getNodeType(){return this.referenceNode.uniformType}generate(e){const t=super.generate(e),r=this.referenceNode.getNodeType(),s=this.getNodeType();return e.format(t,r,s)}}class Hd extends Ks{static get type(){return"ReferenceNode"}constructor(e,t,r=null,s=null){super(),this.property=e,this.uniformType=t,this.object=r,this.count=s,this.properties=e.split("."),this.reference=r,this.node=null,this.group=null,this.name=null,this.updateType=ks.OBJECT}element(e){return Vi(new zd(this,Vi(e)))}setGroup(e){return this.group=e,this}setName(e){return this.name=e,this}label(e){return console.warn('THREE.TSL: "label()" has been deprecated. Use "setName()" instead.'),this.setName(e)}setNodeType(e){let t=null;t=null!==this.count?hl(null,e,this.count):Array.isArray(this.getValueFromReference())?ml(null,e):"texture"===e?ll(null):"cubeTexture"===e?Gd(null):ia(null,e),null!==this.group&&t.setGroup(this.group),null!==this.name&&t.setName(this.name),this.node=t.getSelf()}getNodeType(e){return null===this.node&&(this.updateReference(e),this.updateValue()),this.node.getNodeType(e)}getValueFromReference(e=this.reference){const{properties:t}=this;let r=e[t[0]];for(let e=1;eVi(new Hd(e,t,r)),Wd=(e,t,r,s)=>Vi(new Hd(e,t,s,r));class jd extends Hd{static get type(){return"MaterialReferenceNode"}constructor(e,t,r=null){super(e,t,r),this.material=r,this.isMaterialReferenceNode=!0}updateReference(e){return this.reference=null!==this.material?this.material:e.material,this.reference}}const qd=(e,t,r=null)=>Vi(new jd(e,t,r)),Xd=tl(),Kd=dd.dFdx(),Yd=dd.dFdy(),Qd=Xd.dFdx(),Zd=Xd.dFdy(),Jd=_d,ec=Yd.cross(Jd),tc=Jd.cross(Kd),rc=ec.mul(Qd.x).add(tc.mul(Zd.x)),sc=ec.mul(Qd.y).add(tc.mul(Zd.y)),ic=rc.dot(rc).max(sc.dot(sc)),nc=ic.equal(0).select(0,ic.inverseSqrt()),ac=rc.mul(nc).toVar("tangentViewFrame"),oc=sc.mul(nc).toVar("bitangentViewFrame"),uc=ji(e=>(!1===e.geometry.hasAttribute("tangent")&&e.geometry.computeTangents(),el("tangent","vec4")))(),lc=uc.xyz.toVar("tangentLocal"),dc=ji(({subBuildFn:e,geometry:t,material:r})=>{let s;return s="VERTEX"===e||t.hasAttribute("tangent")?td.mul(cn(lc,0)).xyz.toVarying("v_tangentView").normalize():ac,!0!==r.flatShading&&(s=md(s)),s},"vec3").once(["NORMAL","VERTEX"])().toVar("tangentView"),cc=dc.transformDirection(Fl).toVarying("v_tangentWorld").normalize().toVar("tangentWorld"),hc=ji(([e,t],{subBuildFn:r,material:s})=>{let i=e.mul(uc.w).xyz;return"NORMAL"===r&&!0!==s.flatShading&&(i=i.toVarying(t)),i}).once(["NORMAL"]),pc=hc(fd.cross(uc),"v_bitangentGeometry").normalize().toVar("bitangentGeometry"),gc=hc(yd.cross(lc),"v_bitangentLocal").normalize().toVar("bitangentLocal"),mc=ji(({subBuildFn:e,geometry:t,material:r})=>{let s;return s="VERTEX"===e||t.hasAttribute("tangent")?hc(_d.cross(dc),"v_bitangentView").normalize():oc,!0!==r.flatShading&&(s=md(s)),s},"vec3").once(["NORMAL","VERTEX"])().toVar("bitangentView"),fc=hc(vd.cross(cc),"v_bitangentWorld").normalize().toVar("bitangentWorld"),yc=fn(dc,mc,_d).toVar("TBNViewMatrix"),bc=cd.mul(yc),xc=ji(()=>{let e=Vn.cross(cd);return e=e.cross(Vn).normalize(),e=zo(e,_d,In.mul(En.oneMinus()).oneMinus().pow2().pow2()).normalize(),e}).once()();class Tc extends Zs{static get type(){return"NormalMapNode"}constructor(e,t=null){super("vec3"),this.node=e,this.scaleNode=t,this.normalMapType=M}setup({material:e}){const{normalMapType:t,scaleNode:r}=this;let s=this.node.mul(2).sub(1);if(null!==r){let t=r;!0===e.flatShading&&(t=md(t)),s=on(s.xy.mul(t),s.z)}let i=null;return t===P?i=Ed(s):t===M?i=yc.mul(s).normalize():(console.error(`THREE.NodeMaterial: Unsupported normal map type: ${t}`),i=_d),i}}const _c=Gi(Tc).setParameterLength(1,2),vc=ji(({textureNode:e,bumpScale:t})=>{const r=t=>e.cache().context({getUV:e=>t(e.uvNode||tl()),forceUVContext:!0}),s=Zi(r(e=>e));return rn(Zi(r(e=>e.add(e.dFdx()))).sub(s),Zi(r(e=>e.add(e.dFdy()))).sub(s)).mul(t)}),Nc=ji(e=>{const{surf_pos:t,surf_norm:r,dHdxy:s}=e,i=t.dFdx().normalize(),n=r,a=t.dFdy().normalize().cross(n),o=n.cross(i),u=i.dot(a).mul(gd),l=u.sign().mul(s.x.mul(a).add(s.y.mul(o)));return u.abs().mul(r).sub(l).normalize()});class Sc extends Zs{static get type(){return"BumpMapNode"}constructor(e,t=null){super("vec3"),this.textureNode=e,this.scaleNode=t}setup(){const e=null!==this.scaleNode?this.scaleNode:1,t=vc({textureNode:this.textureNode,bumpScale:e});return Nc({surf_pos:dd,surf_norm:_d,dHdxy:t})}}const Ec=Gi(Sc).setParameterLength(1,2),wc=new Map;class Ac extends Ks{static get type(){return"MaterialNode"}constructor(e){super(),this.scope=e}getCache(e,t){let r=wc.get(e);return void 0===r&&(r=qd(e,t),wc.set(e,r)),r}getFloat(e){return this.getCache(e,"float")}getColor(e){return this.getCache(e,"color")}getTexture(e){return this.getCache("map"===e?"map":e+"Map","texture")}setup(e){const t=e.context.material,r=this.scope;let s=null;if(r===Ac.COLOR){const e=void 0!==t.color?this.getColor(r):on();s=t.map&&!0===t.map.isTexture?e.mul(this.getTexture("map")):e}else if(r===Ac.OPACITY){const e=this.getFloat(r);s=t.alphaMap&&!0===t.alphaMap.isTexture?e.mul(this.getTexture("alpha")):e}else if(r===Ac.SPECULAR_STRENGTH)s=t.specularMap&&!0===t.specularMap.isTexture?this.getTexture("specular").r:Zi(1);else if(r===Ac.SPECULAR_INTENSITY){const e=this.getFloat(r);s=t.specularIntensityMap&&!0===t.specularIntensityMap.isTexture?e.mul(this.getTexture(r).a):e}else if(r===Ac.SPECULAR_COLOR){const e=this.getColor(r);s=t.specularColorMap&&!0===t.specularColorMap.isTexture?e.mul(this.getTexture(r).rgb):e}else if(r===Ac.ROUGHNESS){const e=this.getFloat(r);s=t.roughnessMap&&!0===t.roughnessMap.isTexture?e.mul(this.getTexture(r).g):e}else if(r===Ac.METALNESS){const e=this.getFloat(r);s=t.metalnessMap&&!0===t.metalnessMap.isTexture?e.mul(this.getTexture(r).b):e}else if(r===Ac.EMISSIVE){const e=this.getFloat("emissiveIntensity"),i=this.getColor(r).mul(e);s=t.emissiveMap&&!0===t.emissiveMap.isTexture?i.mul(this.getTexture(r)):i}else if(r===Ac.NORMAL)t.normalMap?(s=_c(this.getTexture("normal"),this.getCache("normalScale","vec2")),s.normalMapType=t.normalMapType):s=t.bumpMap?Ec(this.getTexture("bump").r,this.getFloat("bumpScale")):_d;else if(r===Ac.CLEARCOAT){const e=this.getFloat(r);s=t.clearcoatMap&&!0===t.clearcoatMap.isTexture?e.mul(this.getTexture(r).r):e}else if(r===Ac.CLEARCOAT_ROUGHNESS){const e=this.getFloat(r);s=t.clearcoatRoughnessMap&&!0===t.clearcoatRoughnessMap.isTexture?e.mul(this.getTexture(r).r):e}else if(r===Ac.CLEARCOAT_NORMAL)s=t.clearcoatNormalMap?_c(this.getTexture(r),this.getCache(r+"Scale","vec2")):_d;else if(r===Ac.SHEEN){const e=this.getColor("sheenColor").mul(this.getFloat("sheen"));s=t.sheenColorMap&&!0===t.sheenColorMap.isTexture?e.mul(this.getTexture("sheenColor").rgb):e}else if(r===Ac.SHEEN_ROUGHNESS){const e=this.getFloat(r);s=t.sheenRoughnessMap&&!0===t.sheenRoughnessMap.isTexture?e.mul(this.getTexture(r).a):e,s=s.clamp(.07,1)}else if(r===Ac.ANISOTROPY)if(t.anisotropyMap&&!0===t.anisotropyMap.isTexture){const e=this.getTexture(r);s=mn(ch.x,ch.y,ch.y.negate(),ch.x).mul(e.rg.mul(2).sub(rn(1)).normalize().mul(e.b))}else s=ch;else if(r===Ac.IRIDESCENCE_THICKNESS){const e=$d("1","float",t.iridescenceThicknessRange);if(t.iridescenceThicknessMap){const i=$d("0","float",t.iridescenceThicknessRange);s=e.sub(i).mul(this.getTexture(r).g).add(i)}else s=e}else if(r===Ac.TRANSMISSION){const e=this.getFloat(r);s=t.transmissionMap?e.mul(this.getTexture(r).r):e}else if(r===Ac.THICKNESS){const e=this.getFloat(r);s=t.thicknessMap?e.mul(this.getTexture(r).g):e}else if(r===Ac.IOR)s=this.getFloat(r);else if(r===Ac.LIGHT_MAP)s=this.getTexture(r).rgb.mul(this.getFloat("lightMapIntensity"));else if(r===Ac.AO)s=this.getTexture(r).r.sub(1).mul(this.getFloat("aoMapIntensity")).add(1);else if(r===Ac.LINE_DASH_OFFSET)s=t.dashOffset?this.getFloat(r):Zi(0);else{const t=this.getNodeType(e);s=this.getCache(r,t)}return s}}Ac.ALPHA_TEST="alphaTest",Ac.COLOR="color",Ac.OPACITY="opacity",Ac.SHININESS="shininess",Ac.SPECULAR="specular",Ac.SPECULAR_STRENGTH="specularStrength",Ac.SPECULAR_INTENSITY="specularIntensity",Ac.SPECULAR_COLOR="specularColor",Ac.REFLECTIVITY="reflectivity",Ac.ROUGHNESS="roughness",Ac.METALNESS="metalness",Ac.NORMAL="normal",Ac.CLEARCOAT="clearcoat",Ac.CLEARCOAT_ROUGHNESS="clearcoatRoughness",Ac.CLEARCOAT_NORMAL="clearcoatNormal",Ac.EMISSIVE="emissive",Ac.ROTATION="rotation",Ac.SHEEN="sheen",Ac.SHEEN_ROUGHNESS="sheenRoughness",Ac.ANISOTROPY="anisotropy",Ac.IRIDESCENCE="iridescence",Ac.IRIDESCENCE_IOR="iridescenceIOR",Ac.IRIDESCENCE_THICKNESS="iridescenceThickness",Ac.IOR="ior",Ac.TRANSMISSION="transmission",Ac.THICKNESS="thickness",Ac.ATTENUATION_DISTANCE="attenuationDistance",Ac.ATTENUATION_COLOR="attenuationColor",Ac.LINE_SCALE="scale",Ac.LINE_DASH_SIZE="dashSize",Ac.LINE_GAP_SIZE="gapSize",Ac.LINE_WIDTH="linewidth",Ac.LINE_DASH_OFFSET="dashOffset",Ac.POINT_SIZE="size",Ac.DISPERSION="dispersion",Ac.LIGHT_MAP="light",Ac.AO="ao";const Rc=zi(Ac,Ac.ALPHA_TEST),Cc=zi(Ac,Ac.COLOR),Mc=zi(Ac,Ac.SHININESS),Pc=zi(Ac,Ac.EMISSIVE),Bc=zi(Ac,Ac.OPACITY),Fc=zi(Ac,Ac.SPECULAR),Lc=zi(Ac,Ac.SPECULAR_INTENSITY),Ic=zi(Ac,Ac.SPECULAR_COLOR),Dc=zi(Ac,Ac.SPECULAR_STRENGTH),Vc=zi(Ac,Ac.REFLECTIVITY),Uc=zi(Ac,Ac.ROUGHNESS),Oc=zi(Ac,Ac.METALNESS),kc=zi(Ac,Ac.NORMAL),Gc=zi(Ac,Ac.CLEARCOAT),zc=zi(Ac,Ac.CLEARCOAT_ROUGHNESS),Hc=zi(Ac,Ac.CLEARCOAT_NORMAL),$c=zi(Ac,Ac.ROTATION),Wc=zi(Ac,Ac.SHEEN),jc=zi(Ac,Ac.SHEEN_ROUGHNESS),qc=zi(Ac,Ac.ANISOTROPY),Xc=zi(Ac,Ac.IRIDESCENCE),Kc=zi(Ac,Ac.IRIDESCENCE_IOR),Yc=zi(Ac,Ac.IRIDESCENCE_THICKNESS),Qc=zi(Ac,Ac.TRANSMISSION),Zc=zi(Ac,Ac.THICKNESS),Jc=zi(Ac,Ac.IOR),eh=zi(Ac,Ac.ATTENUATION_DISTANCE),th=zi(Ac,Ac.ATTENUATION_COLOR),rh=zi(Ac,Ac.LINE_SCALE),sh=zi(Ac,Ac.LINE_DASH_SIZE),ih=zi(Ac,Ac.LINE_GAP_SIZE),nh=zi(Ac,Ac.LINE_WIDTH),ah=zi(Ac,Ac.LINE_DASH_OFFSET),oh=zi(Ac,Ac.POINT_SIZE),uh=zi(Ac,Ac.DISPERSION),lh=zi(Ac,Ac.LIGHT_MAP),dh=zi(Ac,Ac.AO),ch=ia(new t).onReference(function(e){return e.material}).onRenderUpdate(function({material:e}){this.value.set(e.anisotropy*Math.cos(e.anisotropyRotation),e.anisotropy*Math.sin(e.anisotropyRotation))}),hh=ji(e=>e.context.setupModelViewProjection(),"vec4").once()().toVarying("v_modelViewProjection");class ph extends Ks{static get type(){return"IndexNode"}constructor(e){super("uint"),this.scope=e,this.isIndexNode=!0}generate(e){const t=this.getNodeType(e),r=this.scope;let s,i;if(r===ph.VERTEX)s=e.getVertexIndex();else if(r===ph.INSTANCE)s=e.getInstanceIndex();else if(r===ph.DRAW)s=e.getDrawIndex();else if(r===ph.INVOCATION_LOCAL)s=e.getInvocationLocalIndex();else if(r===ph.INVOCATION_SUBGROUP)s=e.getInvocationSubgroupIndex();else{if(r!==ph.SUBGROUP)throw new Error("THREE.IndexNode: Unknown scope: "+r);s=e.getSubgroupIndex()}if("vertex"===e.shaderStage||"compute"===e.shaderStage)i=s;else{i=fu(this).build(e,t)}return i}}ph.VERTEX="vertex",ph.INSTANCE="instance",ph.SUBGROUP="subgroup",ph.INVOCATION_LOCAL="invocationLocal",ph.INVOCATION_SUBGROUP="invocationSubgroup",ph.DRAW="draw";const gh=zi(ph,ph.VERTEX),mh=zi(ph,ph.INSTANCE),fh=zi(ph,ph.SUBGROUP),yh=zi(ph,ph.INVOCATION_SUBGROUP),bh=zi(ph,ph.INVOCATION_LOCAL),xh=zi(ph,ph.DRAW);class Th extends Ks{static get type(){return"InstanceNode"}constructor(e,t,r=null){super("void"),this.count=e,this.instanceMatrix=t,this.instanceColor=r,this.instanceMatrixNode=null,this.instanceColorNode=null,this.updateType=ks.FRAME,this.buffer=null,this.bufferColor=null}setup(e){const{instanceMatrix:t,instanceColor:r}=this,{count:s}=t;let{instanceMatrixNode:i,instanceColorNode:n}=this;if(null===i){if(s<=1e3)i=hl(t.array,"mat4",Math.max(s,1)).element(mh);else{const e=new B(t.array,16,1);this.buffer=e;const r=t.usage===y?Iu:Lu,s=[r(e,"vec4",16,0),r(e,"vec4",16,4),r(e,"vec4",16,8),r(e,"vec4",16,12)];i=yn(...s)}this.instanceMatrixNode=i}if(r&&null===n){const e=new F(r.array,3),t=r.usage===y?Iu:Lu;this.bufferColor=e,n=on(t(e,"vec3",3,0)),this.instanceColorNode=n}const a=i.mul(ad).xyz;if(ad.assign(a),e.hasGeometryAttribute("normal")){const e=Sd(yd,i);yd.assign(e)}null!==this.instanceColorNode&&vn("vec3","vInstanceColor").assign(this.instanceColorNode)}update(){this.instanceMatrix.usage!==y&&null!==this.buffer&&this.instanceMatrix.version!==this.buffer.version&&(this.buffer.version=this.instanceMatrix.version),this.instanceColor&&this.instanceColor.usage!==y&&null!==this.bufferColor&&this.instanceColor.version!==this.bufferColor.version&&(this.bufferColor.version=this.instanceColor.version)}}const _h=Gi(Th).setParameterLength(2,3);class vh extends Th{static get type(){return"InstancedMeshNode"}constructor(e){const{count:t,instanceMatrix:r,instanceColor:s}=e;super(t,r,s),this.instancedMesh=e}}const Nh=Gi(vh).setParameterLength(1);class Sh extends Ks{static get type(){return"BatchNode"}constructor(e){super("void"),this.batchMesh=e,this.batchingIdNode=null}setup(e){null===this.batchingIdNode&&(null===e.getDrawIndex()?this.batchingIdNode=mh:this.batchingIdNode=xh);const t=ji(([e])=>{const t=Ji(sl(dl(this.batchMesh._indirectTexture),0).x),r=Ji(e).mod(t),s=Ji(e).div(t);return dl(this.batchMesh._indirectTexture,sn(r,s)).x}).setLayout({name:"getIndirectIndex",type:"uint",inputs:[{name:"id",type:"int"}]}),r=t(Ji(this.batchingIdNode)),s=this.batchMesh._matricesTexture,i=Ji(sl(dl(s),0).x),n=Zi(r).mul(4).toInt().toVar(),a=n.mod(i),o=n.div(i),u=yn(dl(s,sn(a,o)),dl(s,sn(a.add(1),o)),dl(s,sn(a.add(2),o)),dl(s,sn(a.add(3),o))),l=this.batchMesh._colorsTexture;if(null!==l){const e=ji(([e])=>{const t=Ji(sl(dl(l),0).x),r=e,s=r.mod(t),i=r.div(t);return dl(l,sn(s,i)).rgb}).setLayout({name:"getBatchingColor",type:"vec3",inputs:[{name:"id",type:"int"}]}),t=e(r);vn("vec3","vBatchColor").assign(t)}const d=fn(u);ad.assign(u.mul(ad));const c=yd.div(on(d[0].dot(d[0]),d[1].dot(d[1]),d[2].dot(d[2]))),h=d.mul(c).xyz;yd.assign(h),e.hasGeometryAttribute("tangent")&&lc.mulAssign(d)}}const Eh=Gi(Sh).setParameterLength(1);class wh extends Ys{static get type(){return"StorageArrayElementNode"}constructor(e,t){super(e,t),this.isStorageArrayElementNode=!0}set storageBufferNode(e){this.node=e}get storageBufferNode(){return this.node}getMemberType(e,t){const r=this.storageBufferNode.structTypeNode;return r?r.getMemberType(e,t):"void"}setup(e){return!1===e.isAvailable("storageBuffer")&&!0===this.node.isPBO&&e.setupPBO(this.node),super.setup(e)}generate(e,t){let r;const s=e.context.assign;if(r=!1===e.isAvailable("storageBuffer")?!0!==this.node.isPBO||!0===s||!this.node.value.isInstancedBufferAttribute&&"compute"===e.shaderStage?this.node.build(e):e.generatePBO(this):super.generate(e),!0!==s){const s=this.getNodeType(e);r=e.format(r,s,t)}return r}}const Ah=Gi(wh).setParameterLength(2);class Rh extends cl{static get type(){return"StorageBufferNode"}constructor(e,t=null,r=0){let s,i=null;t&&t.isStruct?(s="struct",i=t.layout,(e.isStorageBufferAttribute||e.isStorageInstancedBufferAttribute)&&(r=e.count)):null===t&&(e.isStorageBufferAttribute||e.isStorageInstancedBufferAttribute)?(s=Rs(e.itemSize),r=e.count):s=t,super(e,s,r),this.isStorageBufferNode=!0,this.structTypeNode=i,this.access=zs.READ_WRITE,this.isAtomic=!1,this.isPBO=!1,this._attribute=null,this._varying=null,this.global=!0,!0!==e.isStorageBufferAttribute&&!0!==e.isStorageInstancedBufferAttribute&&(e.isInstancedBufferAttribute?e.isStorageInstancedBufferAttribute=!0:e.isStorageBufferAttribute=!0)}getHash(e){if(0===this.bufferCount){let t=e.globalCache.getData(this.value);return void 0===t&&(t={node:this},e.globalCache.setData(this.value,t)),t.node.uuid}return this.uuid}getInputType(){return this.value.isIndirectStorageBufferAttribute?"indirectStorageBuffer":"storageBuffer"}element(e){return Ah(this,e)}setPBO(e){return this.isPBO=e,this}getPBO(){return this.isPBO}setAccess(e){return this.access=e,this}toReadOnly(){return this.setAccess(zs.READ_ONLY)}setAtomic(e){return this.isAtomic=e,this}toAtomic(){return this.setAtomic(!0)}getAttributeData(){return null===this._attribute&&(this._attribute=Bu(this.value),this._varying=fu(this._attribute)),{attribute:this._attribute,varying:this._varying}}getNodeType(e){if(null!==this.structTypeNode)return this.structTypeNode.getNodeType(e);if(e.isAvailable("storageBuffer")||e.isAvailable("indirectStorageBuffer"))return super.getNodeType(e);const{attribute:t}=this.getAttributeData();return t.getNodeType(e)}getMemberType(e,t){return null!==this.structTypeNode?this.structTypeNode.getMemberType(e,t):"void"}generate(e){if(null!==this.structTypeNode&&this.structTypeNode.build(e),e.isAvailable("storageBuffer")||e.isAvailable("indirectStorageBuffer"))return super.generate(e);const{attribute:t,varying:r}=this.getAttributeData(),s=r.build(e);return e.registerTransform(s,t),s}}const Ch=(e,t=null,r=0)=>Vi(new Rh(e,t,r)),Mh=new WeakMap;class Ph extends Ks{static get type(){return"SkinningNode"}constructor(e){super("void"),this.skinnedMesh=e,this.updateType=ks.OBJECT,this.skinIndexNode=el("skinIndex","uvec4"),this.skinWeightNode=el("skinWeight","vec4"),this.bindMatrixNode=$d("bindMatrix","mat4"),this.bindMatrixInverseNode=$d("bindMatrixInverse","mat4"),this.boneMatricesNode=Wd("skeleton.boneMatrices","mat4",e.skeleton.bones.length),this.positionNode=ad,this.toPositionNode=ad,this.previousBoneMatricesNode=null}getSkinnedPosition(e=this.boneMatricesNode,t=this.positionNode){const{skinIndexNode:r,skinWeightNode:s,bindMatrixNode:i,bindMatrixInverseNode:n}=this,a=e.element(r.x),o=e.element(r.y),u=e.element(r.z),l=e.element(r.w),d=i.mul(t),c=pa(a.mul(s.x).mul(d),o.mul(s.y).mul(d),u.mul(s.z).mul(d),l.mul(s.w).mul(d));return n.mul(c).xyz}getSkinnedNormal(e=this.boneMatricesNode,t=yd){const{skinIndexNode:r,skinWeightNode:s,bindMatrixNode:i,bindMatrixInverseNode:n}=this,a=e.element(r.x),o=e.element(r.y),u=e.element(r.z),l=e.element(r.w);let d=pa(s.x.mul(a),s.y.mul(o),s.z.mul(u),s.w.mul(l));return d=n.mul(d).mul(i),d.transformDirection(t).xyz}getPreviousSkinnedPosition(e){const t=e.object;return null===this.previousBoneMatricesNode&&(t.skeleton.previousBoneMatrices=new Float32Array(t.skeleton.boneMatrices),this.previousBoneMatricesNode=Wd("skeleton.previousBoneMatrices","mat4",t.skeleton.bones.length)),this.getSkinnedPosition(this.previousBoneMatricesNode,od)}needsPreviousBoneMatrices(e){const t=e.renderer.getMRT();return t&&t.has("velocity")||!0===Is(e.object).useVelocity}setup(e){this.needsPreviousBoneMatrices(e)&&od.assign(this.getPreviousSkinnedPosition(e));const t=this.getSkinnedPosition();if(this.toPositionNode&&this.toPositionNode.assign(t),e.hasGeometryAttribute("normal")){const t=this.getSkinnedNormal();yd.assign(t),e.hasGeometryAttribute("tangent")&&lc.assign(t)}return t}generate(e,t){if("void"!==t)return super.generate(e,t)}update(e){const t=e.object&&e.object.skeleton?e.object.skeleton:this.skinnedMesh.skeleton;Mh.get(t)!==e.frameId&&(Mh.set(t,e.frameId),null!==this.previousBoneMatricesNode&&t.previousBoneMatrices.set(t.boneMatrices),t.update())}}const Bh=e=>Vi(new Ph(e));class Fh extends Ks{static get type(){return"LoopNode"}constructor(e=[]){super(),this.params=e}getVarName(e){return String.fromCharCode("i".charCodeAt(0)+e)}getProperties(e){const t=e.getNodeProperties(this);if(void 0!==t.stackNode)return t;const r={};for(let e=0,t=this.params.length-1;eNumber(u)?">=":"<")),a)n=`while ( ${u} )`;else{const r={start:o,end:u},s=r.start,i=r.end;let a;const p=()=>c.includes("<")?"+=":"-=";if(null!=h)switch(typeof h){case"function":a=e.flowStagesNode(t.updateNode,"void").code.replace(/\t|;/g,"");break;case"number":a=l+" "+p()+" "+e.generateConst(d,h);break;case"string":a=l+" "+h;break;default:h.isNode?a=l+" "+p()+" "+h.build(e):(console.error("THREE.TSL: 'Loop( { update: ... } )' is not a function, string or number."),a="break /* invalid update */")}else h="int"===d||"uint"===d?c.includes("<")?"++":"--":p()+" 1.",a=l+" "+h;n=`for ( ${e.getVar(d,l)+" = "+s}; ${l+" "+c+" "+i}; ${a} )`}e.addFlowCode((0===s?"\n":"")+e.tab+n+" {\n\n").addFlowTab()}const i=s.build(e,"void"),n=t.returnsNode?t.returnsNode.build(e):"";e.removeFlowTab().addFlowCode("\n"+e.tab+i);for(let t=0,r=this.params.length-1;tVi(new Fh(ki(e,"int"))).toStack(),Ih=()=>qu("break").toStack(),Dh=new WeakMap,Vh=new s,Uh=ji(({bufferMap:e,influence:t,stride:r,width:s,depth:i,offset:n})=>{const a=Ji(gh).mul(r).add(n),o=a.div(s),u=a.sub(o.mul(s));return dl(e,sn(u,o)).depth(i).xyz.mul(t)});class Oh extends Ks{static get type(){return"MorphNode"}constructor(e){super("void"),this.mesh=e,this.morphBaseInfluence=ia(1),this.updateType=ks.OBJECT}setup(e){const{geometry:r}=e,s=void 0!==r.morphAttributes.position,i=r.hasAttribute("normal")&&void 0!==r.morphAttributes.normal,n=r.morphAttributes.position||r.morphAttributes.normal||r.morphAttributes.color,a=void 0!==n?n.length:0,{texture:o,stride:u,size:l}=function(e){const r=void 0!==e.morphAttributes.position,s=void 0!==e.morphAttributes.normal,i=void 0!==e.morphAttributes.color,n=e.morphAttributes.position||e.morphAttributes.normal||e.morphAttributes.color,a=void 0!==n?n.length:0;let o=Dh.get(e);if(void 0===o||o.count!==a){void 0!==o&&o.texture.dispose();const u=e.morphAttributes.position||[],l=e.morphAttributes.normal||[],d=e.morphAttributes.color||[];let c=0;!0===r&&(c=1),!0===s&&(c=2),!0===i&&(c=3);let h=e.attributes.position.count*c,p=1;const g=4096;h>g&&(p=Math.ceil(h/g),h=g);const m=new Float32Array(h*p*4*a),f=new L(m,h,p,a);f.type=I,f.needsUpdate=!0;const y=4*c;for(let x=0;x{const t=Zi(0).toVar();this.mesh.count>1&&null!==this.mesh.morphTexture&&void 0!==this.mesh.morphTexture?t.assign(dl(this.mesh.morphTexture,sn(Ji(e).add(1),Ji(mh))).r):t.assign($d("morphTargetInfluences","float").element(e).toVar()),Ki(t.notEqual(0),()=>{!0===s&&ad.addAssign(Uh({bufferMap:o,influence:t,stride:u,width:d,depth:e,offset:Ji(0)})),!0===i&&yd.addAssign(Uh({bufferMap:o,influence:t,stride:u,width:d,depth:e,offset:Ji(1)}))})})}update(){const e=this.morphBaseInfluence;this.mesh.geometry.morphTargetsRelative?e.value=1:e.value=1-this.mesh.morphTargetInfluences.reduce((e,t)=>e+t,0)}}const kh=Gi(Oh).setParameterLength(1);class Gh extends Ks{static get type(){return"LightingNode"}constructor(){super("vec3"),this.isLightingNode=!0}}class zh extends Gh{static get type(){return"AONode"}constructor(e=null){super(),this.aoNode=e}setup(e){e.context.ambientOcclusion.mulAssign(this.aoNode)}}class Hh extends su{static get type(){return"LightingContextNode"}constructor(e,t=null,r=null,s=null){super(e),this.lightingModel=t,this.backdropNode=r,this.backdropAlphaNode=s,this._value=null}getContext(){const{backdropNode:e,backdropAlphaNode:t}=this,r={directDiffuse:on().toVar("directDiffuse"),directSpecular:on().toVar("directSpecular"),indirectDiffuse:on().toVar("indirectDiffuse"),indirectSpecular:on().toVar("indirectSpecular")};return{radiance:on().toVar("radiance"),irradiance:on().toVar("irradiance"),iblIrradiance:on().toVar("iblIrradiance"),ambientOcclusion:Zi(1).toVar("ambientOcclusion"),reflectedLight:r,backdrop:e,backdropAlpha:t}}setup(e){return this.value=this._value||(this._value=this.getContext()),this.value.lightingModel=this.lightingModel||e.context.lightingModel,super.setup(e)}}const $h=Gi(Hh);class Wh extends Gh{static get type(){return"IrradianceNode"}constructor(e){super(),this.node=e}setup(e){e.context.irradiance.addAssign(this.node)}}const jh=new t;class qh extends ol{static get type(){return"ViewportTextureNode"}constructor(e=Tl,t=null,r=null){let s=null;null===r?(s=new D,s.minFilter=V,r=s):s=r,super(r,e,t),this.generateMipmaps=!1,this.defaultFramebuffer=s,this.isOutputTextureNode=!0,this.updateBeforeType=ks.FRAME,this._cacheTextures=new WeakMap}getTextureForReference(e=null){let t,r;if(this.referenceNode?(t=this.referenceNode.defaultFramebuffer,r=this.referenceNode._cacheTextures):(t=this.defaultFramebuffer,r=this._cacheTextures),null===e)return t;if(!1===r.has(e)){const s=t.clone();r.set(e,s)}return r.get(e)}updateReference(e){const t=e.renderer.getRenderTarget();return this.value=this.getTextureForReference(t),this.value}updateBefore(e){const t=e.renderer,r=t.getRenderTarget();null===r?t.getDrawingBufferSize(jh):jh.set(r.width,r.height);const s=this.getTextureForReference(r);s.image.width===jh.width&&s.image.height===jh.height||(s.image.width=jh.width,s.image.height=jh.height,s.needsUpdate=!0);const i=s.generateMipmaps;s.generateMipmaps=this.generateMipmaps,t.copyFramebufferToTexture(s),s.generateMipmaps=i}clone(){const e=new this.constructor(this.uvNode,this.levelNode,this.value);return e.generateMipmaps=this.generateMipmaps,e}}const Xh=Gi(qh).setParameterLength(0,3),Kh=Gi(qh,null,null,{generateMipmaps:!0}).setParameterLength(0,3);let Yh=null;class Qh extends qh{static get type(){return"ViewportDepthTextureNode"}constructor(e=Tl,t=null){null===Yh&&(Yh=new U),super(e,t,Yh)}getTextureForReference(){return Yh}}const Zh=Gi(Qh).setParameterLength(0,2);class Jh extends Ks{static get type(){return"ViewportDepthNode"}constructor(e,t=null){super("float"),this.scope=e,this.valueNode=t,this.isViewportDepthNode=!0}generate(e){const{scope:t}=this;return t===Jh.DEPTH_BASE?e.getFragDepth():super.generate(e)}setup({camera:e}){const{scope:t}=this,r=this.valueNode;let s=null;if(t===Jh.DEPTH_BASE)null!==r&&(s=ip().assign(r));else if(t===Jh.DEPTH)s=e.isPerspectiveCamera?tp(dd.z,Cl,Ml):ep(dd.z,Cl,Ml);else if(t===Jh.LINEAR_DEPTH)if(null!==r)if(e.isPerspectiveCamera){const e=rp(r,Cl,Ml);s=ep(e,Cl,Ml)}else s=r;else s=ep(dd.z,Cl,Ml);return s}}Jh.DEPTH_BASE="depthBase",Jh.DEPTH="depth",Jh.LINEAR_DEPTH="linearDepth";const ep=(e,t,r)=>e.add(t).div(t.sub(r)),tp=(e,t,r)=>t.add(e).mul(r).div(r.sub(t).mul(e)),rp=(e,t,r)=>t.mul(r).div(r.sub(t).mul(e).sub(r)),sp=(e,t,r)=>{t=t.max(1e-6).toVar();const s=Qa(e.negate().div(t)),i=Qa(r.div(t));return s.div(i)},ip=Gi(Jh,Jh.DEPTH_BASE),np=zi(Jh,Jh.DEPTH),ap=Gi(Jh,Jh.LINEAR_DEPTH).setParameterLength(0,1),op=ap(Zh());np.assign=e=>ip(e);class up extends Ks{static get type(){return"ClippingNode"}constructor(e=up.DEFAULT){super(),this.scope=e}setup(e){super.setup(e);const t=e.clippingContext,{intersectionPlanes:r,unionPlanes:s}=t;return this.hardwareClipping=e.material.hardwareClipping,this.scope===up.ALPHA_TO_COVERAGE?this.setupAlphaToCoverage(r,s):this.scope===up.HARDWARE?this.setupHardwareClipping(s,e):this.setupDefault(r,s)}setupAlphaToCoverage(e,t){return ji(()=>{const r=Zi().toVar("distanceToPlane"),s=Zi().toVar("distanceToGradient"),i=Zi(1).toVar("clipOpacity"),n=t.length;if(!1===this.hardwareClipping&&n>0){const e=ml(t);Lh(n,({i:t})=>{const n=e.element(t);r.assign(dd.dot(n.xyz).negate().add(n.w)),s.assign(r.fwidth().div(2)),i.mulAssign(jo(s.negate(),s,r))})}const a=e.length;if(a>0){const t=ml(e),n=Zi(1).toVar("intersectionClipOpacity");Lh(a,({i:e})=>{const i=t.element(e);r.assign(dd.dot(i.xyz).negate().add(i.w)),s.assign(r.fwidth().div(2)),n.mulAssign(jo(s.negate(),s,r).oneMinus())}),i.mulAssign(n.oneMinus())}Nn.a.mulAssign(i),Nn.a.equal(0).discard()})()}setupDefault(e,t){return ji(()=>{const r=t.length;if(!1===this.hardwareClipping&&r>0){const e=ml(t);Lh(r,({i:t})=>{const r=e.element(t);dd.dot(r.xyz).greaterThan(r.w).discard()})}const s=e.length;if(s>0){const t=ml(e),r=tn(!0).toVar("clipped");Lh(s,({i:e})=>{const s=t.element(e);r.assign(dd.dot(s.xyz).greaterThan(s.w).and(r))}),r.discard()}})()}setupHardwareClipping(e,t){const r=e.length;return t.enableHardwareClipping(r),ji(()=>{const s=ml(e),i=fl(t.getClipDistance());Lh(r,({i:e})=>{const t=s.element(e),r=dd.dot(t.xyz).sub(t.w).negate();i.element(e).assign(r)})})()}}up.ALPHA_TO_COVERAGE="alphaToCoverage",up.DEFAULT="default",up.HARDWARE="hardware";const lp=ji(([e])=>so(ma(1e4,io(ma(17,e.x).add(ma(.1,e.y)))).mul(pa(.1,co(io(ma(13,e.y).add(e.x))))))),dp=ji(([e])=>lp(rn(lp(e.xy),e.z))),cp=ji(([e])=>{const t=Ro(po(fo(e.xyz)),po(yo(e.xyz))),r=Zi(1).div(Zi(.05).mul(t)).toVar("pixScale"),s=rn(Ka(eo(Qa(r))),Ka(to(Qa(r)))),i=rn(dp(eo(s.x.mul(e.xyz))),dp(eo(s.y.mul(e.xyz)))),n=so(Qa(r)),a=pa(ma(n.oneMinus(),i.x),ma(n,i.y)),o=Ao(n,n.oneMinus()),u=on(a.mul(a).div(ma(2,o).mul(ga(1,o))),a.sub(ma(.5,o)).div(ga(1,o)),ga(1,ga(1,a).mul(ga(1,a)).div(ma(2,o).mul(ga(1,o))))),l=a.lessThan(o.oneMinus()).select(a.lessThan(o).select(u.x,u.y),u.z);return Ho(l,1e-6,1)}).setLayout({name:"getAlphaHashThreshold",type:"float",inputs:[{name:"position",type:"vec3"}]});class hp extends Ju{static get type(){return"VertexColorNode"}constructor(e){super(null,"vec4"),this.isVertexColorNode=!0,this.index=e}getAttributeName(){const e=this.index;return"color"+(e>0?e:"")}generate(e){const t=this.getAttributeName(e);let r;return r=!0===e.hasGeometryAttribute(t)?super.generate(e):e.generateConst(this.nodeType,new s(1,1,1,1)),r}serialize(e){super.serialize(e),e.index=this.index}deserialize(e){super.deserialize(e),this.index=e.index}}const pp=(e=0)=>Vi(new hp(e)),gp=ji(([e,t])=>Ao(1,e.oneMinus().div(t)).oneMinus()).setLayout({name:"blendBurn",type:"vec3",inputs:[{name:"base",type:"vec3"},{name:"blend",type:"vec3"}]}),mp=ji(([e,t])=>Ao(e.div(t.oneMinus()),1)).setLayout({name:"blendDodge",type:"vec3",inputs:[{name:"base",type:"vec3"},{name:"blend",type:"vec3"}]}),fp=ji(([e,t])=>e.oneMinus().mul(t.oneMinus()).oneMinus()).setLayout({name:"blendScreen",type:"vec3",inputs:[{name:"base",type:"vec3"},{name:"blend",type:"vec3"}]}),yp=ji(([e,t])=>zo(e.mul(2).mul(t),e.oneMinus().mul(2).mul(t.oneMinus()).oneMinus(),Co(.5,e))).setLayout({name:"blendOverlay",type:"vec3",inputs:[{name:"base",type:"vec3"},{name:"blend",type:"vec3"}]}),bp=ji(([e,t])=>{const r=t.a.add(e.a.mul(t.a.oneMinus()));return cn(t.rgb.mul(t.a).add(e.rgb.mul(e.a).mul(t.a.oneMinus())).div(r),r)}).setLayout({name:"blendColor",type:"vec4",inputs:[{name:"base",type:"vec4"},{name:"blend",type:"vec4"}]}),xp=ji(([e])=>cn(e.rgb.mul(e.a),e.a),{color:"vec4",return:"vec4"}),Tp=ji(([e])=>(Ki(e.a.equal(0),()=>cn(0)),cn(e.rgb.div(e.a),e.a)),{color:"vec4",return:"vec4"});class _p extends O{static get type(){return"NodeMaterial"}get type(){return this.constructor.type}set type(e){}constructor(){super(),this.isNodeMaterial=!0,this.fog=!0,this.lights=!1,this.hardwareClipping=!1,this.lightsNode=null,this.envNode=null,this.aoNode=null,this.colorNode=null,this.normalNode=null,this.opacityNode=null,this.backdropNode=null,this.backdropAlphaNode=null,this.alphaTestNode=null,this.maskNode=null,this.positionNode=null,this.geometryNode=null,this.depthNode=null,this.receivedShadowPositionNode=null,this.castShadowPositionNode=null,this.receivedShadowNode=null,this.castShadowNode=null,this.outputNode=null,this.mrtNode=null,this.fragmentNode=null,this.vertexNode=null,Object.defineProperty(this,"shadowPositionNode",{get:()=>this.receivedShadowPositionNode,set:e=>{console.warn('THREE.NodeMaterial: ".shadowPositionNode" was renamed to ".receivedShadowPositionNode".'),this.receivedShadowPositionNode=e}})}customProgramCacheKey(){return this.type+Ss(this)}build(e){this.setup(e)}setupObserver(e){return new xs(e)}setup(e){e.context.setupNormal=()=>gu(this.setupNormal(e),"NORMAL","vec3"),e.context.setupPositionView=()=>this.setupPositionView(e),e.context.setupModelViewProjection=()=>this.setupModelViewProjection(e);const t=e.renderer,r=t.getRenderTarget();e.addStack();const s=gu(this.setupVertex(e),"VERTEX"),i=this.vertexNode||s;let n;e.stack.outputNode=i,this.setupHardwareClipping(e),null!==this.geometryNode&&(e.stack.outputNode=e.stack.outputNode.bypass(this.geometryNode)),e.addFlow("vertex",e.removeStack()),e.addStack();const a=this.setupClipping(e);if(!0!==this.depthWrite&&!0!==this.depthTest||(null!==r?!0===r.depthBuffer&&this.setupDepth(e):!0===t.depth&&this.setupDepth(e)),null===this.fragmentNode){this.setupDiffuseColor(e),this.setupVariants(e);const s=this.setupLighting(e);null!==a&&e.stack.add(a);const i=cn(s,Nn.a).max(0);n=this.setupOutput(e,i),Gn.assign(n);const o=null!==this.outputNode;if(o&&(n=this.outputNode),null!==r){const e=t.getMRT(),r=this.mrtNode;null!==e?(o&&Gn.assign(n),n=e,null!==r&&(n=e.merge(r))):null!==r&&(n=r)}}else{let t=this.fragmentNode;!0!==t.isOutputStructNode&&(t=cn(t)),n=this.setupOutput(e,t)}e.stack.outputNode=n,e.addFlow("fragment",e.removeStack()),e.observer=this.setupObserver(e)}setupClipping(e){if(null===e.clippingContext)return null;const{unionPlanes:t,intersectionPlanes:r}=e.clippingContext;let s=null;if(t.length>0||r.length>0){const t=e.renderer.samples;this.alphaToCoverage&&t>1?s=Vi(new up(up.ALPHA_TO_COVERAGE)):e.stack.add(Vi(new up))}return s}setupHardwareClipping(e){if(this.hardwareClipping=!1,null===e.clippingContext)return;const t=e.clippingContext.unionPlanes.length;t>0&&t<=8&&e.isAvailable("clipDistance")&&(e.stack.add(Vi(new up(up.HARDWARE))),this.hardwareClipping=!0)}setupDepth(e){const{renderer:t,camera:r}=e;let s=this.depthNode;if(null===s){const e=t.getMRT();e&&e.has("depth")?s=e.get("depth"):!0===t.logarithmicDepthBuffer&&(s=r.isPerspectiveCamera?sp(dd.z,Cl,Ml):ep(dd.z,Cl,Ml))}null!==s&&np.assign(s).toStack()}setupPositionView(){return td.mul(ad).xyz}setupModelViewProjection(){return Pl.mul(dd)}setupVertex(e){return e.addStack(),this.setupPosition(e),e.context.vertex=e.removeStack(),hh}setupPosition(e){const{object:t,geometry:r}=e;if((r.morphAttributes.position||r.morphAttributes.normal||r.morphAttributes.color)&&kh(t).toStack(),!0===t.isSkinnedMesh&&Bh(t).toStack(),this.displacementMap){const e=qd("displacementMap","texture"),t=qd("displacementScale","float"),r=qd("displacementBias","float");ad.addAssign(yd.normalize().mul(e.x.mul(t).add(r)))}return t.isBatchedMesh&&Eh(t).toStack(),t.isInstancedMesh&&t.instanceMatrix&&!0===t.instanceMatrix.isInstancedBufferAttribute&&Nh(t).toStack(),null!==this.positionNode&&ad.assign(gu(this.positionNode,"POSITION","vec3")),ad}setupDiffuseColor({object:e,geometry:t}){null!==this.maskNode&&tn(this.maskNode).not().discard();let r=this.colorNode?cn(this.colorNode):Cc;if(!0===this.vertexColors&&t.hasAttribute("color")&&(r=r.mul(pp())),e.instanceColor){r=vn("vec3","vInstanceColor").mul(r)}if(e.isBatchedMesh&&e._colorsTexture){r=vn("vec3","vBatchColor").mul(r)}Nn.assign(r);const s=this.opacityNode?Zi(this.opacityNode):Bc;Nn.a.assign(Nn.a.mul(s));let i=null;(null!==this.alphaTestNode||this.alphaTest>0)&&(i=null!==this.alphaTestNode?Zi(this.alphaTestNode):Rc,Nn.a.lessThanEqual(i).discard()),!0===this.alphaHash&&Nn.a.lessThan(cp(ad)).discard();!1===this.transparent&&this.blending===k&&!1===this.alphaToCoverage?Nn.a.assign(1):null===i&&Nn.a.lessThanEqual(0).discard()}setupVariants(){}setupOutgoingLight(){return!0===this.lights?on(0):Nn.rgb}setupNormal(){return this.normalNode?on(this.normalNode):kc}setupEnvironment(){let e=null;return this.envNode?e=this.envNode:this.envMap&&(e=this.envMap.isCubeTexture?qd("envMap","cubeTexture"):qd("envMap","texture")),e}setupLightMap(e){let t=null;return e.material.lightMap&&(t=new Wh(lh)),t}setupLights(e){const t=[],r=this.setupEnvironment(e);r&&r.isLightingNode&&t.push(r);const s=this.setupLightMap(e);if(s&&s.isLightingNode&&t.push(s),null!==this.aoNode||e.material.aoMap){const e=null!==this.aoNode?this.aoNode:dh;t.push(new zh(e))}let i=this.lightsNode||e.lightsNode;return t.length>0&&(i=e.renderer.lighting.createNode([...i.getLights(),...t])),i}setupLightingModel(){}setupLighting(e){const{material:t}=e,{backdropNode:r,backdropAlphaNode:s,emissiveNode:i}=this,n=!0===this.lights||null!==this.lightsNode?this.setupLights(e):null;let a=this.setupOutgoingLight(e);if(n&&n.getScope().hasLights){const t=this.setupLightingModel(e)||null;a=$h(n,t,r,s)}else null!==r&&(a=on(null!==s?zo(a,r,s):r));return(i&&!0===i.isNode||t.emissive&&!0===t.emissive.isColor)&&(Sn.assign(on(i||Pc)),a=a.add(Sn)),a}setupFog(e,t){const r=e.fogNode;return r&&(Gn.assign(t),t=cn(r.toVar())),t}setupPremultipliedAlpha(e,t){return xp(t)}setupOutput(e,t){return!0===this.fog&&(t=this.setupFog(e,t)),!0===this.premultipliedAlpha&&(t=this.setupPremultipliedAlpha(e,t)),t}setDefaultValues(e){for(const t in e){const r=e[t];void 0===this[t]&&(this[t]=r,r&&r.clone&&(this[t]=r.clone()))}const t=Object.getOwnPropertyDescriptors(e.constructor.prototype);for(const e in t)void 0===Object.getOwnPropertyDescriptor(this.constructor.prototype,e)&&void 0!==t[e].get&&Object.defineProperty(this.constructor.prototype,e,t[e])}toJSON(e){const t=void 0===e||"string"==typeof e;t&&(e={textures:{},images:{},nodes:{}});const r=O.prototype.toJSON.call(this,e),s=Es(this);r.inputNodes={};for(const{property:t,childNode:i}of s)r.inputNodes[t]=i.toJSON(e).uuid;function i(e){const t=[];for(const r in e){const s=e[r];delete s.metadata,t.push(s)}return t}if(t){const t=i(e.textures),s=i(e.images),n=i(e.nodes);t.length>0&&(r.textures=t),s.length>0&&(r.images=s),n.length>0&&(r.nodes=n)}return r}copy(e){return this.lightsNode=e.lightsNode,this.envNode=e.envNode,this.colorNode=e.colorNode,this.normalNode=e.normalNode,this.opacityNode=e.opacityNode,this.backdropNode=e.backdropNode,this.backdropAlphaNode=e.backdropAlphaNode,this.alphaTestNode=e.alphaTestNode,this.maskNode=e.maskNode,this.positionNode=e.positionNode,this.geometryNode=e.geometryNode,this.depthNode=e.depthNode,this.receivedShadowPositionNode=e.receivedShadowPositionNode,this.castShadowPositionNode=e.castShadowPositionNode,this.receivedShadowNode=e.receivedShadowNode,this.castShadowNode=e.castShadowNode,this.outputNode=e.outputNode,this.mrtNode=e.mrtNode,this.fragmentNode=e.fragmentNode,this.vertexNode=e.vertexNode,super.copy(e)}}const vp=new G;class Np extends _p{static get type(){return"LineBasicNodeMaterial"}constructor(e){super(),this.isLineBasicNodeMaterial=!0,this.setDefaultValues(vp),this.setValues(e)}}const Sp=new z;class Ep extends _p{static get type(){return"LineDashedNodeMaterial"}constructor(e){super(),this.isLineDashedNodeMaterial=!0,this.setDefaultValues(Sp),this.dashOffset=0,this.offsetNode=null,this.dashScaleNode=null,this.dashSizeNode=null,this.gapSizeNode=null,this.setValues(e)}setupVariants(){const e=this.offsetNode?Zi(this.offsetNode):ah,t=this.dashScaleNode?Zi(this.dashScaleNode):rh,r=this.dashSizeNode?Zi(this.dashSizeNode):sh,s=this.gapSizeNode?Zi(this.gapSizeNode):ih;zn.assign(r),Hn.assign(s);const i=fu(el("lineDistance").mul(t));(e?i.add(e):i).mod(zn.add(Hn)).greaterThan(zn).discard()}}let wp=null;class Ap extends qh{static get type(){return"ViewportSharedTextureNode"}constructor(e=Tl,t=null){null===wp&&(wp=new D),super(e,t,wp)}getTextureForReference(){return wp}updateReference(){return this}}const Rp=Gi(Ap).setParameterLength(0,2),Cp=new z;class Mp extends _p{static get type(){return"Line2NodeMaterial"}constructor(e={}){super(),this.isLine2NodeMaterial=!0,this.setDefaultValues(Cp),this.useColor=e.vertexColors,this.dashOffset=0,this.lineColorNode=null,this.offsetNode=null,this.dashScaleNode=null,this.dashSizeNode=null,this.gapSizeNode=null,this.blending=H,this._useDash=e.dashed,this._useAlphaToCoverage=!0,this._useWorldUnits=!1,this.setValues(e)}setup(e){const{renderer:t}=e,r=this._useAlphaToCoverage,s=this.useColor,i=this._useDash,n=this._useWorldUnits,a=ji(({start:e,end:t})=>{const r=Pl.element(2).element(2),s=Pl.element(3).element(2).mul(-.5).div(r).sub(e.z).div(t.z.sub(e.z));return cn(zo(e.xyz,t.xyz,s),t.w)}).setLayout({name:"trimSegment",type:"vec4",inputs:[{name:"start",type:"vec4"},{name:"end",type:"vec4"}]});this.vertexNode=ji(()=>{const e=el("instanceStart"),t=el("instanceEnd"),r=cn(td.mul(cn(e,1))).toVar("start"),s=cn(td.mul(cn(t,1))).toVar("end");if(i){const e=this.dashScaleNode?Zi(this.dashScaleNode):rh,t=this.offsetNode?Zi(this.offsetNode):ah,r=el("instanceDistanceStart"),s=el("instanceDistanceEnd");let i=nd.y.lessThan(.5).select(e.mul(r),e.mul(s));i=i.add(t),vn("float","lineDistance").assign(i)}n&&(vn("vec3","worldStart").assign(r.xyz),vn("vec3","worldEnd").assign(s.xyz));const o=Nl.z.div(Nl.w),u=Pl.element(2).element(3).equal(-1);Ki(u,()=>{Ki(r.z.lessThan(0).and(s.z.greaterThan(0)),()=>{s.assign(a({start:r,end:s}))}).ElseIf(s.z.lessThan(0).and(r.z.greaterThanEqual(0)),()=>{r.assign(a({start:s,end:r}))})});const l=Pl.mul(r),d=Pl.mul(s),c=l.xyz.div(l.w),h=d.xyz.div(d.w),p=h.xy.sub(c.xy).toVar();p.x.assign(p.x.mul(o)),p.assign(p.normalize());const g=cn().toVar();if(n){const e=s.xyz.sub(r.xyz).normalize(),t=zo(r.xyz,s.xyz,.5).normalize(),n=e.cross(t).normalize(),a=e.cross(n),o=vn("vec4","worldPos");o.assign(nd.y.lessThan(.5).select(r,s));const u=nh.mul(.5);o.addAssign(cn(nd.x.lessThan(0).select(n.mul(u),n.mul(u).negate()),0)),i||(o.addAssign(cn(nd.y.lessThan(.5).select(e.mul(u).negate(),e.mul(u)),0)),o.addAssign(cn(a.mul(u),0)),Ki(nd.y.greaterThan(1).or(nd.y.lessThan(0)),()=>{o.subAssign(cn(a.mul(2).mul(u),0))})),g.assign(Pl.mul(o));const l=on().toVar();l.assign(nd.y.lessThan(.5).select(c,h)),g.z.assign(l.z.mul(g.w))}else{const e=rn(p.y,p.x.negate()).toVar("offset");p.x.assign(p.x.div(o)),e.x.assign(e.x.div(o)),e.assign(nd.x.lessThan(0).select(e.negate(),e)),Ki(nd.y.lessThan(0),()=>{e.assign(e.sub(p))}).ElseIf(nd.y.greaterThan(1),()=>{e.assign(e.add(p))}),e.assign(e.mul(nh)),e.assign(e.div(Nl.w)),g.assign(nd.y.lessThan(.5).select(l,d)),e.assign(e.mul(g.w)),g.assign(g.add(cn(e,0,0)))}return g})();const o=ji(({p1:e,p2:t,p3:r,p4:s})=>{const i=e.sub(r),n=s.sub(r),a=t.sub(e),o=i.dot(n),u=n.dot(a),l=i.dot(a),d=n.dot(n),c=a.dot(a).mul(d).sub(u.mul(u)),h=o.mul(u).sub(l.mul(d)).div(c).clamp(),p=o.add(u.mul(h)).div(d).clamp();return rn(h,p)});if(this.colorNode=ji(()=>{const e=tl();if(i){const t=this.dashSizeNode?Zi(this.dashSizeNode):sh,r=this.gapSizeNode?Zi(this.gapSizeNode):ih;zn.assign(t),Hn.assign(r);const s=vn("float","lineDistance");e.y.lessThan(-1).or(e.y.greaterThan(1)).discard(),s.mod(zn.add(Hn)).greaterThan(zn).discard()}const a=Zi(1).toVar("alpha");if(n){const e=vn("vec3","worldStart"),s=vn("vec3","worldEnd"),n=vn("vec4","worldPos").xyz.normalize().mul(1e5),u=s.sub(e),l=o({p1:e,p2:s,p3:on(0,0,0),p4:n}),d=e.add(u.mul(l.x)),c=n.mul(l.y),h=d.sub(c).length().div(nh);if(!i)if(r&&t.samples>1){const e=h.fwidth();a.assign(jo(e.negate().add(.5),e.add(.5),h).oneMinus())}else h.greaterThan(.5).discard()}else if(r&&t.samples>1){const t=e.x,r=e.y.greaterThan(0).select(e.y.sub(1),e.y.add(1)),s=t.mul(t).add(r.mul(r)),i=Zi(s.fwidth()).toVar("dlen");Ki(e.y.abs().greaterThan(1),()=>{a.assign(jo(i.oneMinus(),i.add(1),s).oneMinus())})}else Ki(e.y.abs().greaterThan(1),()=>{const t=e.x,r=e.y.greaterThan(0).select(e.y.sub(1),e.y.add(1));t.mul(t).add(r.mul(r)).greaterThan(1).discard()});let u;if(this.lineColorNode)u=this.lineColorNode;else if(s){const e=el("instanceColorStart"),t=el("instanceColorEnd");u=nd.y.lessThan(.5).select(e,t).mul(Cc)}else u=Cc;return cn(u,a)})(),this.transparent){const e=this.opacityNode?Zi(this.opacityNode):Bc;this.outputNode=cn(this.colorNode.rgb.mul(e).add(Rp().rgb.mul(e.oneMinus())),this.colorNode.a)}super.setup(e)}get worldUnits(){return this._useWorldUnits}set worldUnits(e){this._useWorldUnits!==e&&(this._useWorldUnits=e,this.needsUpdate=!0)}get dashed(){return this._useDash}set dashed(e){this._useDash!==e&&(this._useDash=e,this.needsUpdate=!0)}get alphaToCoverage(){return this._useAlphaToCoverage}set alphaToCoverage(e){this._useAlphaToCoverage!==e&&(this._useAlphaToCoverage=e,this.needsUpdate=!0)}}const Pp=e=>Vi(e).mul(.5).add(.5),Bp=new $;class Fp extends _p{static get type(){return"MeshNormalNodeMaterial"}constructor(e){super(),this.isMeshNormalNodeMaterial=!0,this.setDefaultValues(Bp),this.setValues(e)}setupDiffuseColor(){const e=this.opacityNode?Zi(this.opacityNode):Bc;Nn.assign(Nu(cn(Pp(_d),e),W))}}const Lp=ji(([e=ld])=>{const t=e.z.atan(e.x).mul(1/(2*Math.PI)).add(.5),r=e.y.clamp(-1,1).asin().mul(1/Math.PI).add(.5);return rn(t,r)});class Ip extends j{constructor(e=1,t={}){super(e,t),this.isCubeRenderTarget=!0}fromEquirectangularTexture(e,t){const r=t.minFilter,s=t.generateMipmaps;t.generateMipmaps=!0,this.texture.type=t.type,this.texture.colorSpace=t.colorSpace,this.texture.generateMipmaps=t.generateMipmaps,this.texture.minFilter=t.minFilter,this.texture.magFilter=t.magFilter;const i=new q(5,5,5),n=Lp(ld),a=new _p;a.colorNode=ll(t,n,0),a.side=S,a.blending=H;const o=new X(i,a),u=new K;u.add(o),t.minFilter===V&&(t.minFilter=Y);const l=new Q(1,10,this),d=e.getMRT();return e.setMRT(null),l.update(e,u),e.setMRT(d),t.minFilter=r,t.currentGenerateMipmaps=s,o.geometry.dispose(),o.material.dispose(),this}}const Dp=new WeakMap;class Vp extends Zs{static get type(){return"CubeMapNode"}constructor(e){super("vec3"),this.envNode=e,this._cubeTexture=null,this._cubeTextureNode=Gd(null);const t=new A;t.isRenderTargetTexture=!0,this._defaultTexture=t,this.updateBeforeType=ks.RENDER}updateBefore(e){const{renderer:t,material:r}=e,s=this.envNode;if(s.isTextureNode||s.isMaterialReferenceNode){const e=s.isTextureNode?s.value:r[s.property];if(e&&e.isTexture){const r=e.mapping;if(r===Z||r===J){if(Dp.has(e)){const t=Dp.get(e);Op(t,e.mapping),this._cubeTexture=t}else{const r=e.image;if(function(e){return null!=e&&e.height>0}(r)){const s=new Ip(r.height);s.fromEquirectangularTexture(t,e),Op(s.texture,e.mapping),this._cubeTexture=s.texture,Dp.set(e,s.texture),e.addEventListener("dispose",Up)}else this._cubeTexture=this._defaultTexture}this._cubeTextureNode.value=this._cubeTexture}else this._cubeTextureNode=this.envNode}}}setup(e){return this.updateBefore(e),this._cubeTextureNode}}function Up(e){const t=e.target;t.removeEventListener("dispose",Up);const r=Dp.get(t);void 0!==r&&(Dp.delete(t),r.dispose())}function Op(e,t){t===Z?e.mapping=R:t===J&&(e.mapping=C)}const kp=Gi(Vp).setParameterLength(1);class Gp extends Gh{static get type(){return"BasicEnvironmentNode"}constructor(e=null){super(),this.envNode=e}setup(e){e.context.environment=kp(this.envNode)}}class zp extends Gh{static get type(){return"BasicLightMapNode"}constructor(e=null){super(),this.lightMapNode=e}setup(e){const t=Zi(1/Math.PI);e.context.irradianceLightMap=this.lightMapNode.mul(t)}}class Hp{start(e){e.lightsNode.setupLights(e,e.lightsNode.getLightNodes(e)),this.indirect(e)}finish(){}direct(){}directRectArea(){}indirect(){}ambientOcclusion(){}}class $p extends Hp{constructor(){super()}indirect({context:e}){const t=e.ambientOcclusion,r=e.reflectedLight,s=e.irradianceLightMap;r.indirectDiffuse.assign(cn(0)),s?r.indirectDiffuse.addAssign(s):r.indirectDiffuse.addAssign(cn(1,1,1,0)),r.indirectDiffuse.mulAssign(t),r.indirectDiffuse.mulAssign(Nn.rgb)}finish(e){const{material:t,context:r}=e,s=r.outgoingLight,i=e.context.environment;if(i)switch(t.combine){case re:s.rgb.assign(zo(s.rgb,s.rgb.mul(i.rgb),Dc.mul(Vc)));break;case te:s.rgb.assign(zo(s.rgb,i.rgb,Dc.mul(Vc)));break;case ee:s.rgb.addAssign(i.rgb.mul(Dc.mul(Vc)));break;default:console.warn("THREE.BasicLightingModel: Unsupported .combine value:",t.combine)}}}const Wp=new se;class jp extends _p{static get type(){return"MeshBasicNodeMaterial"}constructor(e){super(),this.isMeshBasicNodeMaterial=!0,this.lights=!0,this.setDefaultValues(Wp),this.setValues(e)}setupNormal(){return md(xd)}setupEnvironment(e){const t=super.setupEnvironment(e);return t?new Gp(t):null}setupLightMap(e){let t=null;return e.material.lightMap&&(t=new zp(lh)),t}setupOutgoingLight(){return Nn.rgb}setupLightingModel(){return new $p}}const qp=ji(({f0:e,f90:t,dotVH:r})=>{const s=r.mul(-5.55473).sub(6.98316).mul(r).exp2();return e.mul(s.oneMinus()).add(t.mul(s))}),Xp=ji(e=>e.diffuseColor.mul(1/Math.PI)),Kp=ji(({dotNH:e})=>kn.mul(Zi(.5)).add(1).mul(Zi(1/Math.PI)).mul(e.pow(kn))),Yp=ji(({lightDirection:e})=>{const t=e.add(cd).normalize(),r=_d.dot(t).clamp(),s=cd.dot(t).clamp(),i=qp({f0:Un,f90:1,dotVH:s}),n=Zi(.25),a=Kp({dotNH:r});return i.mul(n).mul(a)});class Qp extends $p{constructor(e=!0){super(),this.specular=e}direct({lightDirection:e,lightColor:t,reflectedLight:r}){const s=_d.dot(e).clamp().mul(t);r.directDiffuse.addAssign(s.mul(Xp({diffuseColor:Nn.rgb}))),!0===this.specular&&r.directSpecular.addAssign(s.mul(Yp({lightDirection:e})).mul(Dc))}indirect(e){const{ambientOcclusion:t,irradiance:r,reflectedLight:s}=e.context;s.indirectDiffuse.addAssign(r.mul(Xp({diffuseColor:Nn}))),s.indirectDiffuse.mulAssign(t)}}const Zp=new ie;class Jp extends _p{static get type(){return"MeshLambertNodeMaterial"}constructor(e){super(),this.isMeshLambertNodeMaterial=!0,this.lights=!0,this.setDefaultValues(Zp),this.setValues(e)}setupEnvironment(e){const t=super.setupEnvironment(e);return t?new Gp(t):null}setupLightingModel(){return new Qp(!1)}}const eg=new ne;class tg extends _p{static get type(){return"MeshPhongNodeMaterial"}constructor(e){super(),this.isMeshPhongNodeMaterial=!0,this.lights=!0,this.shininessNode=null,this.specularNode=null,this.setDefaultValues(eg),this.setValues(e)}setupEnvironment(e){const t=super.setupEnvironment(e);return t?new Gp(t):null}setupLightingModel(){return new Qp}setupVariants(){const e=(this.shininessNode?Zi(this.shininessNode):Mc).max(1e-4);kn.assign(e);const t=this.specularNode||Fc;Un.assign(t)}copy(e){return this.shininessNode=e.shininessNode,this.specularNode=e.specularNode,super.copy(e)}}const rg=ji(e=>{if(!1===e.geometry.hasAttribute("normal"))return Zi(0);const t=xd.dFdx().abs().max(xd.dFdy().abs());return t.x.max(t.y).max(t.z)}),sg=ji(e=>{const{roughness:t}=e,r=rg();let s=t.max(.0525);return s=s.add(r),s=s.min(1),s}),ig=ji(({alpha:e,dotNL:t,dotNV:r})=>{const s=e.pow2(),i=t.mul(s.add(s.oneMinus().mul(r.pow2())).sqrt()),n=r.mul(s.add(s.oneMinus().mul(t.pow2())).sqrt());return fa(.5,i.add(n).max(ka))}).setLayout({name:"V_GGX_SmithCorrelated",type:"float",inputs:[{name:"alpha",type:"float"},{name:"dotNL",type:"float"},{name:"dotNV",type:"float"}]}),ng=ji(({alphaT:e,alphaB:t,dotTV:r,dotBV:s,dotTL:i,dotBL:n,dotNV:a,dotNL:o})=>{const u=o.mul(on(e.mul(r),t.mul(s),a).length()),l=a.mul(on(e.mul(i),t.mul(n),o).length());return fa(.5,u.add(l)).saturate()}).setLayout({name:"V_GGX_SmithCorrelated_Anisotropic",type:"float",inputs:[{name:"alphaT",type:"float",qualifier:"in"},{name:"alphaB",type:"float",qualifier:"in"},{name:"dotTV",type:"float",qualifier:"in"},{name:"dotBV",type:"float",qualifier:"in"},{name:"dotTL",type:"float",qualifier:"in"},{name:"dotBL",type:"float",qualifier:"in"},{name:"dotNV",type:"float",qualifier:"in"},{name:"dotNL",type:"float",qualifier:"in"}]}),ag=ji(({alpha:e,dotNH:t})=>{const r=e.pow2(),s=t.pow2().mul(r.oneMinus()).oneMinus();return r.div(s.pow2()).mul(1/Math.PI)}).setLayout({name:"D_GGX",type:"float",inputs:[{name:"alpha",type:"float"},{name:"dotNH",type:"float"}]}),og=Zi(1/Math.PI),ug=ji(({alphaT:e,alphaB:t,dotNH:r,dotTH:s,dotBH:i})=>{const n=e.mul(t),a=on(t.mul(s),e.mul(i),n.mul(r)),o=a.dot(a),u=n.div(o);return og.mul(n.mul(u.pow2()))}).setLayout({name:"D_GGX_Anisotropic",type:"float",inputs:[{name:"alphaT",type:"float",qualifier:"in"},{name:"alphaB",type:"float",qualifier:"in"},{name:"dotNH",type:"float",qualifier:"in"},{name:"dotTH",type:"float",qualifier:"in"},{name:"dotBH",type:"float",qualifier:"in"}]}),lg=ji(({lightDirection:e,f0:t,f90:r,roughness:s,f:i,normalView:n=_d,USE_IRIDESCENCE:a,USE_ANISOTROPY:o})=>{const u=s.pow2(),l=e.add(cd).normalize(),d=n.dot(e).clamp(),c=n.dot(cd).clamp(),h=n.dot(l).clamp(),p=cd.dot(l).clamp();let g,m,f=qp({f0:t,f90:r,dotVH:p});if(Li(a)&&(f=Pn.mix(f,i)),Li(o)){const t=Dn.dot(e),r=Dn.dot(cd),s=Dn.dot(l),i=Vn.dot(e),n=Vn.dot(cd),a=Vn.dot(l);g=ng({alphaT:Ln,alphaB:u,dotTV:r,dotBV:n,dotTL:t,dotBL:i,dotNV:c,dotNL:d}),m=ug({alphaT:Ln,alphaB:u,dotNH:h,dotTH:s,dotBH:a})}else g=ig({alpha:u,dotNL:d,dotNV:c}),m=ag({alpha:u,dotNH:h});return f.mul(g).mul(m)}),dg=ji(({roughness:e,dotNV:t})=>{const r=cn(-1,-.0275,-.572,.022),s=cn(1,.0425,1.04,-.04),i=e.mul(r).add(s),n=i.x.mul(i.x).min(t.mul(-9.28).exp2()).mul(i.x).add(i.y);return rn(-1.04,1.04).mul(n).add(i.zw)}).setLayout({name:"DFGApprox",type:"vec2",inputs:[{name:"roughness",type:"float"},{name:"dotNV",type:"vec3"}]}),cg=ji(e=>{const{dotNV:t,specularColor:r,specularF90:s,roughness:i}=e,n=dg({dotNV:t,roughness:i});return r.mul(n.x).add(s.mul(n.y))}),hg=ji(({f:e,f90:t,dotVH:r})=>{const s=r.oneMinus().saturate(),i=s.mul(s),n=s.mul(i,i).clamp(0,.9999);return e.sub(on(t).mul(n)).div(n.oneMinus())}).setLayout({name:"Schlick_to_F0",type:"vec3",inputs:[{name:"f",type:"vec3"},{name:"f90",type:"float"},{name:"dotVH",type:"float"}]}),pg=ji(({roughness:e,dotNH:t})=>{const r=e.pow2(),s=Zi(1).div(r),i=t.pow2().oneMinus().max(.0078125);return Zi(2).add(s).mul(i.pow(s.mul(.5))).div(2*Math.PI)}).setLayout({name:"D_Charlie",type:"float",inputs:[{name:"roughness",type:"float"},{name:"dotNH",type:"float"}]}),gg=ji(({dotNV:e,dotNL:t})=>Zi(1).div(Zi(4).mul(t.add(e).sub(t.mul(e))))).setLayout({name:"V_Neubelt",type:"float",inputs:[{name:"dotNV",type:"float"},{name:"dotNL",type:"float"}]}),mg=ji(({lightDirection:e})=>{const t=e.add(cd).normalize(),r=_d.dot(e).clamp(),s=_d.dot(cd).clamp(),i=_d.dot(t).clamp(),n=pg({roughness:Mn,dotNH:i}),a=gg({dotNV:s,dotNL:r});return Cn.mul(n).mul(a)}),fg=ji(({N:e,V:t,roughness:r})=>{const s=e.dot(t).saturate(),i=rn(r,s.oneMinus().sqrt());return i.assign(i.mul(.984375).add(.0078125)),i}).setLayout({name:"LTC_Uv",type:"vec2",inputs:[{name:"N",type:"vec3"},{name:"V",type:"vec3"},{name:"roughness",type:"float"}]}),yg=ji(({f:e})=>{const t=e.length();return Ro(t.mul(t).add(e.z).div(t.add(1)),0)}).setLayout({name:"LTC_ClippedSphereFormFactor",type:"float",inputs:[{name:"f",type:"vec3"}]}),bg=ji(({v1:e,v2:t})=>{const r=e.dot(t),s=r.abs().toVar(),i=s.mul(.0145206).add(.4965155).mul(s).add(.8543985).toVar(),n=s.add(4.1616724).mul(s).add(3.417594).toVar(),a=i.div(n),o=r.greaterThan(0).select(a,Ro(r.mul(r).oneMinus(),1e-7).inverseSqrt().mul(.5).sub(a));return e.cross(t).mul(o)}).setLayout({name:"LTC_EdgeVectorFormFactor",type:"vec3",inputs:[{name:"v1",type:"vec3"},{name:"v2",type:"vec3"}]}),xg=ji(({N:e,V:t,P:r,mInv:s,p0:i,p1:n,p2:a,p3:o})=>{const u=n.sub(i).toVar(),l=o.sub(i).toVar(),d=u.cross(l),c=on().toVar();return Ki(d.dot(r.sub(i)).greaterThanEqual(0),()=>{const u=t.sub(e.mul(t.dot(e))).normalize(),l=e.cross(u).negate(),d=s.mul(fn(u,l,e).transpose()).toVar(),h=d.mul(i.sub(r)).normalize().toVar(),p=d.mul(n.sub(r)).normalize().toVar(),g=d.mul(a.sub(r)).normalize().toVar(),m=d.mul(o.sub(r)).normalize().toVar(),f=on(0).toVar();f.addAssign(bg({v1:h,v2:p})),f.addAssign(bg({v1:p,v2:g})),f.addAssign(bg({v1:g,v2:m})),f.addAssign(bg({v1:m,v2:h})),c.assign(on(yg({f:f})))}),c}).setLayout({name:"LTC_Evaluate",type:"vec3",inputs:[{name:"N",type:"vec3"},{name:"V",type:"vec3"},{name:"P",type:"vec3"},{name:"mInv",type:"mat3"},{name:"p0",type:"vec3"},{name:"p1",type:"vec3"},{name:"p2",type:"vec3"},{name:"p3",type:"vec3"}]}),Tg=ji(({P:e,p0:t,p1:r,p2:s,p3:i})=>{const n=r.sub(t).toVar(),a=i.sub(t).toVar(),o=n.cross(a),u=on().toVar();return Ki(o.dot(e.sub(t)).greaterThanEqual(0),()=>{const n=t.sub(e).normalize().toVar(),a=r.sub(e).normalize().toVar(),o=s.sub(e).normalize().toVar(),l=i.sub(e).normalize().toVar(),d=on(0).toVar();d.addAssign(bg({v1:n,v2:a})),d.addAssign(bg({v1:a,v2:o})),d.addAssign(bg({v1:o,v2:l})),d.addAssign(bg({v1:l,v2:n})),u.assign(on(yg({f:d.abs()})))}),u}).setLayout({name:"LTC_Evaluate",type:"vec3",inputs:[{name:"P",type:"vec3"},{name:"p0",type:"vec3"},{name:"p1",type:"vec3"},{name:"p2",type:"vec3"},{name:"p3",type:"vec3"}]}),_g=1/6,vg=e=>ma(_g,ma(e,ma(e,e.negate().add(3)).sub(3)).add(1)),Ng=e=>ma(_g,ma(e,ma(e,ma(3,e).sub(6))).add(4)),Sg=e=>ma(_g,ma(e,ma(e,ma(-3,e).add(3)).add(3)).add(1)),Eg=e=>ma(_g,Io(e,3)),wg=e=>vg(e).add(Ng(e)),Ag=e=>Sg(e).add(Eg(e)),Rg=e=>pa(-1,Ng(e).div(vg(e).add(Ng(e)))),Cg=e=>pa(1,Eg(e).div(Sg(e).add(Eg(e)))),Mg=(e,t,r)=>{const s=e.uvNode,i=ma(s,t.zw).add(.5),n=eo(i),a=so(i),o=wg(a.x),u=Ag(a.x),l=Rg(a.x),d=Cg(a.x),c=Rg(a.y),h=Cg(a.y),p=rn(n.x.add(l),n.y.add(c)).sub(.5).mul(t.xy),g=rn(n.x.add(d),n.y.add(c)).sub(.5).mul(t.xy),m=rn(n.x.add(l),n.y.add(h)).sub(.5).mul(t.xy),f=rn(n.x.add(d),n.y.add(h)).sub(.5).mul(t.xy),y=wg(a.y).mul(pa(o.mul(e.sample(p).level(r)),u.mul(e.sample(g).level(r)))),b=Ag(a.y).mul(pa(o.mul(e.sample(m).level(r)),u.mul(e.sample(f).level(r))));return y.add(b)},Pg=ji(([e,t])=>{const r=rn(e.size(Ji(t))),s=rn(e.size(Ji(t.add(1)))),i=fa(1,r),n=fa(1,s),a=Mg(e,cn(i,r),eo(t)),o=Mg(e,cn(n,s),to(t));return so(t).mix(a,o)}),Bg=ji(([e,t])=>{const r=t.mul(nl(e));return Pg(e,r)}),Fg=ji(([e,t,r,s,i])=>{const n=on(Wo(t.negate(),ro(e),fa(1,s))),a=on(po(i[0].xyz),po(i[1].xyz),po(i[2].xyz));return ro(n).mul(r.mul(a))}).setLayout({name:"getVolumeTransmissionRay",type:"vec3",inputs:[{name:"n",type:"vec3"},{name:"v",type:"vec3"},{name:"thickness",type:"float"},{name:"ior",type:"float"},{name:"modelMatrix",type:"mat4"}]}),Lg=ji(([e,t])=>e.mul(Ho(t.mul(2).sub(2),0,1))).setLayout({name:"applyIorToRoughness",type:"float",inputs:[{name:"roughness",type:"float"},{name:"ior",type:"float"}]}),Ig=Kh(),Dg=Kh(),Vg=ji(([e,t,r],{material:s})=>{const i=(s.side===S?Ig:Dg).sample(e),n=Qa(_l.x).mul(Lg(t,r));return Pg(i,n)}),Ug=ji(([e,t,r])=>(Ki(r.notEqual(0),()=>{const s=Ya(t).negate().div(r);return Xa(s.negate().mul(e))}),on(1))).setLayout({name:"volumeAttenuation",type:"vec3",inputs:[{name:"transmissionDistance",type:"float"},{name:"attenuationColor",type:"vec3"},{name:"attenuationDistance",type:"float"}]}),Og=ji(([e,t,r,s,i,n,a,o,u,l,d,c,h,p,g])=>{let m,f;if(g){m=cn().toVar(),f=on().toVar();const i=d.sub(1).mul(g.mul(.025)),n=on(d.sub(i),d,d.add(i));Lh({start:0,end:3},({i:i})=>{const d=n.element(i),g=Fg(e,t,c,d,o),y=a.add(g),b=l.mul(u.mul(cn(y,1))),x=rn(b.xy.div(b.w)).toVar();x.addAssign(1),x.divAssign(2),x.assign(rn(x.x,x.y.oneMinus()));const T=Vg(x,r,d);m.element(i).assign(T.element(i)),m.a.addAssign(T.a),f.element(i).assign(s.element(i).mul(Ug(po(g),h,p).element(i)))}),m.a.divAssign(3)}else{const i=Fg(e,t,c,d,o),n=a.add(i),g=l.mul(u.mul(cn(n,1))),y=rn(g.xy.div(g.w)).toVar();y.addAssign(1),y.divAssign(2),y.assign(rn(y.x,y.y.oneMinus())),m=Vg(y,r,d),f=s.mul(Ug(po(i),h,p))}const y=f.rgb.mul(m.rgb),b=e.dot(t).clamp(),x=on(cg({dotNV:b,specularColor:i,specularF90:n,roughness:r})),T=f.r.add(f.g,f.b).div(3);return cn(x.oneMinus().mul(y),m.a.oneMinus().mul(T).oneMinus())}),kg=fn(3.2404542,-.969266,.0556434,-1.5371385,1.8760108,-.2040259,-.4985314,.041556,1.0572252),Gg=(e,t)=>e.sub(t).div(e.add(t)).pow2(),zg=ji(({outsideIOR:e,eta2:t,cosTheta1:r,thinFilmThickness:s,baseF0:i})=>{const n=zo(e,t,jo(0,.03,s)),a=e.div(n).pow2().mul(r.pow2().oneMinus()).oneMinus();Ki(a.lessThan(0),()=>on(1));const o=a.sqrt(),u=Gg(n,e),l=qp({f0:u,f90:1,dotVH:r}),d=l.oneMinus(),c=n.lessThan(e).select(Math.PI,0),h=Zi(Math.PI).sub(c),p=(e=>{const t=e.sqrt();return on(1).add(t).div(on(1).sub(t))})(i.clamp(0,.9999)),g=Gg(p,n.toVec3()),m=qp({f0:g,f90:1,dotVH:o}),f=on(p.x.lessThan(n).select(Math.PI,0),p.y.lessThan(n).select(Math.PI,0),p.z.lessThan(n).select(Math.PI,0)),y=n.mul(s,o,2),b=on(h).add(f),x=l.mul(m).clamp(1e-5,.9999),T=x.sqrt(),_=d.pow2().mul(m).div(on(1).sub(x)),v=l.add(_).toVar(),N=_.sub(d).toVar();return Lh({start:1,end:2,condition:"<=",name:"m"},({m:e})=>{N.mulAssign(T);const t=((e,t)=>{const r=e.mul(2*Math.PI*1e-9),s=on(54856e-17,44201e-17,52481e-17),i=on(1681e3,1795300,2208400),n=on(43278e5,93046e5,66121e5),a=Zi(9747e-17*Math.sqrt(2*Math.PI*45282e5)).mul(r.mul(2239900).add(t.x).cos()).mul(r.pow2().mul(-45282e5).exp());let o=s.mul(n.mul(2*Math.PI).sqrt()).mul(i.mul(r).add(t).cos()).mul(r.pow2().negate().mul(n).exp());return o=on(o.x.add(a),o.y,o.z).div(1.0685e-7),kg.mul(o)})(Zi(e).mul(y),Zi(e).mul(b)).mul(2);v.addAssign(N.mul(t))}),v.max(on(0))}).setLayout({name:"evalIridescence",type:"vec3",inputs:[{name:"outsideIOR",type:"float"},{name:"eta2",type:"float"},{name:"cosTheta1",type:"float"},{name:"thinFilmThickness",type:"float"},{name:"baseF0",type:"vec3"}]}),Hg=ji(({normal:e,viewDir:t,roughness:r})=>{const s=e.dot(t).saturate(),i=r.pow2(),n=ru(r.lessThan(.25),Zi(-339.2).mul(i).add(Zi(161.4).mul(r)).sub(25.9),Zi(-8.48).mul(i).add(Zi(14.3).mul(r)).sub(9.95)),a=ru(r.lessThan(.25),Zi(44).mul(i).sub(Zi(23.7).mul(r)).add(3.26),Zi(1.97).mul(i).sub(Zi(3.27).mul(r)).add(.72));return ru(r.lessThan(.25),0,Zi(.1).mul(r).sub(.025)).add(n.mul(s).add(a).exp()).mul(1/Math.PI).saturate()}),$g=on(.04),Wg=Zi(1);class jg extends Hp{constructor(e=!1,t=!1,r=!1,s=!1,i=!1,n=!1){super(),this.clearcoat=e,this.sheen=t,this.iridescence=r,this.anisotropy=s,this.transmission=i,this.dispersion=n,this.clearcoatRadiance=null,this.clearcoatSpecularDirect=null,this.clearcoatSpecularIndirect=null,this.sheenSpecularDirect=null,this.sheenSpecularIndirect=null,this.iridescenceFresnel=null,this.iridescenceF0=null}start(e){if(!0===this.clearcoat&&(this.clearcoatRadiance=on().toVar("clearcoatRadiance"),this.clearcoatSpecularDirect=on().toVar("clearcoatSpecularDirect"),this.clearcoatSpecularIndirect=on().toVar("clearcoatSpecularIndirect")),!0===this.sheen&&(this.sheenSpecularDirect=on().toVar("sheenSpecularDirect"),this.sheenSpecularIndirect=on().toVar("sheenSpecularIndirect")),!0===this.iridescence){const e=_d.dot(cd).clamp();this.iridescenceFresnel=zg({outsideIOR:Zi(1),eta2:Bn,cosTheta1:e,thinFilmThickness:Fn,baseF0:Un}),this.iridescenceF0=hg({f:this.iridescenceFresnel,f90:1,dotVH:e})}if(!0===this.transmission){const t=ud,r=Dl.sub(ud).normalize(),s=vd,i=e.context;i.backdrop=Og(s,r,En,Nn,Un,On,t,Xl,Fl,Pl,Wn,qn,Kn,Xn,this.dispersion?Yn:null),i.backdropAlpha=jn,Nn.a.mulAssign(zo(1,i.backdrop.a,jn))}super.start(e)}computeMultiscattering(e,t,r){const s=_d.dot(cd).clamp(),i=dg({roughness:En,dotNV:s}),n=(this.iridescenceF0?Pn.mix(Un,this.iridescenceF0):Un).mul(i.x).add(r.mul(i.y)),a=i.x.add(i.y).oneMinus(),o=Un.add(Un.oneMinus().mul(.047619)),u=n.mul(o).div(a.mul(o).oneMinus());e.addAssign(n),t.addAssign(u.mul(a))}direct({lightDirection:e,lightColor:t,reflectedLight:r}){const s=_d.dot(e).clamp().mul(t);if(!0===this.sheen&&this.sheenSpecularDirect.addAssign(s.mul(mg({lightDirection:e}))),!0===this.clearcoat){const r=Nd.dot(e).clamp().mul(t);this.clearcoatSpecularDirect.addAssign(r.mul(lg({lightDirection:e,f0:$g,f90:Wg,roughness:Rn,normalView:Nd})))}r.directDiffuse.addAssign(s.mul(Xp({diffuseColor:Nn.rgb}))),r.directSpecular.addAssign(s.mul(lg({lightDirection:e,f0:Un,f90:1,roughness:En,iridescence:this.iridescence,f:this.iridescenceFresnel,USE_IRIDESCENCE:this.iridescence,USE_ANISOTROPY:this.anisotropy})))}directRectArea({lightColor:e,lightPosition:t,halfWidth:r,halfHeight:s,reflectedLight:i,ltc_1:n,ltc_2:a}){const o=t.add(r).sub(s),u=t.sub(r).sub(s),l=t.sub(r).add(s),d=t.add(r).add(s),c=_d,h=cd,p=dd.toVar(),g=fg({N:c,V:h,roughness:En}),m=n.sample(g).toVar(),f=a.sample(g).toVar(),y=fn(on(m.x,0,m.y),on(0,1,0),on(m.z,0,m.w)).toVar(),b=Un.mul(f.x).add(Un.oneMinus().mul(f.y)).toVar();i.directSpecular.addAssign(e.mul(b).mul(xg({N:c,V:h,P:p,mInv:y,p0:o,p1:u,p2:l,p3:d}))),i.directDiffuse.addAssign(e.mul(Nn).mul(xg({N:c,V:h,P:p,mInv:fn(1,0,0,0,1,0,0,0,1),p0:o,p1:u,p2:l,p3:d})))}indirect(e){this.indirectDiffuse(e),this.indirectSpecular(e),this.ambientOcclusion(e)}indirectDiffuse(e){const{irradiance:t,reflectedLight:r}=e.context;r.indirectDiffuse.addAssign(t.mul(Xp({diffuseColor:Nn})))}indirectSpecular(e){const{radiance:t,iblIrradiance:r,reflectedLight:s}=e.context;if(!0===this.sheen&&this.sheenSpecularIndirect.addAssign(r.mul(Cn,Hg({normal:_d,viewDir:cd,roughness:Mn}))),!0===this.clearcoat){const e=Nd.dot(cd).clamp(),t=cg({dotNV:e,specularColor:$g,specularF90:Wg,roughness:Rn});this.clearcoatSpecularIndirect.addAssign(this.clearcoatRadiance.mul(t))}const i=on().toVar("singleScattering"),n=on().toVar("multiScattering"),a=r.mul(1/Math.PI);this.computeMultiscattering(i,n,On);const o=i.add(n),u=Nn.mul(o.r.max(o.g).max(o.b).oneMinus());s.indirectSpecular.addAssign(t.mul(i)),s.indirectSpecular.addAssign(n.mul(a)),s.indirectDiffuse.addAssign(u.mul(a))}ambientOcclusion(e){const{ambientOcclusion:t,reflectedLight:r}=e.context,s=_d.dot(cd).clamp().add(t),i=En.mul(-16).oneMinus().negate().exp2(),n=t.sub(s.pow(i).oneMinus()).clamp();!0===this.clearcoat&&this.clearcoatSpecularIndirect.mulAssign(t),!0===this.sheen&&this.sheenSpecularIndirect.mulAssign(t),r.indirectDiffuse.mulAssign(t),r.indirectSpecular.mulAssign(n)}finish({context:e}){const{outgoingLight:t}=e;if(!0===this.clearcoat){const e=Nd.dot(cd).clamp(),r=qp({dotVH:e,f0:$g,f90:Wg}),s=t.mul(An.mul(r).oneMinus()).add(this.clearcoatSpecularDirect.add(this.clearcoatSpecularIndirect).mul(An));t.assign(s)}if(!0===this.sheen){const e=Cn.r.max(Cn.g).max(Cn.b).mul(.157).oneMinus(),r=t.mul(e).add(this.sheenSpecularDirect,this.sheenSpecularIndirect);t.assign(r)}}}const qg=Zi(1),Xg=Zi(-2),Kg=Zi(.8),Yg=Zi(-1),Qg=Zi(.4),Zg=Zi(2),Jg=Zi(.305),em=Zi(3),tm=Zi(.21),rm=Zi(4),sm=Zi(4),im=Zi(16),nm=ji(([e])=>{const t=on(co(e)).toVar(),r=Zi(-1).toVar();return Ki(t.x.greaterThan(t.z),()=>{Ki(t.x.greaterThan(t.y),()=>{r.assign(ru(e.x.greaterThan(0),0,3))}).Else(()=>{r.assign(ru(e.y.greaterThan(0),1,4))})}).Else(()=>{Ki(t.z.greaterThan(t.y),()=>{r.assign(ru(e.z.greaterThan(0),2,5))}).Else(()=>{r.assign(ru(e.y.greaterThan(0),1,4))})}),r}).setLayout({name:"getFace",type:"float",inputs:[{name:"direction",type:"vec3"}]}),am=ji(([e,t])=>{const r=rn().toVar();return Ki(t.equal(0),()=>{r.assign(rn(e.z,e.y).div(co(e.x)))}).ElseIf(t.equal(1),()=>{r.assign(rn(e.x.negate(),e.z.negate()).div(co(e.y)))}).ElseIf(t.equal(2),()=>{r.assign(rn(e.x.negate(),e.y).div(co(e.z)))}).ElseIf(t.equal(3),()=>{r.assign(rn(e.z.negate(),e.y).div(co(e.x)))}).ElseIf(t.equal(4),()=>{r.assign(rn(e.x.negate(),e.z).div(co(e.y)))}).Else(()=>{r.assign(rn(e.x,e.y).div(co(e.z)))}),ma(.5,r.add(1))}).setLayout({name:"getUV",type:"vec2",inputs:[{name:"direction",type:"vec3"},{name:"face",type:"float"}]}),om=ji(([e])=>{const t=Zi(0).toVar();return Ki(e.greaterThanEqual(Kg),()=>{t.assign(qg.sub(e).mul(Yg.sub(Xg)).div(qg.sub(Kg)).add(Xg))}).ElseIf(e.greaterThanEqual(Qg),()=>{t.assign(Kg.sub(e).mul(Zg.sub(Yg)).div(Kg.sub(Qg)).add(Yg))}).ElseIf(e.greaterThanEqual(Jg),()=>{t.assign(Qg.sub(e).mul(em.sub(Zg)).div(Qg.sub(Jg)).add(Zg))}).ElseIf(e.greaterThanEqual(tm),()=>{t.assign(Jg.sub(e).mul(rm.sub(em)).div(Jg.sub(tm)).add(em))}).Else(()=>{t.assign(Zi(-2).mul(Qa(ma(1.16,e))))}),t}).setLayout({name:"roughnessToMip",type:"float",inputs:[{name:"roughness",type:"float"}]}),um=ji(([e,t])=>{const r=e.toVar();r.assign(ma(2,r).sub(1));const s=on(r,1).toVar();return Ki(t.equal(0),()=>{s.assign(s.zyx)}).ElseIf(t.equal(1),()=>{s.assign(s.xzy),s.xz.mulAssign(-1)}).ElseIf(t.equal(2),()=>{s.x.mulAssign(-1)}).ElseIf(t.equal(3),()=>{s.assign(s.zyx),s.xz.mulAssign(-1)}).ElseIf(t.equal(4),()=>{s.assign(s.xzy),s.xy.mulAssign(-1)}).ElseIf(t.equal(5),()=>{s.z.mulAssign(-1)}),s}).setLayout({name:"getDirection",type:"vec3",inputs:[{name:"uv",type:"vec2"},{name:"face",type:"float"}]}),lm=ji(([e,t,r,s,i,n])=>{const a=Zi(r),o=on(t),u=Ho(om(a),Xg,n),l=so(u),d=eo(u),c=on(dm(e,o,d,s,i,n)).toVar();return Ki(l.notEqual(0),()=>{const t=on(dm(e,o,d.add(1),s,i,n)).toVar();c.assign(zo(c,t,l))}),c}),dm=ji(([e,t,r,s,i,n])=>{const a=Zi(r).toVar(),o=on(t),u=Zi(nm(o)).toVar(),l=Zi(Ro(sm.sub(a),0)).toVar();a.assign(Ro(a,sm));const d=Zi(Ka(a)).toVar(),c=rn(am(o,u).mul(d.sub(2)).add(1)).toVar();return Ki(u.greaterThan(2),()=>{c.y.addAssign(d),u.subAssign(3)}),c.x.addAssign(u.mul(d)),c.x.addAssign(l.mul(ma(3,im))),c.y.addAssign(ma(4,Ka(n).sub(d))),c.x.mulAssign(s),c.y.mulAssign(i),e.sample(c).grad(rn(),rn())}),cm=ji(({envMap:e,mipInt:t,outputDirection:r,theta:s,axis:i,CUBEUV_TEXEL_WIDTH:n,CUBEUV_TEXEL_HEIGHT:a,CUBEUV_MAX_MIP:o})=>{const u=no(s),l=r.mul(u).add(i.cross(r).mul(io(s))).add(i.mul(i.dot(r).mul(u.oneMinus())));return dm(e,l,t,n,a,o)}),hm=ji(({n:e,latitudinal:t,poleAxis:r,outputDirection:s,weights:i,samples:n,dTheta:a,mipInt:o,envMap:u,CUBEUV_TEXEL_WIDTH:l,CUBEUV_TEXEL_HEIGHT:d,CUBEUV_MAX_MIP:c})=>{const h=on(ru(t,r,Lo(r,s))).toVar();Ki(h.equal(on(0)),()=>{h.assign(on(s.z,0,s.x.negate()))}),h.assign(ro(h));const p=on().toVar();return p.addAssign(i.element(0).mul(cm({theta:0,axis:h,outputDirection:s,mipInt:o,envMap:u,CUBEUV_TEXEL_WIDTH:l,CUBEUV_TEXEL_HEIGHT:d,CUBEUV_MAX_MIP:c}))),Lh({start:Ji(1),end:e},({i:e})=>{Ki(e.greaterThanEqual(n),()=>{Ih()});const t=Zi(a.mul(Zi(e))).toVar();p.addAssign(i.element(e).mul(cm({theta:t.mul(-1),axis:h,outputDirection:s,mipInt:o,envMap:u,CUBEUV_TEXEL_WIDTH:l,CUBEUV_TEXEL_HEIGHT:d,CUBEUV_MAX_MIP:c}))),p.addAssign(i.element(e).mul(cm({theta:t,axis:h,outputDirection:s,mipInt:o,envMap:u,CUBEUV_TEXEL_WIDTH:l,CUBEUV_TEXEL_HEIGHT:d,CUBEUV_MAX_MIP:c})))}),cn(p,1)}),pm=[.125,.215,.35,.446,.526,.582],gm=20,mm=new ae(-1,1,1,-1,0,1),fm=new oe(90,1),ym=new e;let bm=null,xm=0,Tm=0;const _m=(1+Math.sqrt(5))/2,vm=1/_m,Nm=[new r(-_m,vm,0),new r(_m,vm,0),new r(-vm,0,_m),new r(vm,0,_m),new r(0,_m,-vm),new r(0,_m,vm),new r(-1,1,-1),new r(1,1,-1),new r(-1,1,1),new r(1,1,1)],Sm=new r,Em=new WeakMap,wm=[3,1,5,0,4,2],Am=um(tl(),el("faceIndex")).normalize(),Rm=on(Am.x,Am.y,Am.z);class Cm{constructor(e){this._renderer=e,this._pingPongRenderTarget=null,this._lodMax=0,this._cubeSize=0,this._lodPlanes=[],this._sizeLods=[],this._sigmas=[],this._lodMeshes=[],this._blurMaterial=null,this._cubemapMaterial=null,this._equirectMaterial=null,this._backgroundBox=null}get _hasInitialized(){return this._renderer.hasInitialized()}fromScene(e,t=0,r=.1,s=100,i={}){const{size:n=256,position:a=Sm,renderTarget:o=null}=i;if(this._setSize(n),!1===this._hasInitialized){console.warn("THREE.PMREMGenerator: .fromScene() called before the backend is initialized. Try using .fromSceneAsync() instead.");const n=o||this._allocateTarget();return i.renderTarget=n,this.fromSceneAsync(e,t,r,s,i),n}bm=this._renderer.getRenderTarget(),xm=this._renderer.getActiveCubeFace(),Tm=this._renderer.getActiveMipmapLevel();const u=o||this._allocateTarget();return u.depthBuffer=!0,this._init(u),this._sceneToCubeUV(e,r,s,u,a),t>0&&this._blur(u,0,0,t),this._applyPMREM(u),this._cleanup(u),u}async fromSceneAsync(e,t=0,r=.1,s=100,i={}){return!1===this._hasInitialized&&await this._renderer.init(),this.fromScene(e,t,r,s,i)}fromEquirectangular(e,t=null){if(!1===this._hasInitialized){console.warn("THREE.PMREMGenerator: .fromEquirectangular() called before the backend is initialized. Try using .fromEquirectangularAsync() instead."),this._setSizeFromTexture(e);const r=t||this._allocateTarget();return this.fromEquirectangularAsync(e,r),r}return this._fromTexture(e,t)}async fromEquirectangularAsync(e,t=null){return!1===this._hasInitialized&&await this._renderer.init(),this._fromTexture(e,t)}fromCubemap(e,t=null){if(!1===this._hasInitialized){console.warn("THREE.PMREMGenerator: .fromCubemap() called before the backend is initialized. Try using .fromCubemapAsync() instead."),this._setSizeFromTexture(e);const r=t||this._allocateTarget();return this.fromCubemapAsync(e,t),r}return this._fromTexture(e,t)}async fromCubemapAsync(e,t=null){return!1===this._hasInitialized&&await this._renderer.init(),this._fromTexture(e,t)}async compileCubemapShader(){null===this._cubemapMaterial&&(this._cubemapMaterial=Fm(),await this._compileMaterial(this._cubemapMaterial))}async compileEquirectangularShader(){null===this._equirectMaterial&&(this._equirectMaterial=Lm(),await this._compileMaterial(this._equirectMaterial))}dispose(){this._dispose(),null!==this._cubemapMaterial&&this._cubemapMaterial.dispose(),null!==this._equirectMaterial&&this._equirectMaterial.dispose(),null!==this._backgroundBox&&(this._backgroundBox.geometry.dispose(),this._backgroundBox.material.dispose())}_setSizeFromTexture(e){e.mapping===R||e.mapping===C?this._setSize(0===e.image.length?16:e.image[0].width||e.image[0].image.width):this._setSize(e.image.width/4)}_setSize(e){this._lodMax=Math.floor(Math.log2(e)),this._cubeSize=Math.pow(2,this._lodMax)}_dispose(){null!==this._blurMaterial&&this._blurMaterial.dispose(),null!==this._pingPongRenderTarget&&this._pingPongRenderTarget.dispose();for(let e=0;ee-4?u=pm[o-e+4-1]:0===o&&(u=0),s.push(u);const l=1/(a-2),d=-l,c=1+l,h=[d,d,c,d,c,c,d,d,c,c,d,c],p=6,g=6,m=3,f=2,y=1,b=new Float32Array(m*g*p),x=new Float32Array(f*g*p),T=new Float32Array(y*g*p);for(let e=0;e2?0:-1,s=[t,r,0,t+2/3,r,0,t+2/3,r+1,0,t,r,0,t+2/3,r+1,0,t,r+1,0],i=wm[e];b.set(s,m*g*i),x.set(h,f*g*i);const n=[i,i,i,i,i,i];T.set(n,y*g*i)}const _=new pe;_.setAttribute("position",new ge(b,m)),_.setAttribute("uv",new ge(x,f)),_.setAttribute("faceIndex",new ge(T,y)),t.push(_),i.push(new X(_,null)),n>4&&n--}return{lodPlanes:t,sizeLods:r,sigmas:s,lodMeshes:i}}(t)),this._blurMaterial=function(e,t,s){const i=ml(new Array(gm).fill(0)),n=ia(new r(0,1,0)),a=ia(0),o=Zi(gm),u=ia(0),l=ia(1),d=ll(null),c=ia(0),h=Zi(1/t),p=Zi(1/s),g=Zi(e),m={n:o,latitudinal:u,weights:i,poleAxis:n,outputDirection:Rm,dTheta:a,samples:l,envMap:d,mipInt:c,CUBEUV_TEXEL_WIDTH:h,CUBEUV_TEXEL_HEIGHT:p,CUBEUV_MAX_MIP:g},f=Bm("blur");return f.fragmentNode=hm({...m,latitudinal:u.equal(1)}),Em.set(f,m),f}(t,e.width,e.height)}}async _compileMaterial(e){const t=new X(this._lodPlanes[0],e);await this._renderer.compile(t,mm)}_sceneToCubeUV(e,t,r,s,i){const n=fm;n.near=t,n.far=r;const a=[1,1,1,1,-1,1],o=[1,-1,1,-1,1,-1],u=this._renderer,l=u.autoClear;u.getClearColor(ym),u.autoClear=!1;let d=this._backgroundBox;if(null===d){const e=new se({name:"PMREM.Background",side:S,depthWrite:!1,depthTest:!1});d=new X(new q,e)}let c=!1;const h=e.background;h?h.isColor&&(d.material.color.copy(h),e.background=null,c=!0):(d.material.color.copy(ym),c=!0),u.setRenderTarget(s),u.clear(),c&&u.render(d,n);for(let t=0;t<6;t++){const r=t%3;0===r?(n.up.set(0,a[t],0),n.position.set(i.x,i.y,i.z),n.lookAt(i.x+o[t],i.y,i.z)):1===r?(n.up.set(0,0,a[t]),n.position.set(i.x,i.y,i.z),n.lookAt(i.x,i.y+o[t],i.z)):(n.up.set(0,a[t],0),n.position.set(i.x,i.y,i.z),n.lookAt(i.x,i.y,i.z+o[t]));const l=this._cubeSize;Pm(s,r*l,t>2?l:0,l,l),u.render(e,n)}u.autoClear=l,e.background=h}_textureToCubeUV(e,t){const r=this._renderer,s=e.mapping===R||e.mapping===C;s?null===this._cubemapMaterial&&(this._cubemapMaterial=Fm(e)):null===this._equirectMaterial&&(this._equirectMaterial=Lm(e));const i=s?this._cubemapMaterial:this._equirectMaterial;i.fragmentNode.value=e;const n=this._lodMeshes[0];n.material=i;const a=this._cubeSize;Pm(t,0,0,3*a,2*a),r.setRenderTarget(t),r.render(n,mm)}_applyPMREM(e){const t=this._renderer,r=t.autoClear;t.autoClear=!1;const s=this._lodPlanes.length;for(let t=1;tgm&&console.warn(`sigmaRadians, ${i}, is too large and will clip, as it requested ${g} samples when the maximum is set to 20`);const m=[];let f=0;for(let e=0;ey-4?s-y+4:0),4*(this._cubeSize-b),3*b,2*b),o.setRenderTarget(t),o.render(l,mm)}}function Mm(e,t){const r=new ue(e,t,{magFilter:Y,minFilter:Y,generateMipmaps:!1,type:ce,format:de,colorSpace:le});return r.texture.mapping=he,r.texture.name="PMREM.cubeUv",r.texture.isPMREMTexture=!0,r.scissorTest=!0,r}function Pm(e,t,r,s,i){e.viewport.set(t,r,s,i),e.scissor.set(t,r,s,i)}function Bm(e){const t=new _p;return t.depthTest=!1,t.depthWrite=!1,t.blending=H,t.name=`PMREM_${e}`,t}function Fm(e){const t=Bm("cubemap");return t.fragmentNode=Gd(e,Rm),t}function Lm(e){const t=Bm("equirect");return t.fragmentNode=ll(e,Lp(Rm),0),t}const Im=new WeakMap;function Dm(e,t,r){const s=function(e){let t=Im.get(e);void 0===t&&(t=new WeakMap,Im.set(e,t));return t}(t);let i=s.get(e);if((void 0!==i?i.pmremVersion:-1)!==e.pmremVersion){const t=e.image;if(e.isCubeTexture){if(!function(e){if(null==e)return!1;let t=0;const r=6;for(let s=0;s0}(t))return null;i=r.fromEquirectangular(e,i)}i.pmremVersion=e.pmremVersion,s.set(e,i)}return i.texture}class Vm extends Zs{static get type(){return"PMREMNode"}constructor(e,t=null,r=null){super("vec3"),this._value=e,this._pmrem=null,this.uvNode=t,this.levelNode=r,this._generator=null;const s=new x;s.isRenderTargetTexture=!0,this._texture=ll(s),this._width=ia(0),this._height=ia(0),this._maxMip=ia(0),this.updateBeforeType=ks.RENDER}set value(e){this._value=e,this._pmrem=null}get value(){return this._value}updateFromTexture(e){const t=function(e){const t=Math.log2(e)-2,r=1/e;return{texelWidth:1/(3*Math.max(Math.pow(2,t),112)),texelHeight:r,maxMip:t}}(e.image.height);this._texture.value=e,this._width.value=t.texelWidth,this._height.value=t.texelHeight,this._maxMip.value=t.maxMip}updateBefore(e){let t=this._pmrem;const r=t?t.pmremVersion:-1,s=this._value;r!==s.pmremVersion&&(t=!0===s.isPMREMTexture?s:Dm(s,e.renderer,this._generator),null!==t&&(this._pmrem=t,this.updateFromTexture(t)))}setup(e){null===this._generator&&(this._generator=new Cm(e.renderer)),this.updateBefore(e);let t=this.uvNode;null===t&&e.context.getUV&&(t=e.context.getUV(this)),t=Fd.mul(on(t.x,t.y.negate(),t.z));let r=this.levelNode;return null===r&&e.context.getTextureLevel&&(r=e.context.getTextureLevel(this)),lm(this._texture,t,r,this._width,this._height,this._maxMip)}dispose(){super.dispose(),null!==this._generator&&this._generator.dispose()}}const Um=Gi(Vm).setParameterLength(1,3),Om=new WeakMap;class km extends Gh{static get type(){return"EnvironmentNode"}constructor(e=null){super(),this.envNode=e}setup(e){const{material:t}=e;let r=this.envNode;if(r.isTextureNode||r.isMaterialReferenceNode){const e=r.isTextureNode?r.value:t[r.property];let s=Om.get(e);void 0===s&&(s=Um(e),Om.set(e,s)),r=s}const s=!0===t.useAnisotropy||t.anisotropy>0?xc:_d,i=r.context(Gm(En,s)).mul(Bd),n=r.context(zm(vd)).mul(Math.PI).mul(Bd),a=ku(i),o=ku(n);e.context.radiance.addAssign(a),e.context.iblIrradiance.addAssign(o);const u=e.context.lightingModel.clearcoatRadiance;if(u){const e=r.context(Gm(Rn,Nd)).mul(Bd),t=ku(e);u.addAssign(t)}}}const Gm=(e,t)=>{let r=null;return{getUV:()=>(null===r&&(r=cd.negate().reflect(t),r=e.mul(e).mix(r,t).normalize(),r=r.transformDirection(Fl)),r),getTextureLevel:()=>e}},zm=e=>({getUV:()=>e,getTextureLevel:()=>Zi(1)}),Hm=new me;class $m extends _p{static get type(){return"MeshStandardNodeMaterial"}constructor(e){super(),this.isMeshStandardNodeMaterial=!0,this.lights=!0,this.emissiveNode=null,this.metalnessNode=null,this.roughnessNode=null,this.setDefaultValues(Hm),this.setValues(e)}setupEnvironment(e){let t=super.setupEnvironment(e);return null===t&&e.environmentNode&&(t=e.environmentNode),t?new km(t):null}setupLightingModel(){return new jg}setupSpecular(){const e=zo(on(.04),Nn.rgb,wn);Un.assign(e),On.assign(1)}setupVariants(){const e=this.metalnessNode?Zi(this.metalnessNode):Oc;wn.assign(e);let t=this.roughnessNode?Zi(this.roughnessNode):Uc;t=sg({roughness:t}),En.assign(t),this.setupSpecular(),Nn.assign(cn(Nn.rgb.mul(e.oneMinus()),Nn.a))}copy(e){return this.emissiveNode=e.emissiveNode,this.metalnessNode=e.metalnessNode,this.roughnessNode=e.roughnessNode,super.copy(e)}}const Wm=new fe;class jm extends $m{static get type(){return"MeshPhysicalNodeMaterial"}constructor(e){super(),this.isMeshPhysicalNodeMaterial=!0,this.clearcoatNode=null,this.clearcoatRoughnessNode=null,this.clearcoatNormalNode=null,this.sheenNode=null,this.sheenRoughnessNode=null,this.iridescenceNode=null,this.iridescenceIORNode=null,this.iridescenceThicknessNode=null,this.specularIntensityNode=null,this.specularColorNode=null,this.iorNode=null,this.transmissionNode=null,this.thicknessNode=null,this.attenuationDistanceNode=null,this.attenuationColorNode=null,this.dispersionNode=null,this.anisotropyNode=null,this.setDefaultValues(Wm),this.setValues(e)}get useClearcoat(){return this.clearcoat>0||null!==this.clearcoatNode}get useIridescence(){return this.iridescence>0||null!==this.iridescenceNode}get useSheen(){return this.sheen>0||null!==this.sheenNode}get useAnisotropy(){return this.anisotropy>0||null!==this.anisotropyNode}get useTransmission(){return this.transmission>0||null!==this.transmissionNode}get useDispersion(){return this.dispersion>0||null!==this.dispersionNode}setupSpecular(){const e=this.iorNode?Zi(this.iorNode):Jc;Wn.assign(e),Un.assign(zo(Ao(Do(Wn.sub(1).div(Wn.add(1))).mul(Ic),on(1)).mul(Lc),Nn.rgb,wn)),On.assign(zo(Lc,1,wn))}setupLightingModel(){return new jg(this.useClearcoat,this.useSheen,this.useIridescence,this.useAnisotropy,this.useTransmission,this.useDispersion)}setupVariants(e){if(super.setupVariants(e),this.useClearcoat){const e=this.clearcoatNode?Zi(this.clearcoatNode):Gc,t=this.clearcoatRoughnessNode?Zi(this.clearcoatRoughnessNode):zc;An.assign(e),Rn.assign(sg({roughness:t}))}if(this.useSheen){const e=this.sheenNode?on(this.sheenNode):Wc,t=this.sheenRoughnessNode?Zi(this.sheenRoughnessNode):jc;Cn.assign(e),Mn.assign(t)}if(this.useIridescence){const e=this.iridescenceNode?Zi(this.iridescenceNode):Xc,t=this.iridescenceIORNode?Zi(this.iridescenceIORNode):Kc,r=this.iridescenceThicknessNode?Zi(this.iridescenceThicknessNode):Yc;Pn.assign(e),Bn.assign(t),Fn.assign(r)}if(this.useAnisotropy){const e=(this.anisotropyNode?rn(this.anisotropyNode):qc).toVar();In.assign(e.length()),Ki(In.equal(0),()=>{e.assign(rn(1,0))}).Else(()=>{e.divAssign(rn(In)),In.assign(In.saturate())}),Ln.assign(In.pow2().mix(En.pow2(),1)),Dn.assign(yc[0].mul(e.x).add(yc[1].mul(e.y))),Vn.assign(yc[1].mul(e.x).sub(yc[0].mul(e.y)))}if(this.useTransmission){const e=this.transmissionNode?Zi(this.transmissionNode):Qc,t=this.thicknessNode?Zi(this.thicknessNode):Zc,r=this.attenuationDistanceNode?Zi(this.attenuationDistanceNode):eh,s=this.attenuationColorNode?on(this.attenuationColorNode):th;if(jn.assign(e),qn.assign(t),Xn.assign(r),Kn.assign(s),this.useDispersion){const e=this.dispersionNode?Zi(this.dispersionNode):uh;Yn.assign(e)}}}setupClearcoatNormal(){return this.clearcoatNormalNode?on(this.clearcoatNormalNode):Hc}setup(e){e.context.setupClearcoatNormal=()=>gu(this.setupClearcoatNormal(e),"NORMAL","vec3"),super.setup(e)}copy(e){return this.clearcoatNode=e.clearcoatNode,this.clearcoatRoughnessNode=e.clearcoatRoughnessNode,this.clearcoatNormalNode=e.clearcoatNormalNode,this.sheenNode=e.sheenNode,this.sheenRoughnessNode=e.sheenRoughnessNode,this.iridescenceNode=e.iridescenceNode,this.iridescenceIORNode=e.iridescenceIORNode,this.iridescenceThicknessNode=e.iridescenceThicknessNode,this.specularIntensityNode=e.specularIntensityNode,this.specularColorNode=e.specularColorNode,this.transmissionNode=e.transmissionNode,this.thicknessNode=e.thicknessNode,this.attenuationDistanceNode=e.attenuationDistanceNode,this.attenuationColorNode=e.attenuationColorNode,this.dispersionNode=e.dispersionNode,this.anisotropyNode=e.anisotropyNode,super.copy(e)}}class qm extends jg{constructor(e=!1,t=!1,r=!1,s=!1,i=!1,n=!1,a=!1){super(e,t,r,s,i,n),this.useSSS=a}direct({lightDirection:e,lightColor:t,reflectedLight:r},s){if(!0===this.useSSS){const i=s.material,{thicknessColorNode:n,thicknessDistortionNode:a,thicknessAmbientNode:o,thicknessAttenuationNode:u,thicknessPowerNode:l,thicknessScaleNode:d}=i,c=e.add(_d.mul(a)).normalize(),h=Zi(cd.dot(c.negate()).saturate().pow(l).mul(d)),p=on(h.add(o).mul(n));r.directDiffuse.addAssign(p.mul(u.mul(t)))}super.direct({lightDirection:e,lightColor:t,reflectedLight:r},s)}}class Xm extends jm{static get type(){return"MeshSSSNodeMaterial"}constructor(e){super(e),this.thicknessColorNode=null,this.thicknessDistortionNode=Zi(.1),this.thicknessAmbientNode=Zi(0),this.thicknessAttenuationNode=Zi(.1),this.thicknessPowerNode=Zi(2),this.thicknessScaleNode=Zi(10)}get useSSS(){return null!==this.thicknessColorNode}setupLightingModel(){return new qm(this.useClearcoat,this.useSheen,this.useIridescence,this.useAnisotropy,this.useTransmission,this.useDispersion,this.useSSS)}copy(e){return this.thicknessColorNode=e.thicknessColorNode,this.thicknessDistortionNode=e.thicknessDistortionNode,this.thicknessAmbientNode=e.thicknessAmbientNode,this.thicknessAttenuationNode=e.thicknessAttenuationNode,this.thicknessPowerNode=e.thicknessPowerNode,this.thicknessScaleNode=e.thicknessScaleNode,super.copy(e)}}const Km=ji(({normal:e,lightDirection:t,builder:r})=>{const s=e.dot(t),i=rn(s.mul(.5).add(.5),0);if(r.material.gradientMap){const e=qd("gradientMap","texture").context({getUV:()=>i});return on(e.r)}{const e=i.fwidth().mul(.5);return zo(on(.7),on(1),jo(Zi(.7).sub(e.x),Zi(.7).add(e.x),i.x))}});class Ym extends Hp{direct({lightDirection:e,lightColor:t,reflectedLight:r},s){const i=Km({normal:fd,lightDirection:e,builder:s}).mul(t);r.directDiffuse.addAssign(i.mul(Xp({diffuseColor:Nn.rgb})))}indirect(e){const{ambientOcclusion:t,irradiance:r,reflectedLight:s}=e.context;s.indirectDiffuse.addAssign(r.mul(Xp({diffuseColor:Nn}))),s.indirectDiffuse.mulAssign(t)}}const Qm=new ye;class Zm extends _p{static get type(){return"MeshToonNodeMaterial"}constructor(e){super(),this.isMeshToonNodeMaterial=!0,this.lights=!0,this.setDefaultValues(Qm),this.setValues(e)}setupLightingModel(){return new Ym}}const Jm=ji(()=>{const e=on(cd.z,0,cd.x.negate()).normalize(),t=cd.cross(e);return rn(e.dot(_d),t.dot(_d)).mul(.495).add(.5)}).once(["NORMAL","VERTEX"])().toVar("matcapUV"),ef=new be;class tf extends _p{static get type(){return"MeshMatcapNodeMaterial"}constructor(e){super(),this.isMeshMatcapNodeMaterial=!0,this.setDefaultValues(ef),this.setValues(e)}setupVariants(e){const t=Jm;let r;r=e.material.matcap?qd("matcap","texture").context({getUV:()=>t}):on(zo(.2,.8,t.y)),Nn.rgb.mulAssign(r.rgb)}}class rf extends Zs{static get type(){return"RotateNode"}constructor(e,t){super(),this.positionNode=e,this.rotationNode=t}getNodeType(e){return this.positionNode.getNodeType(e)}setup(e){const{rotationNode:t,positionNode:r}=this;if("vec2"===this.getNodeType(e)){const e=t.cos(),s=t.sin();return mn(e,s,s.negate(),e).mul(r)}{const e=t,s=yn(cn(1,0,0,0),cn(0,no(e.x),io(e.x).negate(),0),cn(0,io(e.x),no(e.x),0),cn(0,0,0,1)),i=yn(cn(no(e.y),0,io(e.y),0),cn(0,1,0,0),cn(io(e.y).negate(),0,no(e.y),0),cn(0,0,0,1)),n=yn(cn(no(e.z),io(e.z).negate(),0,0),cn(io(e.z),no(e.z),0,0),cn(0,0,1,0),cn(0,0,0,1));return s.mul(i).mul(n).mul(cn(r,1)).xyz}}}const sf=Gi(rf).setParameterLength(2),nf=new xe;class af extends _p{static get type(){return"SpriteNodeMaterial"}constructor(e){super(),this.isSpriteNodeMaterial=!0,this._useSizeAttenuation=!0,this.positionNode=null,this.rotationNode=null,this.scaleNode=null,this.transparent=!0,this.setDefaultValues(nf),this.setValues(e)}setupPositionView(e){const{object:t,camera:r}=e,s=this.sizeAttenuation,{positionNode:i,rotationNode:n,scaleNode:a}=this,o=td.mul(on(i||0));let u=rn(Xl[0].xyz.length(),Xl[1].xyz.length());if(null!==a&&(u=u.mul(rn(a))),!1===s)if(r.isPerspectiveCamera)u=u.mul(o.z.negate());else{const e=Zi(2).div(Pl.element(1).element(1));u=u.mul(e.mul(2))}let l=nd.xy;if(t.center&&!0===t.center.isVector2){const e=((e,t,r)=>Vi(new Eu(e,t,r)))("center","vec2",t);l=l.sub(e.sub(.5))}l=l.mul(u);const d=Zi(n||$c),c=sf(l,d);return cn(o.xy.add(c),o.zw)}copy(e){return this.positionNode=e.positionNode,this.rotationNode=e.rotationNode,this.scaleNode=e.scaleNode,super.copy(e)}get sizeAttenuation(){return this._useSizeAttenuation}set sizeAttenuation(e){this._useSizeAttenuation!==e&&(this._useSizeAttenuation=e,this.needsUpdate=!0)}}const of=new Te;class uf extends af{static get type(){return"PointsNodeMaterial"}constructor(e){super(),this.sizeNode=null,this.isPointsNodeMaterial=!0,this.setDefaultValues(of),this.setValues(e)}setupPositionView(){const{positionNode:e}=this;return td.mul(on(e||ad)).xyz}setupVertex(e){const{material:t,camera:r}=e,{rotationNode:s,scaleNode:i,sizeNode:n,sizeAttenuation:a}=this;let o=super.setupVertex(e);if(!0!==t.isNodeMaterial)return o;let u=null!==n?rn(n):oh;const l=e.renderer.getPixelRatio();if(u=u.mul(l),r.isPerspectiveCamera&&!0===a){const e=Zi(.5).mul(_l.y).div(l);u=u.mul(e.div(dd.z.negate()))}i&&i.isNode&&(u=u.mul(rn(i)));let d=nd.xy;if(s&&s.isNode){const e=Zi(s);d=sf(d,e)}return d=d.mul(u),d=d.div(Sl.div(2)),d=d.mul(o.w),o=o.add(cn(d,0,0)),o}get alphaToCoverage(){return this._useAlphaToCoverage}set alphaToCoverage(e){this._useAlphaToCoverage!==e&&(this._useAlphaToCoverage=e,this.needsUpdate=!0)}}class lf extends Hp{constructor(){super(),this.shadowNode=Zi(1).toVar("shadowMask")}direct({lightNode:e}){null!==e.shadowNode&&this.shadowNode.mulAssign(e.shadowNode)}finish({context:e}){Nn.a.mulAssign(this.shadowNode.oneMinus()),e.outgoingLight.rgb.assign(Nn.rgb)}}const df=new _e;class cf extends _p{static get type(){return"ShadowNodeMaterial"}constructor(e){super(),this.isShadowNodeMaterial=!0,this.lights=!0,this.transparent=!0,this.setDefaultValues(df),this.setValues(e)}setupLightingModel(){return new lf}}const hf=_n("vec3"),pf=_n("vec3"),gf=_n("vec3");class mf extends Hp{constructor(){super()}start(e){const{material:t,context:r}=e,s=_n("vec3"),i=_n("vec3");Ki(Dl.sub(ud).length().greaterThan(Zl.mul(2)),()=>{s.assign(Dl),i.assign(ud)}).Else(()=>{s.assign(ud),i.assign(Dl)});const n=i.sub(s),a=ia("int").onRenderUpdate(({material:e})=>e.steps),o=n.length().div(a).toVar(),u=n.normalize().toVar(),l=Zi(0).toVar(),d=on(1).toVar();t.offsetNode&&l.addAssign(t.offsetNode.mul(o)),Lh(a,()=>{const i=s.add(u.mul(l)),n=Fl.mul(cn(i,1)).xyz;let a;null!==t.depthNode&&(pf.assign(ap(tp(n.z,Cl,Ml))),r.sceneDepthNode=ap(t.depthNode).toVar()),r.positionWorld=i,r.shadowPositionWorld=i,r.positionView=n,hf.assign(0),t.scatteringNode&&(a=t.scatteringNode({positionRay:i})),super.start(e),a&&hf.mulAssign(a);const c=hf.mul(.01).negate().mul(o).exp();d.mulAssign(c),l.addAssign(o)}),gf.addAssign(d.saturate().oneMinus())}scatteringLight(e,t){const r=t.context.sceneDepthNode;r?Ki(r.greaterThanEqual(pf),()=>{hf.addAssign(e)}):hf.addAssign(e)}direct({lightNode:e,lightColor:t},r){if(void 0===e.light.distance)return;const s=t.xyz.toVar();s.mulAssign(e.shadowNode),this.scatteringLight(s,r)}directRectArea({lightColor:e,lightPosition:t,halfWidth:r,halfHeight:s},i){const n=t.add(r).sub(s),a=t.sub(r).sub(s),o=t.sub(r).add(s),u=t.add(r).add(s),l=i.context.positionView,d=e.xyz.mul(Tg({P:l,p0:n,p1:a,p2:o,p3:u})).pow(1.5);this.scatteringLight(d,i)}finish(e){e.context.outgoingLight.assign(gf)}}class ff extends _p{static get type(){return"VolumeNodeMaterial"}constructor(e){super(),this.isVolumeNodeMaterial=!0,this.steps=25,this.offsetNode=null,this.scatteringNode=null,this.lights=!0,this.transparent=!0,this.side=S,this.depthTest=!1,this.depthWrite=!1,this.setValues(e)}setupLightingModel(){return new mf}}class yf{constructor(e,t){this.nodes=e,this.info=t,this._context="undefined"!=typeof self?self:null,this._animationLoop=null,this._requestId=null}start(){const e=(t,r)=>{this._requestId=this._context.requestAnimationFrame(e),!0===this.info.autoReset&&this.info.reset(),this.nodes.nodeFrame.update(),this.info.frame=this.nodes.nodeFrame.frameId,null!==this._animationLoop&&this._animationLoop(t,r)};e()}stop(){this._context.cancelAnimationFrame(this._requestId),this._requestId=null}getAnimationLoop(){return this._animationLoop}setAnimationLoop(e){this._animationLoop=e}getContext(){return this._context}setContext(e){this._context=e}dispose(){this.stop()}}class bf{constructor(){this.weakMap=new WeakMap}get(e){let t=this.weakMap;for(let r=0;r{this.dispose()},this.onGeometryDispose=()=>{this.attributes=null,this.attributesId=null},this.material.addEventListener("dispose",this.onMaterialDispose),this.geometry.addEventListener("dispose",this.onGeometryDispose)}updateClipping(e){this.clippingContext=e}get clippingNeedsUpdate(){return null!==this.clippingContext&&this.clippingContext.cacheKey!==this.clippingContextCacheKey&&(this.clippingContextCacheKey=this.clippingContext.cacheKey,!0)}get hardwareClippingPlanes(){return!0===this.material.hardwareClipping?this.clippingContext.unionClippingCount:0}getNodeBuilderState(){return this._nodeBuilderState||(this._nodeBuilderState=this._nodes.getForRender(this))}getMonitor(){return this._monitor||(this._monitor=this.getNodeBuilderState().observer)}getBindings(){return this._bindings||(this._bindings=this.getNodeBuilderState().createBindings())}getBindingGroup(e){for(const t of this.getBindings())if(t.name===e)return t}getIndex(){return this._geometries.getIndex(this)}getIndirect(){return this._geometries.getIndirect(this)}getChainArray(){return[this.object,this.material,this.context,this.lightsNode]}setGeometry(e){this.geometry=e,this.attributes=null,this.attributesId=null}getAttributes(){if(null!==this.attributes)return this.attributes;const e=this.getNodeBuilderState().nodeAttributes,t=this.geometry,r=[],s=new Set,i={};for(const n of e){let e;if(n.node&&n.node.attribute?e=n.node.attribute:(e=t.getAttribute(n.name),i[n.name]=e.version),void 0===e)continue;r.push(e);const a=e.isInterleavedBufferAttribute?e.data:e;s.add(a)}return this.attributes=r,this.attributesId=i,this.vertexBuffers=Array.from(s.values()),r}getVertexBuffers(){return null===this.vertexBuffers&&this.getAttributes(),this.vertexBuffers}getDrawParameters(){const{object:e,material:t,geometry:r,group:s,drawRange:i}=this,n=this.drawParams||(this.drawParams={vertexCount:0,firstVertex:0,instanceCount:0,firstInstance:0}),a=this.getIndex(),o=null!==a;let u=1;if(!0===r.isInstancedBufferGeometry?u=r.instanceCount:void 0!==e.count&&(u=Math.max(0,e.count)),0===u)return null;if(n.instanceCount=u,!0===e.isBatchedMesh)return n;let l=1;!0!==t.wireframe||e.isPoints||e.isLineSegments||e.isLine||e.isLineLoop||(l=2);let d=i.start*l,c=(i.start+i.count)*l;null!==s&&(d=Math.max(d,s.start*l),c=Math.min(c,(s.start+s.count)*l));const h=r.attributes.position;let p=1/0;o?p=a.count:null!=h&&(p=h.count),d=Math.max(d,0),c=Math.min(c,p);const g=c-d;return g<0||g===1/0?null:(n.vertexCount=g,n.firstVertex=d,n)}getGeometryCacheKey(){const{geometry:e}=this;let t="";for(const r of Object.keys(e.attributes).sort()){const s=e.attributes[r];t+=r+",",s.data&&(t+=s.data.stride+","),s.offset&&(t+=s.offset+","),s.itemSize&&(t+=s.itemSize+","),s.normalized&&(t+="n,")}for(const r of Object.keys(e.morphAttributes).sort()){const s=e.morphAttributes[r];t+="morph-"+r+",";for(let e=0,r=s.length;e1&&(r+=e.uuid+","),r+=e.receiveShadow+",",_s(r)}get needsGeometryUpdate(){if(this.geometry.id!==this.object.geometry.id)return!0;if(null!==this.attributes){const e=this.attributesId;for(const t in e){const r=this.geometry.getAttribute(t);if(void 0===r||e[t]!==r.id)return!0}}return!1}get needsUpdate(){return this.initialNodesCacheKey!==this.getDynamicCacheKey()||this.clippingNeedsUpdate}getDynamicCacheKey(){let e=0;return!0!==this.material.isShadowPassMaterial&&(e=this._nodes.getCacheKey(this.scene,this.lightsNode)),this.camera.isArrayCamera&&(e=Ns(e,this.camera.cameras.length)),this.object.receiveShadow&&(e=Ns(e,1)),e}getCacheKey(){return this.getMaterialCacheKey()+this.getDynamicCacheKey()}dispose(){this.material.removeEventListener("dispose",this.onMaterialDispose),this.geometry.removeEventListener("dispose",this.onGeometryDispose),this.onDispose()}}const _f=[];class vf{constructor(e,t,r,s,i,n){this.renderer=e,this.nodes=t,this.geometries=r,this.pipelines=s,this.bindings=i,this.info=n,this.chainMaps={}}get(e,t,r,s,i,n,a,o){const u=this.getChainMap(o);_f[0]=e,_f[1]=t,_f[2]=n,_f[3]=i;let l=u.get(_f);return void 0===l?(l=this.createRenderObject(this.nodes,this.geometries,this.renderer,e,t,r,s,i,n,a,o),u.set(_f,l)):(l.updateClipping(a),l.needsGeometryUpdate&&l.setGeometry(e.geometry),(l.version!==t.version||l.needsUpdate)&&(l.initialCacheKey!==l.getCacheKey()?(l.dispose(),l=this.get(e,t,r,s,i,n,a,o)):l.version=t.version)),_f.length=0,l}getChainMap(e="default"){return this.chainMaps[e]||(this.chainMaps[e]=new bf)}dispose(){this.chainMaps={}}createRenderObject(e,t,r,s,i,n,a,o,u,l,d){const c=this.getChainMap(d),h=new Tf(e,t,r,s,i,n,a,o,u,l);return h.onDispose=()=>{this.pipelines.delete(h),this.bindings.delete(h),this.nodes.delete(h),c.delete(h.getChainArray())},h}}class Nf{constructor(){this.data=new WeakMap}get(e){let t=this.data.get(e);return void 0===t&&(t={},this.data.set(e,t)),t}delete(e){let t=null;return this.data.has(e)&&(t=this.data.get(e),this.data.delete(e)),t}has(e){return this.data.has(e)}dispose(){this.data=new WeakMap}}const Sf=1,Ef=2,wf=3,Af=4,Rf=16;class Cf extends Nf{constructor(e){super(),this.backend=e}delete(e){const t=super.delete(e);return null!==t&&this.backend.destroyAttribute(e),t}update(e,t){const r=this.get(e);if(void 0===r.version)t===Sf?this.backend.createAttribute(e):t===Ef?this.backend.createIndexAttribute(e):t===wf?this.backend.createStorageAttribute(e):t===Af&&this.backend.createIndirectStorageAttribute(e),r.version=this._getBufferAttribute(e).version;else{const t=this._getBufferAttribute(e);(r.version{this.info.memory.geometries--;const s=t.index,i=e.getAttributes();null!==s&&this.attributes.delete(s);for(const e of i)this.attributes.delete(e);const n=this.wireframes.get(t);void 0!==n&&this.attributes.delete(n),t.removeEventListener("dispose",r)};t.addEventListener("dispose",r)}updateAttributes(e){const t=e.getAttributes();for(const e of t)e.isStorageBufferAttribute||e.isStorageInstancedBufferAttribute?this.updateAttribute(e,wf):this.updateAttribute(e,Sf);const r=this.getIndex(e);null!==r&&this.updateAttribute(r,Ef);const s=e.geometry.indirect;null!==s&&this.updateAttribute(s,Af)}updateAttribute(e,t){const r=this.info.render.calls;e.isInterleavedBufferAttribute?void 0===this.attributeCall.get(e)?(this.attributes.update(e,t),this.attributeCall.set(e,r)):this.attributeCall.get(e.data)!==r&&(this.attributes.update(e,t),this.attributeCall.set(e.data,r),this.attributeCall.set(e,r)):this.attributeCall.get(e)!==r&&(this.attributes.update(e,t),this.attributeCall.set(e,r))}getIndirect(e){return e.geometry.indirect}getIndex(e){const{geometry:t,material:r}=e;let s=t.index;if(!0===r.wireframe){const e=this.wireframes;let r=e.get(t);void 0===r?(r=Pf(t),e.set(t,r)):r.version!==Mf(t)&&(this.attributes.delete(r),r=Pf(t),e.set(t,r)),s=r}return s}}class Ff{constructor(){this.autoReset=!0,this.frame=0,this.calls=0,this.render={calls:0,frameCalls:0,drawCalls:0,triangles:0,points:0,lines:0,timestamp:0},this.compute={calls:0,frameCalls:0,timestamp:0},this.memory={geometries:0,textures:0}}update(e,t,r){this.render.drawCalls++,e.isMesh||e.isSprite?this.render.triangles+=r*(t/3):e.isPoints?this.render.points+=r*t:e.isLineSegments?this.render.lines+=r*(t/2):e.isLine?this.render.lines+=r*(t-1):console.error("THREE.WebGPUInfo: Unknown object type.")}reset(){this.render.drawCalls=0,this.render.frameCalls=0,this.compute.frameCalls=0,this.render.triangles=0,this.render.points=0,this.render.lines=0}dispose(){this.reset(),this.calls=0,this.render.calls=0,this.compute.calls=0,this.render.timestamp=0,this.compute.timestamp=0,this.memory.geometries=0,this.memory.textures=0}}class Lf{constructor(e){this.cacheKey=e,this.usedTimes=0}}class If extends Lf{constructor(e,t,r){super(e),this.vertexProgram=t,this.fragmentProgram=r}}class Df extends Lf{constructor(e,t){super(e),this.computeProgram=t,this.isComputePipeline=!0}}let Vf=0;class Uf{constructor(e,t,r,s=null,i=null){this.id=Vf++,this.code=e,this.stage=t,this.name=r,this.transforms=s,this.attributes=i,this.usedTimes=0}}class Of extends Nf{constructor(e,t){super(),this.backend=e,this.nodes=t,this.bindings=null,this.caches=new Map,this.programs={vertex:new Map,fragment:new Map,compute:new Map}}getForCompute(e,t){const{backend:r}=this,s=this.get(e);if(this._needsComputeUpdate(e)){const i=s.pipeline;i&&(i.usedTimes--,i.computeProgram.usedTimes--);const n=this.nodes.getForCompute(e);let a=this.programs.compute.get(n.computeShader);void 0===a&&(i&&0===i.computeProgram.usedTimes&&this._releaseProgram(i.computeProgram),a=new Uf(n.computeShader,"compute",e.name,n.transforms,n.nodeAttributes),this.programs.compute.set(n.computeShader,a),r.createProgram(a));const o=this._getComputeCacheKey(e,a);let u=this.caches.get(o);void 0===u&&(i&&0===i.usedTimes&&this._releasePipeline(i),u=this._getComputePipeline(e,a,o,t)),u.usedTimes++,a.usedTimes++,s.version=e.version,s.pipeline=u}return s.pipeline}getForRender(e,t=null){const{backend:r}=this,s=this.get(e);if(this._needsRenderUpdate(e)){const i=s.pipeline;i&&(i.usedTimes--,i.vertexProgram.usedTimes--,i.fragmentProgram.usedTimes--);const n=e.getNodeBuilderState(),a=e.material?e.material.name:"";let o=this.programs.vertex.get(n.vertexShader);void 0===o&&(i&&0===i.vertexProgram.usedTimes&&this._releaseProgram(i.vertexProgram),o=new Uf(n.vertexShader,"vertex",a),this.programs.vertex.set(n.vertexShader,o),r.createProgram(o));let u=this.programs.fragment.get(n.fragmentShader);void 0===u&&(i&&0===i.fragmentProgram.usedTimes&&this._releaseProgram(i.fragmentProgram),u=new Uf(n.fragmentShader,"fragment",a),this.programs.fragment.set(n.fragmentShader,u),r.createProgram(u));const l=this._getRenderCacheKey(e,o,u);let d=this.caches.get(l);void 0===d?(i&&0===i.usedTimes&&this._releasePipeline(i),d=this._getRenderPipeline(e,o,u,l,t)):e.pipeline=d,d.usedTimes++,o.usedTimes++,u.usedTimes++,s.pipeline=d}return s.pipeline}delete(e){const t=this.get(e).pipeline;return t&&(t.usedTimes--,0===t.usedTimes&&this._releasePipeline(t),t.isComputePipeline?(t.computeProgram.usedTimes--,0===t.computeProgram.usedTimes&&this._releaseProgram(t.computeProgram)):(t.fragmentProgram.usedTimes--,t.vertexProgram.usedTimes--,0===t.vertexProgram.usedTimes&&this._releaseProgram(t.vertexProgram),0===t.fragmentProgram.usedTimes&&this._releaseProgram(t.fragmentProgram))),super.delete(e)}dispose(){super.dispose(),this.caches=new Map,this.programs={vertex:new Map,fragment:new Map,compute:new Map}}updateForRender(e){this.getForRender(e)}_getComputePipeline(e,t,r,s){r=r||this._getComputeCacheKey(e,t);let i=this.caches.get(r);return void 0===i&&(i=new Df(r,t),this.caches.set(r,i),this.backend.createComputePipeline(i,s)),i}_getRenderPipeline(e,t,r,s,i){s=s||this._getRenderCacheKey(e,t,r);let n=this.caches.get(s);return void 0===n&&(n=new If(s,t,r),this.caches.set(s,n),e.pipeline=n,this.backend.createRenderPipeline(e,i)),n}_getComputeCacheKey(e,t){return e.id+","+t.id}_getRenderCacheKey(e,t,r){return t.id+","+r.id+","+this.backend.getRenderCacheKey(e)}_releasePipeline(e){this.caches.delete(e.cacheKey)}_releaseProgram(e){const t=e.code,r=e.stage;this.programs[r].delete(t)}_needsComputeUpdate(e){const t=this.get(e);return void 0===t.pipeline||t.version!==e.version}_needsRenderUpdate(e){return void 0===this.get(e).pipeline||this.backend.needsRenderUpdate(e)}}class kf extends Nf{constructor(e,t,r,s,i,n){super(),this.backend=e,this.textures=r,this.pipelines=i,this.attributes=s,this.nodes=t,this.info=n,this.pipelines.bindings=this}getForRender(e){const t=e.getBindings();for(const e of t){const r=this.get(e);void 0===r.bindGroup&&(this._init(e),this.backend.createBindings(e,t,0),r.bindGroup=e)}return t}getForCompute(e){const t=this.nodes.getForCompute(e).bindings;for(const e of t){const r=this.get(e);void 0===r.bindGroup&&(this._init(e),this.backend.createBindings(e,t,0),r.bindGroup=e)}return t}updateForCompute(e){this._updateBindings(this.getForCompute(e))}updateForRender(e){this._updateBindings(this.getForRender(e))}_updateBindings(e){for(const t of e)this._update(t,e)}_init(e){for(const t of e.bindings)if(t.isSampledTexture)this.textures.updateTexture(t.texture);else if(t.isStorageBuffer){const e=t.attribute,r=e.isIndirectStorageBufferAttribute?Af:wf;this.attributes.update(e,r)}}_update(e,t){const{backend:r}=this;let s=!1,i=!0,n=0,a=0;for(const t of e.bindings){if(t.isNodeUniformsGroup){if(!1===this.nodes.updateGroup(t))continue}if(t.isStorageBuffer){const e=t.attribute,r=e.isIndirectStorageBufferAttribute?Af:wf;this.attributes.update(e,r)}if(t.isUniformBuffer){t.update()&&r.updateBinding(t)}else if(t.isSampledTexture){const e=t.update(),o=t.texture,u=this.textures.get(o);e&&(this.textures.updateTexture(o),t.generation!==u.generation&&(t.generation=u.generation,s=!0));if(void 0!==r.get(o).externalTexture||u.isDefaultTexture?i=!1:(n=10*n+o.id,a+=o.version),!0===o.isStorageTexture){const e=this.get(o);!0===t.store?e.needsMipmap=!0:this.textures.needsMipmaps(o)&&!0===e.needsMipmap&&(this.backend.generateMipmaps(o),e.needsMipmap=!1)}}else t.isSampler&&t.update()}!0===s&&this.backend.updateBindings(e,t,i?n:0,a)}}function Gf(e,t){return e.groupOrder!==t.groupOrder?e.groupOrder-t.groupOrder:e.renderOrder!==t.renderOrder?e.renderOrder-t.renderOrder:e.z!==t.z?e.z-t.z:e.id-t.id}function zf(e,t){return e.groupOrder!==t.groupOrder?e.groupOrder-t.groupOrder:e.renderOrder!==t.renderOrder?e.renderOrder-t.renderOrder:e.z!==t.z?t.z-e.z:e.id-t.id}function Hf(e){return(e.transmission>0||e.transmissionNode)&&e.side===E&&!1===e.forceSinglePass}class $f{constructor(e,t,r){this.renderItems=[],this.renderItemsIndex=0,this.opaque=[],this.transparentDoublePass=[],this.transparent=[],this.bundles=[],this.lightsNode=e.getNode(t,r),this.lightsArray=[],this.scene=t,this.camera=r,this.occlusionQueryCount=0}begin(){return this.renderItemsIndex=0,this.opaque.length=0,this.transparentDoublePass.length=0,this.transparent.length=0,this.bundles.length=0,this.lightsArray.length=0,this.occlusionQueryCount=0,this}getNextRenderItem(e,t,r,s,i,n,a){let o=this.renderItems[this.renderItemsIndex];return void 0===o?(o={id:e.id,object:e,geometry:t,material:r,groupOrder:s,renderOrder:e.renderOrder,z:i,group:n,clippingContext:a},this.renderItems[this.renderItemsIndex]=o):(o.id=e.id,o.object=e,o.geometry=t,o.material=r,o.groupOrder=s,o.renderOrder=e.renderOrder,o.z=i,o.group=n,o.clippingContext=a),this.renderItemsIndex++,o}push(e,t,r,s,i,n,a){const o=this.getNextRenderItem(e,t,r,s,i,n,a);!0===e.occlusionTest&&this.occlusionQueryCount++,!0===r.transparent||r.transmission>0?(Hf(r)&&this.transparentDoublePass.push(o),this.transparent.push(o)):this.opaque.push(o)}unshift(e,t,r,s,i,n,a){const o=this.getNextRenderItem(e,t,r,s,i,n,a);!0===r.transparent||r.transmission>0?(Hf(r)&&this.transparentDoublePass.unshift(o),this.transparent.unshift(o)):this.opaque.unshift(o)}pushBundle(e){this.bundles.push(e)}pushLight(e){this.lightsArray.push(e)}sort(e,t){this.opaque.length>1&&this.opaque.sort(e||Gf),this.transparentDoublePass.length>1&&this.transparentDoublePass.sort(t||zf),this.transparent.length>1&&this.transparent.sort(t||zf)}finish(){this.lightsNode.setLights(this.lightsArray);for(let e=this.renderItemsIndex,t=this.renderItems.length;e>t,u=a.height>>t;let l=e.depthTexture||i[t];const d=!0===e.depthBuffer||!0===e.stencilBuffer;let c=!1;void 0===l&&d&&(l=new U,l.format=e.stencilBuffer?we:Ae,l.type=e.stencilBuffer?Re:T,l.image.width=o,l.image.height=u,l.image.depth=a.depth,l.isArrayTexture=!0===e.multiview&&a.depth>1,i[t]=l),r.width===a.width&&a.height===r.height||(c=!0,l&&(l.needsUpdate=!0,l.image.width=o,l.image.height=u,l.image.depth=l.isArrayTexture?l.image.depth:1)),r.width=a.width,r.height=a.height,r.textures=n,r.depthTexture=l||null,r.depth=e.depthBuffer,r.stencil=e.stencilBuffer,r.renderTarget=e,r.sampleCount!==s&&(c=!0,l&&(l.needsUpdate=!0),r.sampleCount=s);const h={sampleCount:s};if(!0!==e.isXRRenderTarget){for(let e=0;e{e.removeEventListener("dispose",t);for(let e=0;e0){const s=e.image;if(void 0===s)console.warn("THREE.Renderer: Texture marked for update but image is undefined.");else if(!1===s.complete)console.warn("THREE.Renderer: Texture marked for update but image is incomplete.");else{if(e.images){const r=[];for(const t of e.images)r.push(t);t.images=r}else t.image=s;void 0!==r.isDefaultTexture&&!0!==r.isDefaultTexture||(i.createTexture(e,t),r.isDefaultTexture=!1,r.generation=e.version),!0===e.source.dataReady&&i.updateTexture(e,t),t.needsMipmaps&&0===e.mipmaps.length&&i.generateMipmaps(e)}}else i.createDefaultTexture(e),r.isDefaultTexture=!0,r.generation=e.version}if(!0!==r.initialized){r.initialized=!0,r.generation=e.version,this.info.memory.textures++,e.isVideoTexture&&c.getTransfer(e.colorSpace)!==h&&console.warn("WebGPURenderer: Video textures must use a color space with a sRGB transfer function, e.g. SRGBColorSpace.");const t=()=>{e.removeEventListener("dispose",t),this._destroyTexture(e)};e.addEventListener("dispose",t)}r.version=e.version}getSize(e,t=ey){let r=e.images?e.images[0]:e.image;return r?(void 0!==r.image&&(r=r.image),"undefined"!=typeof HTMLVideoElement&&r instanceof HTMLVideoElement?(t.width=r.videoWidth||1,t.height=r.videoHeight||1,t.depth=1):r instanceof VideoFrame?(t.width=r.displayWidth||1,t.height=r.displayHeight||1,t.depth=1):(t.width=r.width||1,t.height=r.height||1,t.depth=e.isCubeTexture?6:r.depth||1)):t.width=t.height=t.depth=1,t}getMipLevels(e,t,r){let s;return s=e.isCompressedTexture?e.mipmaps?e.mipmaps.length:1:Math.floor(Math.log2(Math.max(t,r)))+1,s}needsMipmaps(e){return!0===e.isCompressedTexture||e.generateMipmaps}_destroyTexture(e){!0===this.has(e)&&(this.backend.destroySampler(e),this.backend.destroyTexture(e),this.delete(e),this.info.memory.textures--)}}class ry extends e{constructor(e,t,r,s=1){super(e,t,r),this.a=s}set(e,t,r,s=1){return this.a=s,super.set(e,t,r)}copy(e){return void 0!==e.a&&(this.a=e.a),super.copy(e)}clone(){return new this.constructor(this.r,this.g,this.b,this.a)}}class sy extends Tn{static get type(){return"ParameterNode"}constructor(e,t=null){super(e,t),this.isParameterNode=!0}getHash(){return this.uuid}generate(){return this.name}}class iy extends Ks{static get type(){return"StackNode"}constructor(e=null){super(),this.nodes=[],this.outputNode=null,this.parent=e,this._currentCond=null,this._expressionNode=null,this.isStackNode=!0}getNodeType(e){return this.hasOutput?this.outputNode.getNodeType(e):"void"}getMemberType(e,t){return this.hasOutput?this.outputNode.getMemberType(e,t):"void"}add(e){return!0!==e.isNode?(console.error("THREE.TSL: Invalid node added to stack."),this):(this.nodes.push(e),this)}If(e,t){const r=new Di(t);return this._currentCond=ru(e,r),this.add(this._currentCond)}ElseIf(e,t){const r=new Di(t),s=ru(e,r);return this._currentCond.elseNode=s,this._currentCond=s,this}Else(e){return this._currentCond.elseNode=new Di(e),this}Switch(e){return this._expressionNode=Vi(e),this}Case(...e){const t=[];if(e.length>=2)for(let r=0;r"string"==typeof t?{name:e,type:t,atomic:!1}:{name:e,type:t.type,atomic:t.atomic||!1})),this.name=t,this.isStructLayoutNode=!0}getLength(){const e=Float32Array.BYTES_PER_ELEMENT;let t=0;for(const r of this.membersLayout){const s=r.type,i=Ps(s)*e,n=t%8,a=n%Bs(s),o=n+a;t+=a,0!==o&&8-oe.name===t);return r?r.type:"void"}getNodeType(e){return e.getStructTypeFromNode(this,this.membersLayout,this.name).name}setup(e){e.addInclude(this)}generate(e){return this.getNodeType(e)}}class oy extends Ks{static get type(){return"StructNode"}constructor(e,t){super("vec3"),this.structLayoutNode=e,this.values=t,this.isStructNode=!0}getNodeType(e){return this.structLayoutNode.getNodeType(e)}getMemberType(e,t){return this.structLayoutNode.getMemberType(e,t)}generate(e){const t=e.getVarFromNode(this),r=t.type,s=e.getPropertyName(t);return e.addLineFlowCode(`${s} = ${e.generateStruct(r,this.structLayoutNode.membersLayout,this.values)}`,this),t.name}}class uy extends Ks{static get type(){return"OutputStructNode"}constructor(...e){super(),this.members=e,this.isOutputStructNode=!0}getNodeType(e){const t=e.getNodeProperties(this);if(void 0===t.membersLayout){const r=this.members,s=[];for(let t=0;t{const t=e.toUint().mul(747796405).add(2891336453),r=t.shiftRight(t.shiftRight(28).add(4)).bitXor(t).mul(277803737);return r.shiftRight(22).bitXor(r).toFloat().mul(1/2**32)}),gy=(e,t)=>Io(ma(4,e.mul(ga(1,e))),t),my=ji(([e])=>e.fract().sub(.5).abs()).setLayout({name:"tri",type:"float",inputs:[{name:"x",type:"float"}]}),fy=ji(([e])=>on(my(e.z.add(my(e.y.mul(1)))),my(e.z.add(my(e.x.mul(1)))),my(e.y.add(my(e.x.mul(1)))))).setLayout({name:"tri3",type:"vec3",inputs:[{name:"p",type:"vec3"}]}),yy=ji(([e,t,r])=>{const s=on(e).toVar(),i=Zi(1.4).toVar(),n=Zi(0).toVar(),a=on(s).toVar();return Lh({start:Zi(0),end:Zi(3),type:"float",condition:"<="},()=>{const e=on(fy(a.mul(2))).toVar();s.addAssign(e.add(r.mul(Zi(.1).mul(t)))),a.mulAssign(1.8),i.mulAssign(1.5),s.mulAssign(1.2);const o=Zi(my(s.z.add(my(s.x.add(my(s.y)))))).toVar();n.addAssign(o.div(i)),a.addAssign(.14)}),n}).setLayout({name:"triNoise3D",type:"float",inputs:[{name:"position",type:"vec3"},{name:"speed",type:"float"},{name:"time",type:"float"}]});class by extends Ks{static get type(){return"FunctionOverloadingNode"}constructor(e=[],...t){super(),this.functionNodes=e,this.parametersNodes=t,this._candidateFnCall=null,this.global=!0}getNodeType(){return this.functionNodes[0].shaderNode.layout.type}setup(e){const t=this.parametersNodes;let r=this._candidateFnCall;if(null===r){let s=null,i=-1;for(const r of this.functionNodes){const n=r.shaderNode.layout;if(null===n)throw new Error("FunctionOverloadingNode: FunctionNode must be a layout.");const a=n.inputs;if(t.length===a.length){let n=0;for(let r=0;ri&&(s=r,i=n)}}this._candidateFnCall=r=s(...t)}return r}}const xy=Gi(by),Ty=e=>(...t)=>xy(e,...t),_y=ia(0).setGroup(ta).onRenderUpdate(e=>e.time),vy=ia(0).setGroup(ta).onRenderUpdate(e=>e.deltaTime),Ny=ia(0,"uint").setGroup(ta).onRenderUpdate(e=>e.frameId),Sy=ji(([e,t,r=rn(.5)])=>sf(e.sub(r),t).add(r)),Ey=ji(([e,t,r=rn(.5)])=>{const s=e.sub(r),i=s.dot(s),n=i.mul(i).mul(t);return e.add(s.mul(n))}),wy=ji(({position:e=null,horizontal:t=!0,vertical:r=!1})=>{let s;null!==e?(s=Xl.toVar(),s[3][0]=e.x,s[3][1]=e.y,s[3][2]=e.z):s=Xl;const i=Fl.mul(s);return Li(t)&&(i[0][0]=Xl[0].length(),i[0][1]=0,i[0][2]=0),Li(r)&&(i[1][0]=0,i[1][1]=Xl[1].length(),i[1][2]=0),i[2][0]=0,i[2][1]=0,i[2][2]=1,Pl.mul(i).mul(ad)}),Ay=ji(([e=null])=>{const t=ap();return ap(Zh(e)).sub(t).lessThan(0).select(Tl,e)});class Ry extends Ks{static get type(){return"SpriteSheetUVNode"}constructor(e,t=tl(),r=Zi(0)){super("vec2"),this.countNode=e,this.uvNode=t,this.frameNode=r}setup(){const{frameNode:e,uvNode:t,countNode:r}=this,{width:s,height:i}=r,n=e.mod(s.mul(i)).floor(),a=n.mod(s),o=i.sub(n.add(1).div(s).ceil()),u=r.reciprocal(),l=rn(a,o);return t.add(l).mul(u)}}const Cy=Gi(Ry).setParameterLength(3),My=ji(([e,t=null,r=null,s=Zi(1),i=ad,n=yd])=>{let a=n.abs().normalize();a=a.div(a.dot(on(1)));const o=i.yz.mul(s),u=i.zx.mul(s),l=i.xy.mul(s),d=e.value,c=null!==t?t.value:d,h=null!==r?r.value:d,p=ll(d,o).mul(a.x),g=ll(c,u).mul(a.y),m=ll(h,l).mul(a.z);return pa(p,g,m)}),Py=new Me,By=new r,Fy=new r,Ly=new r,Iy=new a,Dy=new r(0,0,-1),Vy=new s,Uy=new r,Oy=new r,ky=new s,Gy=new t,zy=new ue,Hy=Tl.flipX();zy.depthTexture=new U(1,1);let $y=!1;class Wy extends ol{static get type(){return"ReflectorNode"}constructor(e={}){super(e.defaultTexture||zy.texture,Hy),this._reflectorBaseNode=e.reflector||new jy(this,e),this._depthNode=null,this.setUpdateMatrix(!1)}get reflector(){return this._reflectorBaseNode}get target(){return this._reflectorBaseNode.target}getDepthNode(){if(null===this._depthNode){if(!0!==this._reflectorBaseNode.depth)throw new Error("THREE.ReflectorNode: Depth node can only be requested when the reflector is created with { depth: true }. ");this._depthNode=Vi(new Wy({defaultTexture:zy.depthTexture,reflector:this._reflectorBaseNode}))}return this._depthNode}setup(e){return e.object.isQuadMesh||this._reflectorBaseNode.build(e),super.setup(e)}clone(){const e=new this.constructor(this.reflectorNode);return e.uvNode=this.uvNode,e.levelNode=this.levelNode,e.biasNode=this.biasNode,e.sampler=this.sampler,e.depthNode=this.depthNode,e.compareNode=this.compareNode,e.gradNode=this.gradNode,e._reflectorBaseNode=this._reflectorBaseNode,e}dispose(){super.dispose(),this._reflectorBaseNode.dispose()}}class jy extends Ks{static get type(){return"ReflectorBaseNode"}constructor(e,t={}){super();const{target:r=new Pe,resolution:s=1,generateMipmaps:i=!1,bounces:n=!0,depth:a=!1,samples:o=0}=t;this.textureNode=e,this.target=r,this.resolution=s,this.generateMipmaps=i,this.bounces=n,this.depth=a,this.samples=o,this.updateBeforeType=n?ks.RENDER:ks.FRAME,this.virtualCameras=new WeakMap,this.renderTargets=new Map,this.forceUpdate=!1,this.hasOutput=!1}_updateResolution(e,t){const r=this.resolution;t.getDrawingBufferSize(Gy),e.setSize(Math.round(Gy.width*r),Math.round(Gy.height*r))}setup(e){return this._updateResolution(zy,e.renderer),super.setup(e)}dispose(){super.dispose();for(const e of this.renderTargets.values())e.dispose()}getVirtualCamera(e){let t=this.virtualCameras.get(e);return void 0===t&&(t=e.clone(),this.virtualCameras.set(e,t)),t}getRenderTarget(e){let t=this.renderTargets.get(e);return void 0===t&&(t=new ue(0,0,{type:ce,samples:this.samples}),!0===this.generateMipmaps&&(t.texture.minFilter=Be,t.texture.generateMipmaps=!0),!0===this.depth&&(t.depthTexture=new U),this.renderTargets.set(e,t)),t}updateBefore(e){if(!1===this.bounces&&$y)return!1;$y=!0;const{scene:t,camera:r,renderer:s,material:i}=e,{target:n}=this,a=this.getVirtualCamera(r),o=this.getRenderTarget(a);s.getDrawingBufferSize(Gy),this._updateResolution(o,s),Fy.setFromMatrixPosition(n.matrixWorld),Ly.setFromMatrixPosition(r.matrixWorld),Iy.extractRotation(n.matrixWorld),By.set(0,0,1),By.applyMatrix4(Iy),Uy.subVectors(Fy,Ly);let u=!1;if(!0===Uy.dot(By)>0&&!1===this.forceUpdate){if(!1===this.hasOutput)return void($y=!1);u=!0}Uy.reflect(By).negate(),Uy.add(Fy),Iy.extractRotation(r.matrixWorld),Dy.set(0,0,-1),Dy.applyMatrix4(Iy),Dy.add(Ly),Oy.subVectors(Fy,Dy),Oy.reflect(By).negate(),Oy.add(Fy),a.coordinateSystem=r.coordinateSystem,a.position.copy(Uy),a.up.set(0,1,0),a.up.applyMatrix4(Iy),a.up.reflect(By),a.lookAt(Oy),a.near=r.near,a.far=r.far,a.updateMatrixWorld(),a.projectionMatrix.copy(r.projectionMatrix),Py.setFromNormalAndCoplanarPoint(By,Fy),Py.applyMatrix4(a.matrixWorldInverse),Vy.set(Py.normal.x,Py.normal.y,Py.normal.z,Py.constant);const l=a.projectionMatrix;ky.x=(Math.sign(Vy.x)+l.elements[8])/l.elements[0],ky.y=(Math.sign(Vy.y)+l.elements[9])/l.elements[5],ky.z=-1,ky.w=(1+l.elements[10])/l.elements[14],Vy.multiplyScalar(1/Vy.dot(ky));l.elements[2]=Vy.x,l.elements[6]=Vy.y,l.elements[10]=s.coordinateSystem===d?Vy.z-0:Vy.z+1-0,l.elements[14]=Vy.w,this.textureNode.value=o.texture,!0===this.depth&&(this.textureNode.getDepthNode().value=o.depthTexture),i.visible=!1;const c=s.getRenderTarget(),h=s.getMRT(),p=s.autoClear;s.setMRT(null),s.setRenderTarget(o),s.autoClear=!0,u?(s.clear(),this.hasOutput=!1):(s.render(t,a),this.hasOutput=!0),s.setMRT(h),s.setRenderTarget(c),s.autoClear=p,i.visible=!0,$y=!1,this.forceUpdate=!1}}const qy=new ae(-1,1,1,-1,0,1);class Xy extends pe{constructor(e=!1){super();const t=!1===e?[0,-1,0,1,2,1]:[0,2,0,0,2,0];this.setAttribute("position",new Fe([-1,3,0,-1,-1,0,3,-1,0],3)),this.setAttribute("uv",new Fe(t,2))}}const Ky=new Xy;class Yy extends X{constructor(e=null){super(Ky,e),this.camera=qy,this.isQuadMesh=!0}async renderAsync(e){return e.renderAsync(this,qy)}render(e){e.render(this,qy)}}const Qy=new t;class Zy extends ol{static get type(){return"RTTNode"}constructor(e,t=null,r=null,s={type:ce}){const i=new ue(t,r,s);super(i.texture,tl()),this.isRTTNode=!0,this.node=e,this.width=t,this.height=r,this.pixelRatio=1,this.renderTarget=i,this.textureNeedsUpdate=!0,this.autoUpdate=!0,this._rttNode=null,this._quadMesh=new Yy(new _p),this.updateBeforeType=ks.RENDER}get autoResize(){return null===this.width}setup(e){return this._rttNode=this.node.context(e.getSharedContext()),this._quadMesh.material.name="RTT",this._quadMesh.material.needsUpdate=!0,super.setup(e)}setSize(e,t){this.width=e,this.height=t;const r=e*this.pixelRatio,s=t*this.pixelRatio;this.renderTarget.setSize(r,s),this.textureNeedsUpdate=!0}setPixelRatio(e){this.pixelRatio=e,this.setSize(this.width,this.height)}updateBefore({renderer:e}){if(!1===this.textureNeedsUpdate&&!1===this.autoUpdate)return;if(this.textureNeedsUpdate=!1,!0===this.autoResize){const t=e.getPixelRatio(),r=e.getSize(Qy),s=r.width*t,i=r.height*t;s===this.renderTarget.width&&i===this.renderTarget.height||(this.renderTarget.setSize(s,i),this.textureNeedsUpdate=!0)}this._quadMesh.material.fragmentNode=this._rttNode;const t=e.getRenderTarget();e.setRenderTarget(this.renderTarget),this._quadMesh.render(e),e.setRenderTarget(t)}clone(){const e=new ol(this.value,this.uvNode,this.levelNode);return e.sampler=this.sampler,e.referenceNode=this,e}}const Jy=(e,...t)=>Vi(new Zy(Vi(e),...t)),eb=ji(([e,t,r],s)=>{let i;s.renderer.coordinateSystem===d?(e=rn(e.x,e.y.oneMinus()).mul(2).sub(1),i=cn(on(e,t),1)):i=cn(on(e.x,e.y.oneMinus(),t).mul(2).sub(1),1);const n=cn(r.mul(i));return n.xyz.div(n.w)}),tb=ji(([e,t])=>{const r=t.mul(cn(e,1)),s=r.xy.div(r.w).mul(.5).add(.5).toVar();return rn(s.x,s.y.oneMinus())}),rb=ji(([e,t,r])=>{const s=sl(dl(t)),i=sn(e.mul(s)).toVar(),n=dl(t,i).toVar(),a=dl(t,i.sub(sn(2,0))).toVar(),o=dl(t,i.sub(sn(1,0))).toVar(),u=dl(t,i.add(sn(1,0))).toVar(),l=dl(t,i.add(sn(2,0))).toVar(),d=dl(t,i.add(sn(0,2))).toVar(),c=dl(t,i.add(sn(0,1))).toVar(),h=dl(t,i.sub(sn(0,1))).toVar(),p=dl(t,i.sub(sn(0,2))).toVar(),g=co(ga(Zi(2).mul(o).sub(a),n)).toVar(),m=co(ga(Zi(2).mul(u).sub(l),n)).toVar(),f=co(ga(Zi(2).mul(c).sub(d),n)).toVar(),y=co(ga(Zi(2).mul(h).sub(p),n)).toVar(),b=eb(e,n,r).toVar(),x=g.lessThan(m).select(b.sub(eb(e.sub(rn(Zi(1).div(s.x),0)),o,r)),b.negate().add(eb(e.add(rn(Zi(1).div(s.x),0)),u,r))),T=f.lessThan(y).select(b.sub(eb(e.add(rn(0,Zi(1).div(s.y))),c,r)),b.negate().add(eb(e.sub(rn(0,Zi(1).div(s.y))),h,r)));return ro(Lo(x,T))});class sb extends Ks{static get type(){return"SampleNode"}constructor(e,t=null){super(),this.callback=e,this.uvNode=t,this.isSampleNode=!0}setup(){return this.sample(tl())}sample(e){return this.callback(e)}}class ib extends Ks{static get type(){return"EventNode"}constructor(e,t){super("void"),this.eventType=e,this.callback=t,e===ib.OBJECT?this.updateType=ks.OBJECT:e===ib.MATERIAL&&(this.updateType=ks.RENDER)}update(e){this.callback(e)}}ib.OBJECT="object",ib.MATERIAL="material";const nb=(e,t)=>Vi(new ib(e,t)).toStack();class ab extends F{constructor(e,t,r=Float32Array){super(ArrayBuffer.isView(e)?e:new r(e*t),t),this.isStorageInstancedBufferAttribute=!0}}class ob extends ge{constructor(e,t,r=Float32Array){super(ArrayBuffer.isView(e)?e:new r(e*t),t),this.isStorageBufferAttribute=!0}}class ub extends Ks{static get type(){return"PointUVNode"}constructor(){super("vec2"),this.isPointUVNode=!0}generate(){return"vec2( gl_PointCoord.x, 1.0 - gl_PointCoord.y )"}}const lb=zi(ub),db=new w,cb=new a;class hb extends Ks{static get type(){return"SceneNode"}constructor(e=hb.BACKGROUND_BLURRINESS,t=null){super(),this.scope=e,this.scene=t}setup(e){const t=this.scope,r=null!==this.scene?this.scene:e.scene;let s;return t===hb.BACKGROUND_BLURRINESS?s=$d("backgroundBlurriness","float",r):t===hb.BACKGROUND_INTENSITY?s=$d("backgroundIntensity","float",r):t===hb.BACKGROUND_ROTATION?s=ia("mat4").setName("backgroundRotation").setGroup(ta).onRenderUpdate(()=>{const e=r.background;return null!==e&&e.isTexture&&e.mapping!==Le?(db.copy(r.backgroundRotation),db.x*=-1,db.y*=-1,db.z*=-1,cb.makeRotationFromEuler(db)):cb.identity(),cb}):console.error("THREE.SceneNode: Unknown scope:",t),s}}hb.BACKGROUND_BLURRINESS="backgroundBlurriness",hb.BACKGROUND_INTENSITY="backgroundIntensity",hb.BACKGROUND_ROTATION="backgroundRotation";const pb=zi(hb,hb.BACKGROUND_BLURRINESS),gb=zi(hb,hb.BACKGROUND_INTENSITY),mb=zi(hb,hb.BACKGROUND_ROTATION);class fb extends ol{static get type(){return"StorageTextureNode"}constructor(e,t,r=null){super(e,t),this.storeNode=r,this.isStorageTextureNode=!0,this.access=zs.WRITE_ONLY}getInputType(){return"storageTexture"}setup(e){super.setup(e);const t=e.getNodeProperties(this);return t.storeNode=this.storeNode,t}setAccess(e){return this.access=e,this}generate(e,t){let r;return r=null!==this.storeNode?this.generateStore(e):super.generate(e,t),r}toReadWrite(){return this.setAccess(zs.READ_WRITE)}toReadOnly(){return this.setAccess(zs.READ_ONLY)}toWriteOnly(){return this.setAccess(zs.WRITE_ONLY)}generateStore(e){const t=e.getNodeProperties(this),{uvNode:r,storeNode:s,depthNode:i}=t,n=super.generate(e,"property"),a=r.build(e,!0===this.value.is3DTexture?"uvec3":"uvec2"),o=s.build(e,"vec4"),u=i?i.build(e,"int"):null,l=e.generateTextureStore(e,n,a,u,o);e.addLineFlowCode(l,this)}clone(){const e=super.clone();return e.storeNode=this.storeNode,e}}const yb=Gi(fb).setParameterLength(1,3),bb=ji(({texture:e,uv:t})=>{const r=1e-4,s=on().toVar();return Ki(t.x.lessThan(r),()=>{s.assign(on(1,0,0))}).ElseIf(t.y.lessThan(r),()=>{s.assign(on(0,1,0))}).ElseIf(t.z.lessThan(r),()=>{s.assign(on(0,0,1))}).ElseIf(t.x.greaterThan(.9999),()=>{s.assign(on(-1,0,0))}).ElseIf(t.y.greaterThan(.9999),()=>{s.assign(on(0,-1,0))}).ElseIf(t.z.greaterThan(.9999),()=>{s.assign(on(0,0,-1))}).Else(()=>{const r=.01,i=e.sample(t.add(on(-.01,0,0))).r.sub(e.sample(t.add(on(r,0,0))).r),n=e.sample(t.add(on(0,-.01,0))).r.sub(e.sample(t.add(on(0,r,0))).r),a=e.sample(t.add(on(0,0,-.01))).r.sub(e.sample(t.add(on(0,0,r))).r);s.assign(on(i,n,a))}),s.normalize()});class xb extends ol{static get type(){return"Texture3DNode"}constructor(e,t=null,r=null){super(e,t,r),this.isTexture3DNode=!0}getInputType(){return"texture3D"}getDefaultUV(){return on(.5,.5,.5)}setUpdateMatrix(){}setupUV(e,t){const r=this.value;return!e.isFlipY()||!0!==r.isRenderTargetTexture&&!0!==r.isFramebufferTexture||(t=this.sampler?t.flipY():t.setY(Ji(sl(this,this.levelNode).y).sub(t.y).sub(1))),t}generateUV(e,t){return t.build(e,"vec3")}normal(e){return bb({texture:this,uv:e})}}const Tb=Gi(xb).setParameterLength(1,3);class _b extends Hd{static get type(){return"UserDataNode"}constructor(e,t,r=null){super(e,t,r),this.userData=r}updateReference(e){return this.reference=null!==this.userData?this.userData:e.object.userData,this.reference}}const vb=new WeakMap;class Nb extends Zs{static get type(){return"VelocityNode"}constructor(){super("vec2"),this.projectionMatrix=null,this.updateType=ks.OBJECT,this.updateAfterType=ks.OBJECT,this.previousModelWorldMatrix=ia(new a),this.previousProjectionMatrix=ia(new a).setGroup(ta),this.previousCameraViewMatrix=ia(new a)}setProjectionMatrix(e){this.projectionMatrix=e}update({frameId:e,camera:t,object:r}){const s=Eb(r);this.previousModelWorldMatrix.value.copy(s);const i=Sb(t);i.frameId!==e&&(i.frameId=e,void 0===i.previousProjectionMatrix?(i.previousProjectionMatrix=new a,i.previousCameraViewMatrix=new a,i.currentProjectionMatrix=new a,i.currentCameraViewMatrix=new a,i.previousProjectionMatrix.copy(this.projectionMatrix||t.projectionMatrix),i.previousCameraViewMatrix.copy(t.matrixWorldInverse)):(i.previousProjectionMatrix.copy(i.currentProjectionMatrix),i.previousCameraViewMatrix.copy(i.currentCameraViewMatrix)),i.currentProjectionMatrix.copy(this.projectionMatrix||t.projectionMatrix),i.currentCameraViewMatrix.copy(t.matrixWorldInverse),this.previousProjectionMatrix.value.copy(i.previousProjectionMatrix),this.previousCameraViewMatrix.value.copy(i.previousCameraViewMatrix))}updateAfter({object:e}){Eb(e).copy(e.matrixWorld)}setup(){const e=null===this.projectionMatrix?Pl:ia(this.projectionMatrix),t=this.previousCameraViewMatrix.mul(this.previousModelWorldMatrix),r=e.mul(td).mul(ad),s=this.previousProjectionMatrix.mul(t).mul(od),i=r.xy.div(r.w),n=s.xy.div(s.w);return ga(i,n)}}function Sb(e){let t=vb.get(e);return void 0===t&&(t={},vb.set(e,t)),t}function Eb(e,t=0){const r=Sb(e);let s=r[t];return void 0===s&&(r[t]=s=new a,r[t].copy(e.matrixWorld)),s}const wb=zi(Nb),Ab=ji(([e])=>Pb(e.rgb)),Rb=ji(([e,t=Zi(1)])=>t.mix(Pb(e.rgb),e.rgb)),Cb=ji(([e,t=Zi(1)])=>{const r=pa(e.r,e.g,e.b).div(3),s=e.r.max(e.g.max(e.b)),i=s.sub(r).mul(t).mul(-3);return zo(e.rgb,s,i)}),Mb=ji(([e,t=Zi(1)])=>{const r=on(.57735,.57735,.57735),s=t.cos();return on(e.rgb.mul(s).add(r.cross(e.rgb).mul(t.sin()).add(r.mul(Fo(r,e.rgb).mul(s.oneMinus())))))}),Pb=(e,t=on(c.getLuminanceCoefficients(new r)))=>Fo(e,t),Bb=ji(([e,t=on(1),s=on(0),i=on(1),n=Zi(1),a=on(c.getLuminanceCoefficients(new r,le))])=>{const o=e.rgb.dot(on(a)),u=Ro(e.rgb.mul(t).add(s),0).toVar(),l=u.pow(i).toVar();return Ki(u.r.greaterThan(0),()=>{u.r.assign(l.r)}),Ki(u.g.greaterThan(0),()=>{u.g.assign(l.g)}),Ki(u.b.greaterThan(0),()=>{u.b.assign(l.b)}),u.assign(o.add(u.sub(o).mul(n))),cn(u.rgb,e.a)});class Fb extends Zs{static get type(){return"PosterizeNode"}constructor(e,t){super(),this.sourceNode=e,this.stepsNode=t}setup(){const{sourceNode:e,stepsNode:t}=this;return e.mul(t).floor().div(t)}}const Lb=Gi(Fb).setParameterLength(2),Ib=new t;class Db extends ol{static get type(){return"PassTextureNode"}constructor(e,t){super(t),this.passNode=e,this.setUpdateMatrix(!1)}setup(e){return this.passNode.build(e),super.setup(e)}clone(){return new this.constructor(this.passNode,this.value)}}class Vb extends Db{static get type(){return"PassMultipleTextureNode"}constructor(e,t,r=!1){super(e,null),this.textureName=t,this.previousTexture=r}updateTexture(){this.value=this.previousTexture?this.passNode.getPreviousTexture(this.textureName):this.passNode.getTexture(this.textureName)}setup(e){return this.updateTexture(),super.setup(e)}clone(){const e=new this.constructor(this.passNode,this.textureName,this.previousTexture);return e.uvNode=this.uvNode,e.levelNode=this.levelNode,e.biasNode=this.biasNode,e.sampler=this.sampler,e.depthNode=this.depthNode,e.compareNode=this.compareNode,e.gradNode=this.gradNode,e}}class Ub extends Zs{static get type(){return"PassNode"}constructor(e,t,r,s={}){super("vec4"),this.scope=e,this.scene=t,this.camera=r,this.options=s,this._pixelRatio=1,this._width=1,this._height=1;const i=new U;i.isRenderTargetTexture=!0,i.name="depth";const n=new ue(this._width*this._pixelRatio,this._height*this._pixelRatio,{type:ce,...s});n.texture.name="output",n.depthTexture=i,this.renderTarget=n,this._textures={output:n.texture,depth:i},this._textureNodes={},this._linearDepthNodes={},this._viewZNodes={},this._previousTextures={},this._previousTextureNodes={},this._cameraNear=ia(0),this._cameraFar=ia(0),this._mrt=null,this._layers=null,this._resolution=1,this._viewport=null,this._scissor=null,this.isPassNode=!0,this.updateBeforeType=ks.FRAME,this.global=!0}setResolution(e){return this._resolution=e,this}getResolution(){return this._resolution}setLayers(e){return this._layers=e,this}getLayers(){return this._layers}setMRT(e){return this._mrt=e,this}getMRT(){return this._mrt}getTexture(e){let t=this._textures[e];if(void 0===t){t=this.renderTarget.texture.clone(),t.name=e,this._textures[e]=t,this.renderTarget.textures.push(t)}return t}getPreviousTexture(e){let t=this._previousTextures[e];return void 0===t&&(t=this.getTexture(e).clone(),this._previousTextures[e]=t),t}toggleTexture(e){const t=this._previousTextures[e];if(void 0!==t){const r=this._textures[e],s=this.renderTarget.textures.indexOf(r);this.renderTarget.textures[s]=t,this._textures[e]=t,this._previousTextures[e]=r,this._textureNodes[e].updateTexture(),this._previousTextureNodes[e].updateTexture()}}getTextureNode(e="output"){let t=this._textureNodes[e];return void 0===t&&(t=Vi(new Vb(this,e)),t.updateTexture(),this._textureNodes[e]=t),t}getPreviousTextureNode(e="output"){let t=this._previousTextureNodes[e];return void 0===t&&(void 0===this._textureNodes[e]&&this.getTextureNode(e),t=Vi(new Vb(this,e,!0)),t.updateTexture(),this._previousTextureNodes[e]=t),t}getViewZNode(e="depth"){let t=this._viewZNodes[e];if(void 0===t){const r=this._cameraNear,s=this._cameraFar;this._viewZNodes[e]=t=rp(this.getTextureNode(e),r,s)}return t}getLinearDepthNode(e="depth"){let t=this._linearDepthNodes[e];if(void 0===t){const r=this._cameraNear,s=this._cameraFar,i=this.getViewZNode(e);this._linearDepthNodes[e]=t=ep(i,r,s)}return t}async compileAsync(e){const t=e.getRenderTarget(),r=e.getMRT();e.setRenderTarget(this.renderTarget),e.setMRT(this._mrt),await e.compileAsync(this.scene,this.camera),e.setRenderTarget(t),e.setMRT(r)}setup({renderer:e}){return this.renderTarget.samples=void 0===this.options.samples?e.samples:this.options.samples,this.renderTarget.texture.type=e.getColorBufferType(),this.scope===Ub.COLOR?this.getTextureNode():this.getLinearDepthNode()}updateBefore(e){const{renderer:t}=e,{scene:r}=this;let s,i;const n=t.getOutputRenderTarget();n&&!0===n.isXRRenderTarget?(i=1,s=t.xr.getCamera(),t.xr.updateCamera(s),Ib.set(n.width,n.height)):(s=this.camera,i=t.getPixelRatio(),t.getSize(Ib)),this._pixelRatio=i,this.setSize(Ib.width,Ib.height);const a=t.getRenderTarget(),o=t.getMRT(),u=s.layers.mask;this._cameraNear.value=s.near,this._cameraFar.value=s.far,null!==this._layers&&(s.layers.mask=this._layers.mask);for(const e in this._previousTextures)this.toggleTexture(e);t.setRenderTarget(this.renderTarget),t.setMRT(this._mrt),t.render(r,s),t.setRenderTarget(a),t.setMRT(o),s.layers.mask=u}setSize(e,t){this._width=e,this._height=t;const r=this._width*this._pixelRatio*this._resolution,s=this._height*this._pixelRatio*this._resolution;this.renderTarget.setSize(r,s),null!==this._scissor&&this.renderTarget.scissor.copy(this._scissor),null!==this._viewport&&this.renderTarget.viewport.copy(this._viewport)}setScissor(e,t,r,i){null===e?this._scissor=null:(null===this._scissor&&(this._scissor=new s),e.isVector4?this._scissor.copy(e):this._scissor.set(e,t,r,i),this._scissor.multiplyScalar(this._pixelRatio*this._resolution).floor())}setViewport(e,t,r,i){null===e?this._viewport=null:(null===this._viewport&&(this._viewport=new s),e.isVector4?this._viewport.copy(e):this._viewport.set(e,t,r,i),this._viewport.multiplyScalar(this._pixelRatio*this._resolution).floor())}setPixelRatio(e){this._pixelRatio=e,this.setSize(this._width,this._height)}dispose(){this.renderTarget.dispose()}}Ub.COLOR="color",Ub.DEPTH="depth";class Ob extends Ub{static get type(){return"ToonOutlinePassNode"}constructor(e,t,r,s,i){super(Ub.COLOR,e,t),this.colorNode=r,this.thicknessNode=s,this.alphaNode=i,this._materialCache=new WeakMap}updateBefore(e){const{renderer:t}=e,r=t.getRenderObjectFunction();t.setRenderObjectFunction((e,r,s,i,n,a,o,u)=>{if((n.isMeshToonMaterial||n.isMeshToonNodeMaterial)&&!1===n.wireframe){const l=this._getOutlineMaterial(n);t.renderObject(e,r,s,i,l,a,o,u)}t.renderObject(e,r,s,i,n,a,o,u)}),super.updateBefore(e),t.setRenderObjectFunction(r)}_createMaterial(){const e=new _p;e.isMeshToonOutlineMaterial=!0,e.name="Toon_Outline",e.side=S;const t=yd.negate(),r=Pl.mul(td),s=Zi(1),i=r.mul(cn(ad,1)),n=r.mul(cn(ad.add(t),1)),a=ro(i.sub(n));return e.vertexNode=i.add(a.mul(this.thicknessNode).mul(i.w).mul(s)),e.colorNode=cn(this.colorNode,this.alphaNode),e}_getOutlineMaterial(e){let t=this._materialCache.get(e);return void 0===t&&(t=this._createMaterial(),this._materialCache.set(e,t)),t}}const kb=ji(([e,t])=>e.mul(t).clamp()).setLayout({name:"linearToneMapping",type:"vec3",inputs:[{name:"color",type:"vec3"},{name:"exposure",type:"float"}]}),Gb=ji(([e,t])=>(e=e.mul(t)).div(e.add(1)).clamp()).setLayout({name:"reinhardToneMapping",type:"vec3",inputs:[{name:"color",type:"vec3"},{name:"exposure",type:"float"}]}),zb=ji(([e,t])=>{const r=(e=(e=e.mul(t)).sub(.004).max(0)).mul(e.mul(6.2).add(.5)),s=e.mul(e.mul(6.2).add(1.7)).add(.06);return r.div(s).pow(2.2)}).setLayout({name:"cineonToneMapping",type:"vec3",inputs:[{name:"color",type:"vec3"},{name:"exposure",type:"float"}]}),Hb=ji(([e])=>{const t=e.mul(e.add(.0245786)).sub(90537e-9),r=e.mul(e.add(.432951).mul(.983729)).add(.238081);return t.div(r)}),$b=ji(([e,t])=>{const r=fn(.59719,.35458,.04823,.076,.90834,.01566,.0284,.13383,.83777),s=fn(1.60475,-.53108,-.07367,-.10208,1.10813,-.00605,-.00327,-.07276,1.07602);return e=e.mul(t).div(.6),e=r.mul(e),e=Hb(e),(e=s.mul(e)).clamp()}).setLayout({name:"acesFilmicToneMapping",type:"vec3",inputs:[{name:"color",type:"vec3"},{name:"exposure",type:"float"}]}),Wb=fn(on(1.6605,-.1246,-.0182),on(-.5876,1.1329,-.1006),on(-.0728,-.0083,1.1187)),jb=fn(on(.6274,.0691,.0164),on(.3293,.9195,.088),on(.0433,.0113,.8956)),qb=ji(([e])=>{const t=on(e).toVar(),r=on(t.mul(t)).toVar(),s=on(r.mul(r)).toVar();return Zi(15.5).mul(s.mul(r)).sub(ma(40.14,s.mul(t))).add(ma(31.96,s).sub(ma(6.868,r.mul(t))).add(ma(.4298,r).add(ma(.1191,t).sub(.00232))))}),Xb=ji(([e,t])=>{const r=on(e).toVar(),s=fn(on(.856627153315983,.137318972929847,.11189821299995),on(.0951212405381588,.761241990602591,.0767994186031903),on(.0482516061458583,.101439036467562,.811302368396859)),i=fn(on(1.1271005818144368,-.1413297634984383,-.14132976349843826),on(-.11060664309660323,1.157823702216272,-.11060664309660294),on(-.016493938717834573,-.016493938717834257,1.2519364065950405)),n=Zi(-12.47393),a=Zi(4.026069);return r.mulAssign(t),r.assign(jb.mul(r)),r.assign(s.mul(r)),r.assign(Ro(r,1e-10)),r.assign(Qa(r)),r.assign(r.sub(n).div(a.sub(n))),r.assign(Ho(r,0,1)),r.assign(qb(r)),r.assign(i.mul(r)),r.assign(Io(Ro(on(0),r),on(2.2))),r.assign(Wb.mul(r)),r.assign(Ho(r,0,1)),r}).setLayout({name:"agxToneMapping",type:"vec3",inputs:[{name:"color",type:"vec3"},{name:"exposure",type:"float"}]}),Kb=ji(([e,t])=>{const r=Zi(.76),s=Zi(.15);e=e.mul(t);const i=Ao(e.r,Ao(e.g,e.b)),n=ru(i.lessThan(.08),i.sub(ma(6.25,i.mul(i))),.04);e.subAssign(n);const a=Ro(e.r,Ro(e.g,e.b));Ki(a.lessThan(r),()=>e);const o=ga(1,r),u=ga(1,o.mul(o).div(a.add(o.sub(r))));e.mulAssign(u.div(a));const l=ga(1,fa(1,s.mul(a.sub(u)).add(1)));return zo(e,on(u),l)}).setLayout({name:"neutralToneMapping",type:"vec3",inputs:[{name:"color",type:"vec3"},{name:"exposure",type:"float"}]});class Yb extends Ks{static get type(){return"CodeNode"}constructor(e="",t=[],r=""){super("code"),this.isCodeNode=!0,this.global=!0,this.code=e,this.includes=t,this.language=r}setIncludes(e){return this.includes=e,this}getIncludes(){return this.includes}generate(e){const t=this.getIncludes(e);for(const r of t)r.build(e);const r=e.getCodeFromNode(this,this.getNodeType(e));return r.code=this.code,r.code}serialize(e){super.serialize(e),e.code=this.code,e.language=this.language}deserialize(e){super.deserialize(e),this.code=e.code,this.language=e.language}}const Qb=Gi(Yb).setParameterLength(1,3);class Zb extends Yb{static get type(){return"FunctionNode"}constructor(e="",t=[],r=""){super(e,t,r)}getNodeType(e){return this.getNodeFunction(e).type}getMemberType(e,t){const r=this.getNodeType(e);return e.getStructTypeNode(r).getMemberType(e,t)}getInputs(e){return this.getNodeFunction(e).inputs}getNodeFunction(e){const t=e.getDataFromNode(this);let r=t.nodeFunction;return void 0===r&&(r=e.parser.parseFunction(this.code),t.nodeFunction=r),r}generate(e,t){super.generate(e);const r=this.getNodeFunction(e),s=r.name,i=r.type,n=e.getCodeFromNode(this,i);""!==s&&(n.name=s);const a=e.getPropertyName(n),o=this.getNodeFunction(e).getCode(a);return n.code=o+"\n","property"===t?a:e.format(`${a}()`,i,t)}}const Jb=(e,t=[],r="")=>{for(let e=0;es.call(...e);return i.functionNode=s,i};class ex extends Ks{static get type(){return"ScriptableValueNode"}constructor(e=null){super(),this._value=e,this._cache=null,this.inputType=null,this.outputType=null,this.events=new o,this.isScriptableValueNode=!0}get isScriptableOutputNode(){return null!==this.outputType}set value(e){this._value!==e&&(this._cache&&"URL"===this.inputType&&this.value.value instanceof ArrayBuffer&&(URL.revokeObjectURL(this._cache),this._cache=null),this._value=e,this.events.dispatchEvent({type:"change"}),this.refresh())}get value(){return this._value}refresh(){this.events.dispatchEvent({type:"refresh"})}getValue(){const e=this.value;if(e&&null===this._cache&&"URL"===this.inputType&&e.value instanceof ArrayBuffer)this._cache=URL.createObjectURL(new Blob([e.value]));else if(e&&null!==e.value&&void 0!==e.value&&(("URL"===this.inputType||"String"===this.inputType)&&"string"==typeof e.value||"Number"===this.inputType&&"number"==typeof e.value||"Vector2"===this.inputType&&e.value.isVector2||"Vector3"===this.inputType&&e.value.isVector3||"Vector4"===this.inputType&&e.value.isVector4||"Color"===this.inputType&&e.value.isColor||"Matrix3"===this.inputType&&e.value.isMatrix3||"Matrix4"===this.inputType&&e.value.isMatrix4))return e.value;return this._cache||e}getNodeType(e){return this.value&&this.value.isNode?this.value.getNodeType(e):"float"}setup(){return this.value&&this.value.isNode?this.value:Zi()}serialize(e){super.serialize(e),null!==this.value?"ArrayBuffer"===this.inputType?e.value=Ds(this.value):e.value=this.value?this.value.toJSON(e.meta).uuid:null:e.value=null,e.inputType=this.inputType,e.outputType=this.outputType}deserialize(e){super.deserialize(e);let t=null;null!==e.value&&(t="ArrayBuffer"===e.inputType?Vs(e.value):"Texture"===e.inputType?e.meta.textures[e.value]:e.meta.nodes[e.value]||null),this.value=t,this.inputType=e.inputType,this.outputType=e.outputType}}const tx=Gi(ex).setParameterLength(1);class rx extends Map{get(e,t=null,...r){if(this.has(e))return super.get(e);if(null!==t){const s=t(...r);return this.set(e,s),s}}}class sx{constructor(e){this.scriptableNode=e}get parameters(){return this.scriptableNode.parameters}get layout(){return this.scriptableNode.getLayout()}getInputLayout(e){return this.scriptableNode.getInputLayout(e)}get(e){const t=this.parameters[e];return t?t.getValue():null}}const ix=new rx;class nx extends Ks{static get type(){return"ScriptableNode"}constructor(e=null,t={}){super(),this.codeNode=e,this.parameters=t,this._local=new rx,this._output=tx(null),this._outputs={},this._source=this.source,this._method=null,this._object=null,this._value=null,this._needsOutputUpdate=!0,this.onRefresh=this.onRefresh.bind(this),this.isScriptableNode=!0}get source(){return this.codeNode?this.codeNode.code:""}setLocal(e,t){return this._local.set(e,t)}getLocal(e){return this._local.get(e)}onRefresh(){this._refresh()}getInputLayout(e){for(const t of this.getLayout())if(t.inputType&&(t.id===e||t.name===e))return t}getOutputLayout(e){for(const t of this.getLayout())if(t.outputType&&(t.id===e||t.name===e))return t}setOutput(e,t){const r=this._outputs;return void 0===r[e]?r[e]=tx(t):r[e].value=t,this}getOutput(e){return this._outputs[e]}getParameter(e){return this.parameters[e]}setParameter(e,t){const r=this.parameters;return t&&t.isScriptableNode?(this.deleteParameter(e),r[e]=t,r[e].getDefaultOutput().events.addEventListener("refresh",this.onRefresh)):t&&t.isScriptableValueNode?(this.deleteParameter(e),r[e]=t,r[e].events.addEventListener("refresh",this.onRefresh)):void 0===r[e]?(r[e]=tx(t),r[e].events.addEventListener("refresh",this.onRefresh)):r[e].value=t,this}getValue(){return this.getDefaultOutput().getValue()}deleteParameter(e){let t=this.parameters[e];return t&&(t.isScriptableNode&&(t=t.getDefaultOutput()),t.events.removeEventListener("refresh",this.onRefresh)),this}clearParameters(){for(const e of Object.keys(this.parameters))this.deleteParameter(e);return this.needsUpdate=!0,this}call(e,...t){const r=this.getObject()[e];if("function"==typeof r)return r(...t)}async callAsync(e,...t){const r=this.getObject()[e];if("function"==typeof r)return"AsyncFunction"===r.constructor.name?await r(...t):r(...t)}getNodeType(e){return this.getDefaultOutputNode().getNodeType(e)}refresh(e=null){null!==e?this.getOutput(e).refresh():this._refresh()}getObject(){if(this.needsUpdate&&this.dispose(),null!==this._object)return this._object;const e=new sx(this),t=ix.get("THREE"),r=ix.get("TSL"),s=this.getMethod(),i=[e,this._local,ix,()=>this.refresh(),(e,t)=>this.setOutput(e,t),t,r];this._object=s(...i);const n=this._object.layout;if(n&&(!1===n.cache&&this._local.clear(),this._output.outputType=n.outputType||null,Array.isArray(n.elements)))for(const e of n.elements){const t=e.id||e.name;e.inputType&&(void 0===this.getParameter(t)&&this.setParameter(t,null),this.getParameter(t).inputType=e.inputType),e.outputType&&(void 0===this.getOutput(t)&&this.setOutput(t,null),this.getOutput(t).outputType=e.outputType)}return this._object}deserialize(e){super.deserialize(e);for(const e in this.parameters){let t=this.parameters[e];t.isScriptableNode&&(t=t.getDefaultOutput()),t.events.addEventListener("refresh",this.onRefresh)}}getLayout(){return this.getObject().layout}getDefaultOutputNode(){const e=this.getDefaultOutput().value;return e&&e.isNode?e:Zi()}getDefaultOutput(){return this._exec()._output}getMethod(){if(this.needsUpdate&&this.dispose(),null!==this._method)return this._method;const e=["layout","init","main","dispose"].join(", "),t="\nreturn { ...output, "+e+" };",r="var "+e+"; var output = {};\n"+this.codeNode.code+t;return this._method=new Function(...["parameters","local","global","refresh","setOutput","THREE","TSL"],r),this._method}dispose(){null!==this._method&&(this._object&&"function"==typeof this._object.dispose&&this._object.dispose(),this._method=null,this._object=null,this._source=null,this._value=null,this._needsOutputUpdate=!0,this._output.value=null,this._outputs={})}setup(){return this.getDefaultOutputNode()}getCacheKey(e){const t=[_s(this.source),this.getDefaultOutputNode().getCacheKey(e)];for(const r in this.parameters)t.push(this.parameters[r].getCacheKey(e));return vs(t)}set needsUpdate(e){!0===e&&this.dispose()}get needsUpdate(){return this.source!==this._source}_exec(){return null===this.codeNode||(!0===this._needsOutputUpdate&&(this._value=this.call("main"),this._needsOutputUpdate=!1),this._output.value=this._value),this}_refresh(){this.needsUpdate=!0,this._exec(),this._output.refresh()}}const ax=Gi(nx).setParameterLength(1,2);function ox(e){let t;const r=e.context.getViewZ;return void 0!==r&&(t=r(this)),(t||dd.z).negate()}const ux=ji(([e,t],r)=>{const s=ox(r);return jo(e,t,s)}),lx=ji(([e],t)=>{const r=ox(t);return e.mul(e,r,r).negate().exp().oneMinus()}),dx=ji(([e,t])=>cn(t.toFloat().mix(Gn.rgb,e.toVec3()),Gn.a));let cx=null,hx=null;class px extends Ks{static get type(){return"RangeNode"}constructor(e=Zi(),t=Zi()){super(),this.minNode=e,this.maxNode=t}getVectorLength(e){const t=e.getTypeLength(Fs(this.minNode.value)),r=e.getTypeLength(Fs(this.maxNode.value));return t>r?t:r}getNodeType(e){return e.object.count>1?e.getTypeFromLength(this.getVectorLength(e)):"float"}setup(e){const t=e.object;let r=null;if(t.count>1){const i=this.minNode.value,n=this.maxNode.value,a=e.getTypeLength(Fs(i)),o=e.getTypeLength(Fs(n));cx=cx||new s,hx=hx||new s,cx.setScalar(0),hx.setScalar(0),1===a?cx.setScalar(i):i.isColor?cx.set(i.r,i.g,i.b,1):cx.set(i.x,i.y,i.z||0,i.w||0),1===o?hx.setScalar(n):n.isColor?hx.set(n.r,n.g,n.b,1):hx.set(n.x,n.y,n.z||0,n.w||0);const l=4,d=l*t.count,c=new Float32Array(d);for(let e=0;eVi(new mx(e,t)),yx=fx("numWorkgroups","uvec3"),bx=fx("workgroupId","uvec3"),xx=fx("globalId","uvec3"),Tx=fx("localId","uvec3"),_x=fx("subgroupSize","uint");const vx=Gi(class extends Ks{constructor(e){super(),this.scope=e}generate(e){const{scope:t}=this,{renderer:r}=e;!0===r.backend.isWebGLBackend?e.addFlowCode(`\t// ${t}Barrier \n`):e.addLineFlowCode(`${t}Barrier()`,this)}});class Nx extends Ys{constructor(e,t){super(e,t),this.isWorkgroupInfoElementNode=!0}generate(e,t){let r;const s=e.context.assign;if(r=super.generate(e),!0!==s){const s=this.getNodeType(e);r=e.format(r,s,t)}return r}}class Sx extends Ks{constructor(e,t,r=0){super(t),this.bufferType=t,this.bufferCount=r,this.isWorkgroupInfoNode=!0,this.elementType=t,this.scope=e,this.name=""}setName(e){return this.name=e,this}label(e){return console.warn('THREE.TSL: "label()" has been deprecated. Use "setName()" instead.'),this.setName(e)}setScope(e){return this.scope=e,this}getElementType(){return this.elementType}getInputType(){return`${this.scope}Array`}element(e){return Vi(new Nx(this,e))}generate(e){const t=""!==this.name?this.name:`${this.scope}Array_${this.id}`;return e.getScopedArray(t,this.scope.toLowerCase(),this.bufferType,this.bufferCount)}}class Ex extends Ks{static get type(){return"AtomicFunctionNode"}constructor(e,t,r){super("uint"),this.method=e,this.pointerNode=t,this.valueNode=r,this.parents=!0}getInputType(e){return this.pointerNode.getNodeType(e)}getNodeType(e){return this.getInputType(e)}generate(e){const t=e.getNodeProperties(this),r=t.parents,s=this.method,i=this.getNodeType(e),n=this.getInputType(e),a=this.pointerNode,o=this.valueNode,u=[];u.push(`&${a.build(e,n)}`),null!==o&&u.push(o.build(e,n));const l=`${e.getMethod(s,i)}( ${u.join(", ")} )`;if(!(!!r&&(1===r.length&&!0===r[0].isStackNode)))return void 0===t.constNode&&(t.constNode=qu(l,i).toConst()),t.constNode.build(e);e.addLineFlowCode(l,this)}}Ex.ATOMIC_LOAD="atomicLoad",Ex.ATOMIC_STORE="atomicStore",Ex.ATOMIC_ADD="atomicAdd",Ex.ATOMIC_SUB="atomicSub",Ex.ATOMIC_MAX="atomicMax",Ex.ATOMIC_MIN="atomicMin",Ex.ATOMIC_AND="atomicAnd",Ex.ATOMIC_OR="atomicOr",Ex.ATOMIC_XOR="atomicXor";const wx=Gi(Ex),Ax=(e,t,r)=>wx(e,t,r).toStack();let Rx;function Cx(e){Rx=Rx||new WeakMap;let t=Rx.get(e);return void 0===t&&Rx.set(e,t={}),t}function Mx(e){const t=Cx(e);return t.shadowMatrix||(t.shadowMatrix=ia("mat4").setGroup(ta).onRenderUpdate(t=>(!0===e.castShadow&&!1!==t.renderer.shadowMap.enabled||e.shadow.updateMatrices(e),e.shadow.matrix)))}function Px(e,t=ud){const r=Mx(e).mul(t);return r.xyz.div(r.w)}function Bx(e){const t=Cx(e);return t.position||(t.position=ia(new r).setGroup(ta).onRenderUpdate((t,r)=>r.value.setFromMatrixPosition(e.matrixWorld)))}function Fx(e){const t=Cx(e);return t.targetPosition||(t.targetPosition=ia(new r).setGroup(ta).onRenderUpdate((t,r)=>r.value.setFromMatrixPosition(e.target.matrixWorld)))}function Lx(e){const t=Cx(e);return t.viewPosition||(t.viewPosition=ia(new r).setGroup(ta).onRenderUpdate(({camera:t},s)=>{s.value=s.value||new r,s.value.setFromMatrixPosition(e.matrixWorld),s.value.applyMatrix4(t.matrixWorldInverse)}))}const Ix=e=>Fl.transformDirection(Bx(e).sub(Fx(e))),Dx=(e,t)=>{for(const r of t)if(r.isAnalyticLightNode&&r.light.id===e)return r;return null},Vx=new WeakMap,Ux=[];class Ox extends Ks{static get type(){return"LightsNode"}constructor(){super("vec3"),this.totalDiffuseNode=_n("vec3","totalDiffuse"),this.totalSpecularNode=_n("vec3","totalSpecular"),this.outgoingLightNode=_n("vec3","outgoingLight"),this._lights=[],this._lightNodes=null,this._lightNodesHash=null,this.global=!0}customCacheKey(){const e=this._lights;for(let t=0;te.sort((e,t)=>e.id-t.id))(this._lights),i=e.renderer.library;for(const e of s)if(e.isNode)t.push(Vi(e));else{let s=null;if(null!==r&&(s=Dx(e.id,r)),null===s){const r=i.getLightNodeClass(e.constructor);if(null===r){console.warn(`LightsNode.setupNodeLights: Light node not found for ${e.constructor.name}`);continue}let s=null;Vx.has(e)?s=Vx.get(e):(s=Vi(new r(e)),Vx.set(e,s)),t.push(s)}}this._lightNodes=t}setupDirectLight(e,t,r){const{lightingModel:s,reflectedLight:i}=e.context;s.direct({...r,lightNode:t,reflectedLight:i},e)}setupDirectRectAreaLight(e,t,r){const{lightingModel:s,reflectedLight:i}=e.context;s.directRectArea({...r,lightNode:t,reflectedLight:i},e)}setupLights(e,t){for(const r of t)r.build(e)}getLightNodes(e){return null===this._lightNodes&&this.setupLightsNode(e),this._lightNodes}setup(e){const t=e.lightsNode;e.lightsNode=this;let r=this.outgoingLightNode;const s=e.context,i=s.lightingModel,n=e.getNodeProperties(this);if(i){const{totalDiffuseNode:t,totalSpecularNode:a}=this;s.outgoingLight=r;const o=e.addStack();n.nodes=o.nodes,i.start(e);const{backdrop:u,backdropAlpha:l}=s,{directDiffuse:d,directSpecular:c,indirectDiffuse:h,indirectSpecular:p}=s.reflectedLight;let g=d.add(h);null!==u&&(g=on(null!==l?l.mix(g,u):u),s.material.transparent=!0),t.assign(g),a.assign(c.add(p)),r.assign(t.add(a)),i.finish(e),r=r.bypass(e.removeStack())}else n.nodes=[];return e.lightsNode=t,r}setLights(e){return this._lights=e,this._lightNodes=null,this._lightNodesHash=null,this}getLights(){return this._lights}get hasLights(){return this._lights.length>0}}class kx extends Ks{static get type(){return"ShadowBaseNode"}constructor(e){super(),this.light=e,this.updateBeforeType=ks.RENDER,this.isShadowBaseNode=!0}setupShadowPosition({context:e,material:t}){Gx.assign(t.receivedShadowPositionNode||e.shadowPositionWorld||ud)}}const Gx=_n("vec3","shadowPositionWorld");function zx(t,r={}){return r.toneMapping=t.toneMapping,r.toneMappingExposure=t.toneMappingExposure,r.outputColorSpace=t.outputColorSpace,r.renderTarget=t.getRenderTarget(),r.activeCubeFace=t.getActiveCubeFace(),r.activeMipmapLevel=t.getActiveMipmapLevel(),r.renderObjectFunction=t.getRenderObjectFunction(),r.pixelRatio=t.getPixelRatio(),r.mrt=t.getMRT(),r.clearColor=t.getClearColor(r.clearColor||new e),r.clearAlpha=t.getClearAlpha(),r.autoClear=t.autoClear,r.scissorTest=t.getScissorTest(),r}function Hx(e,t){return t=zx(e,t),e.setMRT(null),e.setRenderObjectFunction(null),e.setClearColor(0,1),e.autoClear=!0,t}function $x(e,t){e.toneMapping=t.toneMapping,e.toneMappingExposure=t.toneMappingExposure,e.outputColorSpace=t.outputColorSpace,e.setRenderTarget(t.renderTarget,t.activeCubeFace,t.activeMipmapLevel),e.setRenderObjectFunction(t.renderObjectFunction),e.setPixelRatio(t.pixelRatio),e.setMRT(t.mrt),e.setClearColor(t.clearColor,t.clearAlpha),e.autoClear=t.autoClear,e.setScissorTest(t.scissorTest)}function Wx(e,t={}){return t.background=e.background,t.backgroundNode=e.backgroundNode,t.overrideMaterial=e.overrideMaterial,t}function jx(e,t){return t=Wx(e,t),e.background=null,e.backgroundNode=null,e.overrideMaterial=null,t}function qx(e,t){e.background=t.background,e.backgroundNode=t.backgroundNode,e.overrideMaterial=t.overrideMaterial}function Xx(e,t,r){return r=jx(t,r=Hx(e,r))}function Kx(e,t,r){$x(e,r),qx(t,r)}var Yx=Object.freeze({__proto__:null,resetRendererAndSceneState:Xx,resetRendererState:Hx,resetSceneState:jx,restoreRendererAndSceneState:Kx,restoreRendererState:$x,restoreSceneState:qx,saveRendererAndSceneState:function(e,t,r={}){return r=Wx(t,r=zx(e,r))},saveRendererState:zx,saveSceneState:Wx});const Qx=new WeakMap,Zx=ji(({depthTexture:e,shadowCoord:t,depthLayer:r})=>{let s=ll(e,t.xy).setName("t_basic");return e.isArrayTexture&&(s=s.depth(r)),s.compare(t.z)}),Jx=ji(({depthTexture:e,shadowCoord:t,shadow:r,depthLayer:s})=>{const i=(t,r)=>{let i=ll(e,t);return e.isArrayTexture&&(i=i.depth(s)),i.compare(r)},n=$d("mapSize","vec2",r).setGroup(ta),a=$d("radius","float",r).setGroup(ta),o=rn(1).div(n),u=o.x.negate().mul(a),l=o.y.negate().mul(a),d=o.x.mul(a),c=o.y.mul(a),h=u.div(2),p=l.div(2),g=d.div(2),m=c.div(2);return pa(i(t.xy.add(rn(u,l)),t.z),i(t.xy.add(rn(0,l)),t.z),i(t.xy.add(rn(d,l)),t.z),i(t.xy.add(rn(h,p)),t.z),i(t.xy.add(rn(0,p)),t.z),i(t.xy.add(rn(g,p)),t.z),i(t.xy.add(rn(u,0)),t.z),i(t.xy.add(rn(h,0)),t.z),i(t.xy,t.z),i(t.xy.add(rn(g,0)),t.z),i(t.xy.add(rn(d,0)),t.z),i(t.xy.add(rn(h,m)),t.z),i(t.xy.add(rn(0,m)),t.z),i(t.xy.add(rn(g,m)),t.z),i(t.xy.add(rn(u,c)),t.z),i(t.xy.add(rn(0,c)),t.z),i(t.xy.add(rn(d,c)),t.z)).mul(1/17)}),eT=ji(({depthTexture:e,shadowCoord:t,shadow:r,depthLayer:s})=>{const i=(t,r)=>{let i=ll(e,t);return e.isArrayTexture&&(i=i.depth(s)),i.compare(r)},n=$d("mapSize","vec2",r).setGroup(ta),a=rn(1).div(n),o=a.x,u=a.y,l=t.xy,d=so(l.mul(n).add(.5));return l.subAssign(d.mul(a)),pa(i(l,t.z),i(l.add(rn(o,0)),t.z),i(l.add(rn(0,u)),t.z),i(l.add(a),t.z),zo(i(l.add(rn(o.negate(),0)),t.z),i(l.add(rn(o.mul(2),0)),t.z),d.x),zo(i(l.add(rn(o.negate(),u)),t.z),i(l.add(rn(o.mul(2),u)),t.z),d.x),zo(i(l.add(rn(0,u.negate())),t.z),i(l.add(rn(0,u.mul(2))),t.z),d.y),zo(i(l.add(rn(o,u.negate())),t.z),i(l.add(rn(o,u.mul(2))),t.z),d.y),zo(zo(i(l.add(rn(o.negate(),u.negate())),t.z),i(l.add(rn(o.mul(2),u.negate())),t.z),d.x),zo(i(l.add(rn(o.negate(),u.mul(2))),t.z),i(l.add(rn(o.mul(2),u.mul(2))),t.z),d.x),d.y)).mul(1/9)}),tT=ji(({depthTexture:e,shadowCoord:t,depthLayer:r})=>{const s=Zi(1).toVar();let i=ll(e).sample(t.xy);e.isArrayTexture&&(i=i.depth(r)),i=i.rg;const n=Co(t.z,i.x);return Ki(n.notEqual(Zi(1)),()=>{const e=t.z.sub(i.x),r=Ro(0,i.y.mul(i.y));let a=r.div(r.add(e.mul(e)));a=Ho(ga(a,.3).div(.95-.3)),s.assign(Ho(Ro(n,a)))}),s}),rT=ji(([e,t,r])=>{let s=ud.sub(e).length();return s=s.sub(t).div(r.sub(t)),s=s.saturate(),s}),sT=e=>{let t=Qx.get(e);if(void 0===t){const r=e.isPointLight?(e=>{const t=e.shadow.camera,r=$d("near","float",t).setGroup(ta),s=$d("far","float",t).setGroup(ta),i=zl(e);return rT(i,r,s)})(e):null;t=new _p,t.colorNode=cn(0,0,0,1),t.depthNode=r,t.isShadowPassMaterial=!0,t.name="ShadowMaterial",t.fog=!1,Qx.set(e,t)}return t},iT=new bf,nT=[],aT=(e,t,r,s)=>{nT[0]=e,nT[1]=t;let i=iT.get(nT);return void 0!==i&&i.shadowType===r&&i.useVelocity===s||(i=(i,n,a,o,u,l,...d)=>{(!0===i.castShadow||i.receiveShadow&&r===Ie)&&(s&&(Is(i).useVelocity=!0),i.onBeforeShadow(e,i,a,t.camera,o,n.overrideMaterial,l),e.renderObject(i,n,a,o,u,l,...d),i.onAfterShadow(e,i,a,t.camera,o,n.overrideMaterial,l))},i.shadowType=r,i.useVelocity=s,iT.set(nT,i)),nT[0]=null,nT[1]=null,i},oT=ji(({samples:e,radius:t,size:r,shadowPass:s,depthLayer:i})=>{const n=Zi(0).toVar("meanVertical"),a=Zi(0).toVar("squareMeanVertical"),o=e.lessThanEqual(Zi(1)).select(Zi(0),Zi(2).div(e.sub(1))),u=e.lessThanEqual(Zi(1)).select(Zi(0),Zi(-1));Lh({start:Ji(0),end:Ji(e),type:"int",condition:"<"},({i:e})=>{const l=u.add(Zi(e).mul(o));let d=s.sample(pa(vl.xy,rn(0,l).mul(t)).div(r));s.value.isArrayTexture&&(d=d.depth(i)),d=d.x,n.addAssign(d),a.addAssign(d.mul(d))}),n.divAssign(e),a.divAssign(e);const l=Za(a.sub(n.mul(n)));return rn(n,l)}),uT=ji(({samples:e,radius:t,size:r,shadowPass:s,depthLayer:i})=>{const n=Zi(0).toVar("meanHorizontal"),a=Zi(0).toVar("squareMeanHorizontal"),o=e.lessThanEqual(Zi(1)).select(Zi(0),Zi(2).div(e.sub(1))),u=e.lessThanEqual(Zi(1)).select(Zi(0),Zi(-1));Lh({start:Ji(0),end:Ji(e),type:"int",condition:"<"},({i:e})=>{const l=u.add(Zi(e).mul(o));let d=s.sample(pa(vl.xy,rn(l,0).mul(t)).div(r));s.value.isArrayTexture&&(d=d.depth(i)),n.addAssign(d.x),a.addAssign(pa(d.y.mul(d.y),d.x.mul(d.x)))}),n.divAssign(e),a.divAssign(e);const l=Za(a.sub(n.mul(n)));return rn(n,l)}),lT=[Zx,Jx,eT,tT];let dT;const cT=new Yy;class hT extends kx{static get type(){return"ShadowNode"}constructor(e,t=null){super(e),this.shadow=t||e.shadow,this.shadowMap=null,this.vsmShadowMapVertical=null,this.vsmShadowMapHorizontal=null,this.vsmMaterialVertical=null,this.vsmMaterialHorizontal=null,this._node=null,this._cameraFrameId=new WeakMap,this.isShadowNode=!0,this.depthLayer=0}setupShadowFilter(e,{filterFn:t,depthTexture:r,shadowCoord:s,shadow:i,depthLayer:n}){const a=s.x.greaterThanEqual(0).and(s.x.lessThanEqual(1)).and(s.y.greaterThanEqual(0)).and(s.y.lessThanEqual(1)).and(s.z.lessThanEqual(1)),o=t({depthTexture:r,shadowCoord:s,shadow:i,depthLayer:n});return a.select(o,Zi(1))}setupShadowCoord(e,t){const{shadow:r}=this,{renderer:s}=e,i=$d("bias","float",r).setGroup(ta);let n,a=t;if(r.camera.isOrthographicCamera||!0!==s.logarithmicDepthBuffer)a=a.xyz.div(a.w),n=a.z,s.coordinateSystem===d&&(n=n.mul(2).sub(1));else{const e=a.w;a=a.xy.div(e);const t=$d("near","float",r.camera).setGroup(ta),s=$d("far","float",r.camera).setGroup(ta);n=sp(e.negate(),t,s)}return a=on(a.x,a.y.oneMinus(),n.add(i)),a}getShadowFilterFn(e){return lT[e]}setupRenderTarget(e,t){const r=new U(e.mapSize.width,e.mapSize.height);r.name="ShadowDepthTexture",r.compareFunction=De;const s=t.createRenderTarget(e.mapSize.width,e.mapSize.height);return s.texture.name="ShadowMap",s.texture.type=e.mapType,s.depthTexture=r,{shadowMap:s,depthTexture:r}}setupShadow(e){const{renderer:t}=e,{light:r,shadow:s}=this,i=t.shadowMap.type,{depthTexture:n,shadowMap:a}=this.setupRenderTarget(s,e);if(s.camera.updateProjectionMatrix(),i===Ie&&!0!==s.isPointLightShadow){n.compareFunction=null,a.depth>1?(a._vsmShadowMapVertical||(a._vsmShadowMapVertical=e.createRenderTarget(s.mapSize.width,s.mapSize.height,{format:Ve,type:ce,depth:a.depth,depthBuffer:!1}),a._vsmShadowMapVertical.texture.name="VSMVertical"),this.vsmShadowMapVertical=a._vsmShadowMapVertical,a._vsmShadowMapHorizontal||(a._vsmShadowMapHorizontal=e.createRenderTarget(s.mapSize.width,s.mapSize.height,{format:Ve,type:ce,depth:a.depth,depthBuffer:!1}),a._vsmShadowMapHorizontal.texture.name="VSMHorizontal"),this.vsmShadowMapHorizontal=a._vsmShadowMapHorizontal):(this.vsmShadowMapVertical=e.createRenderTarget(s.mapSize.width,s.mapSize.height,{format:Ve,type:ce,depthBuffer:!1}),this.vsmShadowMapHorizontal=e.createRenderTarget(s.mapSize.width,s.mapSize.height,{format:Ve,type:ce,depthBuffer:!1}));let t=ll(n);n.isArrayTexture&&(t=t.depth(this.depthLayer));let r=ll(this.vsmShadowMapVertical.texture);n.isArrayTexture&&(r=r.depth(this.depthLayer));const i=$d("blurSamples","float",s).setGroup(ta),o=$d("radius","float",s).setGroup(ta),u=$d("mapSize","vec2",s).setGroup(ta);let l=this.vsmMaterialVertical||(this.vsmMaterialVertical=new _p);l.fragmentNode=oT({samples:i,radius:o,size:u,shadowPass:t,depthLayer:this.depthLayer}).context(e.getSharedContext()),l.name="VSMVertical",l=this.vsmMaterialHorizontal||(this.vsmMaterialHorizontal=new _p),l.fragmentNode=uT({samples:i,radius:o,size:u,shadowPass:r,depthLayer:this.depthLayer}).context(e.getSharedContext()),l.name="VSMHorizontal"}const o=$d("intensity","float",s).setGroup(ta),u=$d("normalBias","float",s).setGroup(ta),l=Mx(r).mul(Gx.add(vd.mul(u))),d=this.setupShadowCoord(e,l),c=s.filterNode||this.getShadowFilterFn(t.shadowMap.type)||null;if(null===c)throw new Error("THREE.WebGPURenderer: Shadow map type not supported yet.");const h=i===Ie&&!0!==s.isPointLightShadow?this.vsmShadowMapHorizontal.texture:n,p=this.setupShadowFilter(e,{filterFn:c,shadowTexture:a.texture,depthTexture:h,shadowCoord:d,shadow:s,depthLayer:this.depthLayer});let g=ll(a.texture,d);n.isArrayTexture&&(g=g.depth(this.depthLayer));const m=zo(1,p.rgb.mix(g,1),o.mul(g.a)).toVar();return this.shadowMap=a,this.shadow.map=a,m}setup(e){if(!1!==e.renderer.shadowMap.enabled)return ji(()=>{let t=this._node;return this.setupShadowPosition(e),null===t&&(this._node=t=this.setupShadow(e)),e.material.shadowNode&&console.warn('THREE.NodeMaterial: ".shadowNode" is deprecated. Use ".castShadowNode" instead.'),e.material.receivedShadowNode&&(t=e.material.receivedShadowNode(t)),t})()}renderShadow(e){const{shadow:t,shadowMap:r,light:s}=this,{renderer:i,scene:n}=e;t.updateMatrices(s),r.setSize(t.mapSize.width,t.mapSize.height,r.depth),i.render(n,t.camera)}updateShadow(e){const{shadowMap:t,light:r,shadow:s}=this,{renderer:i,scene:n,camera:a}=e,o=i.shadowMap.type,u=t.depthTexture.version;this._depthVersionCached=u;const l=s.camera.layers.mask;4294967294&s.camera.layers.mask||(s.camera.layers.mask=a.layers.mask);const d=i.getRenderObjectFunction(),c=i.getMRT(),h=!!c&&c.has("velocity");dT=Xx(i,n,dT),n.overrideMaterial=sT(r),i.setRenderObjectFunction(aT(i,s,o,h)),i.setClearColor(0,0),i.setRenderTarget(t),this.renderShadow(e),i.setRenderObjectFunction(d),o===Ie&&!0!==s.isPointLightShadow&&this.vsmPass(i),s.camera.layers.mask=l,Kx(i,n,dT)}vsmPass(e){const{shadow:t}=this,r=this.shadowMap.depth;this.vsmShadowMapVertical.setSize(t.mapSize.width,t.mapSize.height,r),this.vsmShadowMapHorizontal.setSize(t.mapSize.width,t.mapSize.height,r),e.setRenderTarget(this.vsmShadowMapVertical),cT.material=this.vsmMaterialVertical,cT.render(e),e.setRenderTarget(this.vsmShadowMapHorizontal),cT.material=this.vsmMaterialHorizontal,cT.render(e)}dispose(){this.shadowMap.dispose(),this.shadowMap=null,null!==this.vsmShadowMapVertical&&(this.vsmShadowMapVertical.dispose(),this.vsmShadowMapVertical=null,this.vsmMaterialVertical.dispose(),this.vsmMaterialVertical=null),null!==this.vsmShadowMapHorizontal&&(this.vsmShadowMapHorizontal.dispose(),this.vsmShadowMapHorizontal=null,this.vsmMaterialHorizontal.dispose(),this.vsmMaterialHorizontal=null),super.dispose()}updateBefore(e){const{shadow:t}=this;let r=t.needsUpdate||t.autoUpdate;r&&(this._cameraFrameId[e.camera]===e.frameId&&(r=!1),this._cameraFrameId[e.camera]=e.frameId),r&&(this.updateShadow(e),this.shadowMap.depthTexture.version===this._depthVersionCached&&(t.needsUpdate=!1))}}const pT=(e,t)=>Vi(new hT(e,t)),gT=new e,mT=ji(([e,t])=>{const r=e.toVar(),s=co(r),i=fa(1,Ro(s.x,Ro(s.y,s.z)));s.mulAssign(i),r.mulAssign(i.mul(t.mul(2).oneMinus()));const n=rn(r.xy).toVar(),a=t.mul(1.5).oneMinus();return Ki(s.z.greaterThanEqual(a),()=>{Ki(r.z.greaterThan(0),()=>{n.x.assign(ga(4,r.x))})}).ElseIf(s.x.greaterThanEqual(a),()=>{const e=ho(r.x);n.x.assign(r.z.mul(e).add(e.mul(2)))}).ElseIf(s.y.greaterThanEqual(a),()=>{const e=ho(r.y);n.x.assign(r.x.add(e.mul(2)).add(2)),n.y.assign(r.z.mul(e).sub(2))}),rn(.125,.25).mul(n).add(rn(.375,.75)).flipY()}).setLayout({name:"cubeToUV",type:"vec2",inputs:[{name:"pos",type:"vec3"},{name:"texelSizeY",type:"float"}]}),fT=ji(({depthTexture:e,bd3D:t,dp:r,texelSize:s})=>ll(e,mT(t,s.y)).compare(r)),yT=ji(({depthTexture:e,bd3D:t,dp:r,texelSize:s,shadow:i})=>{const n=$d("radius","float",i).setGroup(ta),a=rn(-1,1).mul(n).mul(s.y);return ll(e,mT(t.add(a.xyy),s.y)).compare(r).add(ll(e,mT(t.add(a.yyy),s.y)).compare(r)).add(ll(e,mT(t.add(a.xyx),s.y)).compare(r)).add(ll(e,mT(t.add(a.yyx),s.y)).compare(r)).add(ll(e,mT(t,s.y)).compare(r)).add(ll(e,mT(t.add(a.xxy),s.y)).compare(r)).add(ll(e,mT(t.add(a.yxy),s.y)).compare(r)).add(ll(e,mT(t.add(a.xxx),s.y)).compare(r)).add(ll(e,mT(t.add(a.yxx),s.y)).compare(r)).mul(1/9)}),bT=ji(({filterFn:e,depthTexture:t,shadowCoord:r,shadow:s})=>{const i=r.xyz.toVar(),n=i.length(),a=ia("float").setGroup(ta).onRenderUpdate(()=>s.camera.near),o=ia("float").setGroup(ta).onRenderUpdate(()=>s.camera.far),u=$d("bias","float",s).setGroup(ta),l=ia(s.mapSize).setGroup(ta),d=Zi(1).toVar();return Ki(n.sub(o).lessThanEqual(0).and(n.sub(a).greaterThanEqual(0)),()=>{const r=n.sub(a).div(o.sub(a)).toVar();r.addAssign(u);const c=i.normalize(),h=rn(1).div(l.mul(rn(4,2)));d.assign(e({depthTexture:t,bd3D:c,dp:r,texelSize:h,shadow:s}))}),d}),xT=new s,TT=new t,_T=new t;class vT extends hT{static get type(){return"PointShadowNode"}constructor(e,t=null){super(e,t)}getShadowFilterFn(e){return e===Ue?fT:yT}setupShadowCoord(e,t){return t}setupShadowFilter(e,{filterFn:t,shadowTexture:r,depthTexture:s,shadowCoord:i,shadow:n}){return bT({filterFn:t,shadowTexture:r,depthTexture:s,shadowCoord:i,shadow:n})}renderShadow(e){const{shadow:t,shadowMap:r,light:s}=this,{renderer:i,scene:n}=e,a=t.getFrameExtents();_T.copy(t.mapSize),_T.multiply(a),r.setSize(_T.width,_T.height),TT.copy(t.mapSize);const o=i.autoClear,u=i.getClearColor(gT),l=i.getClearAlpha();i.autoClear=!1,i.setClearColor(t.clearColor,t.clearAlpha),i.clear();const d=t.getViewportCount();for(let e=0;eVi(new vT(e,t));class ST extends Gh{static get type(){return"AnalyticLightNode"}constructor(t=null){super(),this.light=t,this.color=new e,this.colorNode=t&&t.colorNode||ia(this.color).setGroup(ta),this.baseColorNode=null,this.shadowNode=null,this.shadowColorNode=null,this.isAnalyticLightNode=!0,this.updateType=ks.FRAME}getHash(){return this.light.uuid}getLightVector(e){return Lx(this.light).sub(e.context.positionView||dd)}setupDirect(){}setupDirectRectArea(){}setupShadowNode(){return pT(this.light)}setupShadow(e){const{renderer:t}=e;if(!1===t.shadowMap.enabled)return;let r=this.shadowColorNode;if(null===r){const e=this.light.shadow.shadowNode;let t;t=void 0!==e?Vi(e):this.setupShadowNode(),this.shadowNode=t,this.shadowColorNode=r=this.colorNode.mul(t),this.baseColorNode=this.colorNode}this.colorNode=r}setup(e){this.colorNode=this.baseColorNode||this.colorNode,this.light.castShadow?e.object.receiveShadow&&this.setupShadow(e):null!==this.shadowNode&&(this.shadowNode.dispose(),this.shadowNode=null,this.shadowColorNode=null);const t=this.setupDirect(e),r=this.setupDirectRectArea(e);t&&e.lightsNode.setupDirectLight(e,this,t),r&&e.lightsNode.setupDirectRectAreaLight(e,this,r)}update(){const{light:e}=this;this.color.copy(e.color).multiplyScalar(e.intensity)}}const ET=ji(({lightDistance:e,cutoffDistance:t,decayExponent:r})=>{const s=e.pow(r).max(.01).reciprocal();return t.greaterThan(0).select(s.mul(e.div(t).pow4().oneMinus().clamp().pow2()),s)}),wT=({color:e,lightVector:t,cutoffDistance:r,decayExponent:s})=>{const i=t.normalize(),n=t.length(),a=ET({lightDistance:n,cutoffDistance:r,decayExponent:s});return{lightDirection:i,lightColor:e.mul(a)}};class AT extends ST{static get type(){return"PointLightNode"}constructor(e=null){super(e),this.cutoffDistanceNode=ia(0).setGroup(ta),this.decayExponentNode=ia(2).setGroup(ta)}update(e){const{light:t}=this;super.update(e),this.cutoffDistanceNode.value=t.distance,this.decayExponentNode.value=t.decay}setupShadowNode(){return NT(this.light)}setupDirect(e){return wT({color:this.colorNode,lightVector:this.getLightVector(e),cutoffDistance:this.cutoffDistanceNode,decayExponent:this.decayExponentNode})}}const RT=ji(([e=tl()])=>{const t=e.mul(2),r=t.x.floor(),s=t.y.floor();return r.add(s).mod(2).sign()}),CT=ji(([e=tl()],{renderer:t,material:r})=>{const s=Go(e.mul(2).sub(1));let i;if(r.alphaToCoverage&&t.samples>1){const e=Zi(s.fwidth()).toVar();i=jo(e.oneMinus(),e.add(1),s).oneMinus()}else i=ru(s.greaterThan(1),0,1);return i}),MT=ji(([e,t,r])=>{const s=Zi(r).toVar(),i=Zi(t).toVar(),n=tn(e).toVar();return ru(n,i,s)}).setLayout({name:"mx_select",type:"float",inputs:[{name:"b",type:"bool"},{name:"t",type:"float"},{name:"f",type:"float"}]}),PT=ji(([e,t])=>{const r=tn(t).toVar(),s=Zi(e).toVar();return ru(r,s.negate(),s)}).setLayout({name:"mx_negate_if",type:"float",inputs:[{name:"val",type:"float"},{name:"b",type:"bool"}]}),BT=ji(([e])=>{const t=Zi(e).toVar();return Ji(eo(t))}).setLayout({name:"mx_floor",type:"int",inputs:[{name:"x",type:"float"}]}),FT=ji(([e,t])=>{const r=Zi(e).toVar();return t.assign(BT(r)),r.sub(Zi(t))}),LT=Ty([ji(([e,t,r,s,i,n])=>{const a=Zi(n).toVar(),o=Zi(i).toVar(),u=Zi(s).toVar(),l=Zi(r).toVar(),d=Zi(t).toVar(),c=Zi(e).toVar(),h=Zi(ga(1,o)).toVar();return ga(1,a).mul(c.mul(h).add(d.mul(o))).add(a.mul(l.mul(h).add(u.mul(o))))}).setLayout({name:"mx_bilerp_0",type:"float",inputs:[{name:"v0",type:"float"},{name:"v1",type:"float"},{name:"v2",type:"float"},{name:"v3",type:"float"},{name:"s",type:"float"},{name:"t",type:"float"}]}),ji(([e,t,r,s,i,n])=>{const a=Zi(n).toVar(),o=Zi(i).toVar(),u=on(s).toVar(),l=on(r).toVar(),d=on(t).toVar(),c=on(e).toVar(),h=Zi(ga(1,o)).toVar();return ga(1,a).mul(c.mul(h).add(d.mul(o))).add(a.mul(l.mul(h).add(u.mul(o))))}).setLayout({name:"mx_bilerp_1",type:"vec3",inputs:[{name:"v0",type:"vec3"},{name:"v1",type:"vec3"},{name:"v2",type:"vec3"},{name:"v3",type:"vec3"},{name:"s",type:"float"},{name:"t",type:"float"}]})]),IT=Ty([ji(([e,t,r,s,i,n,a,o,u,l,d])=>{const c=Zi(d).toVar(),h=Zi(l).toVar(),p=Zi(u).toVar(),g=Zi(o).toVar(),m=Zi(a).toVar(),f=Zi(n).toVar(),y=Zi(i).toVar(),b=Zi(s).toVar(),x=Zi(r).toVar(),T=Zi(t).toVar(),_=Zi(e).toVar(),v=Zi(ga(1,p)).toVar(),N=Zi(ga(1,h)).toVar();return Zi(ga(1,c)).toVar().mul(N.mul(_.mul(v).add(T.mul(p))).add(h.mul(x.mul(v).add(b.mul(p))))).add(c.mul(N.mul(y.mul(v).add(f.mul(p))).add(h.mul(m.mul(v).add(g.mul(p))))))}).setLayout({name:"mx_trilerp_0",type:"float",inputs:[{name:"v0",type:"float"},{name:"v1",type:"float"},{name:"v2",type:"float"},{name:"v3",type:"float"},{name:"v4",type:"float"},{name:"v5",type:"float"},{name:"v6",type:"float"},{name:"v7",type:"float"},{name:"s",type:"float"},{name:"t",type:"float"},{name:"r",type:"float"}]}),ji(([e,t,r,s,i,n,a,o,u,l,d])=>{const c=Zi(d).toVar(),h=Zi(l).toVar(),p=Zi(u).toVar(),g=on(o).toVar(),m=on(a).toVar(),f=on(n).toVar(),y=on(i).toVar(),b=on(s).toVar(),x=on(r).toVar(),T=on(t).toVar(),_=on(e).toVar(),v=Zi(ga(1,p)).toVar(),N=Zi(ga(1,h)).toVar();return Zi(ga(1,c)).toVar().mul(N.mul(_.mul(v).add(T.mul(p))).add(h.mul(x.mul(v).add(b.mul(p))))).add(c.mul(N.mul(y.mul(v).add(f.mul(p))).add(h.mul(m.mul(v).add(g.mul(p))))))}).setLayout({name:"mx_trilerp_1",type:"vec3",inputs:[{name:"v0",type:"vec3"},{name:"v1",type:"vec3"},{name:"v2",type:"vec3"},{name:"v3",type:"vec3"},{name:"v4",type:"vec3"},{name:"v5",type:"vec3"},{name:"v6",type:"vec3"},{name:"v7",type:"vec3"},{name:"s",type:"float"},{name:"t",type:"float"},{name:"r",type:"float"}]})]),DT=ji(([e,t,r])=>{const s=Zi(r).toVar(),i=Zi(t).toVar(),n=en(e).toVar(),a=en(n.bitAnd(en(7))).toVar(),o=Zi(MT(a.lessThan(en(4)),i,s)).toVar(),u=Zi(ma(2,MT(a.lessThan(en(4)),s,i))).toVar();return PT(o,tn(a.bitAnd(en(1)))).add(PT(u,tn(a.bitAnd(en(2)))))}).setLayout({name:"mx_gradient_float_0",type:"float",inputs:[{name:"hash",type:"uint"},{name:"x",type:"float"},{name:"y",type:"float"}]}),VT=ji(([e,t,r,s])=>{const i=Zi(s).toVar(),n=Zi(r).toVar(),a=Zi(t).toVar(),o=en(e).toVar(),u=en(o.bitAnd(en(15))).toVar(),l=Zi(MT(u.lessThan(en(8)),a,n)).toVar(),d=Zi(MT(u.lessThan(en(4)),n,MT(u.equal(en(12)).or(u.equal(en(14))),a,i))).toVar();return PT(l,tn(u.bitAnd(en(1)))).add(PT(d,tn(u.bitAnd(en(2)))))}).setLayout({name:"mx_gradient_float_1",type:"float",inputs:[{name:"hash",type:"uint"},{name:"x",type:"float"},{name:"y",type:"float"},{name:"z",type:"float"}]}),UT=Ty([DT,VT]),OT=ji(([e,t,r])=>{const s=Zi(r).toVar(),i=Zi(t).toVar(),n=ln(e).toVar();return on(UT(n.x,i,s),UT(n.y,i,s),UT(n.z,i,s))}).setLayout({name:"mx_gradient_vec3_0",type:"vec3",inputs:[{name:"hash",type:"uvec3"},{name:"x",type:"float"},{name:"y",type:"float"}]}),kT=ji(([e,t,r,s])=>{const i=Zi(s).toVar(),n=Zi(r).toVar(),a=Zi(t).toVar(),o=ln(e).toVar();return on(UT(o.x,a,n,i),UT(o.y,a,n,i),UT(o.z,a,n,i))}).setLayout({name:"mx_gradient_vec3_1",type:"vec3",inputs:[{name:"hash",type:"uvec3"},{name:"x",type:"float"},{name:"y",type:"float"},{name:"z",type:"float"}]}),GT=Ty([OT,kT]),zT=ji(([e])=>{const t=Zi(e).toVar();return ma(.6616,t)}).setLayout({name:"mx_gradient_scale2d_0",type:"float",inputs:[{name:"v",type:"float"}]}),HT=ji(([e])=>{const t=Zi(e).toVar();return ma(.982,t)}).setLayout({name:"mx_gradient_scale3d_0",type:"float",inputs:[{name:"v",type:"float"}]}),$T=Ty([zT,ji(([e])=>{const t=on(e).toVar();return ma(.6616,t)}).setLayout({name:"mx_gradient_scale2d_1",type:"vec3",inputs:[{name:"v",type:"vec3"}]})]),WT=Ty([HT,ji(([e])=>{const t=on(e).toVar();return ma(.982,t)}).setLayout({name:"mx_gradient_scale3d_1",type:"vec3",inputs:[{name:"v",type:"vec3"}]})]),jT=ji(([e,t])=>{const r=Ji(t).toVar(),s=en(e).toVar();return s.shiftLeft(r).bitOr(s.shiftRight(Ji(32).sub(r)))}).setLayout({name:"mx_rotl32",type:"uint",inputs:[{name:"x",type:"uint"},{name:"k",type:"int"}]}),qT=ji(([e,t,r])=>{e.subAssign(r),e.bitXorAssign(jT(r,Ji(4))),r.addAssign(t),t.subAssign(e),t.bitXorAssign(jT(e,Ji(6))),e.addAssign(r),r.subAssign(t),r.bitXorAssign(jT(t,Ji(8))),t.addAssign(e),e.subAssign(r),e.bitXorAssign(jT(r,Ji(16))),r.addAssign(t),t.subAssign(e),t.bitXorAssign(jT(e,Ji(19))),e.addAssign(r),r.subAssign(t),r.bitXorAssign(jT(t,Ji(4))),t.addAssign(e)}),XT=ji(([e,t,r])=>{const s=en(r).toVar(),i=en(t).toVar(),n=en(e).toVar();return s.bitXorAssign(i),s.subAssign(jT(i,Ji(14))),n.bitXorAssign(s),n.subAssign(jT(s,Ji(11))),i.bitXorAssign(n),i.subAssign(jT(n,Ji(25))),s.bitXorAssign(i),s.subAssign(jT(i,Ji(16))),n.bitXorAssign(s),n.subAssign(jT(s,Ji(4))),i.bitXorAssign(n),i.subAssign(jT(n,Ji(14))),s.bitXorAssign(i),s.subAssign(jT(i,Ji(24))),s}).setLayout({name:"mx_bjfinal",type:"uint",inputs:[{name:"a",type:"uint"},{name:"b",type:"uint"},{name:"c",type:"uint"}]}),KT=ji(([e])=>{const t=en(e).toVar();return Zi(t).div(Zi(en(Ji(4294967295))))}).setLayout({name:"mx_bits_to_01",type:"float",inputs:[{name:"bits",type:"uint"}]}),YT=ji(([e])=>{const t=Zi(e).toVar();return t.mul(t).mul(t).mul(t.mul(t.mul(6).sub(15)).add(10))}).setLayout({name:"mx_fade",type:"float",inputs:[{name:"t",type:"float"}]}),QT=Ty([ji(([e])=>{const t=Ji(e).toVar(),r=en(en(1)).toVar(),s=en(en(Ji(3735928559)).add(r.shiftLeft(en(2))).add(en(13))).toVar();return XT(s.add(en(t)),s,s)}).setLayout({name:"mx_hash_int_0",type:"uint",inputs:[{name:"x",type:"int"}]}),ji(([e,t])=>{const r=Ji(t).toVar(),s=Ji(e).toVar(),i=en(en(2)).toVar(),n=en().toVar(),a=en().toVar(),o=en().toVar();return n.assign(a.assign(o.assign(en(Ji(3735928559)).add(i.shiftLeft(en(2))).add(en(13))))),n.addAssign(en(s)),a.addAssign(en(r)),XT(n,a,o)}).setLayout({name:"mx_hash_int_1",type:"uint",inputs:[{name:"x",type:"int"},{name:"y",type:"int"}]}),ji(([e,t,r])=>{const s=Ji(r).toVar(),i=Ji(t).toVar(),n=Ji(e).toVar(),a=en(en(3)).toVar(),o=en().toVar(),u=en().toVar(),l=en().toVar();return o.assign(u.assign(l.assign(en(Ji(3735928559)).add(a.shiftLeft(en(2))).add(en(13))))),o.addAssign(en(n)),u.addAssign(en(i)),l.addAssign(en(s)),XT(o,u,l)}).setLayout({name:"mx_hash_int_2",type:"uint",inputs:[{name:"x",type:"int"},{name:"y",type:"int"},{name:"z",type:"int"}]}),ji(([e,t,r,s])=>{const i=Ji(s).toVar(),n=Ji(r).toVar(),a=Ji(t).toVar(),o=Ji(e).toVar(),u=en(en(4)).toVar(),l=en().toVar(),d=en().toVar(),c=en().toVar();return l.assign(d.assign(c.assign(en(Ji(3735928559)).add(u.shiftLeft(en(2))).add(en(13))))),l.addAssign(en(o)),d.addAssign(en(a)),c.addAssign(en(n)),qT(l,d,c),l.addAssign(en(i)),XT(l,d,c)}).setLayout({name:"mx_hash_int_3",type:"uint",inputs:[{name:"x",type:"int"},{name:"y",type:"int"},{name:"z",type:"int"},{name:"xx",type:"int"}]}),ji(([e,t,r,s,i])=>{const n=Ji(i).toVar(),a=Ji(s).toVar(),o=Ji(r).toVar(),u=Ji(t).toVar(),l=Ji(e).toVar(),d=en(en(5)).toVar(),c=en().toVar(),h=en().toVar(),p=en().toVar();return c.assign(h.assign(p.assign(en(Ji(3735928559)).add(d.shiftLeft(en(2))).add(en(13))))),c.addAssign(en(l)),h.addAssign(en(u)),p.addAssign(en(o)),qT(c,h,p),c.addAssign(en(a)),h.addAssign(en(n)),XT(c,h,p)}).setLayout({name:"mx_hash_int_4",type:"uint",inputs:[{name:"x",type:"int"},{name:"y",type:"int"},{name:"z",type:"int"},{name:"xx",type:"int"},{name:"yy",type:"int"}]})]),ZT=Ty([ji(([e,t])=>{const r=Ji(t).toVar(),s=Ji(e).toVar(),i=en(QT(s,r)).toVar(),n=ln().toVar();return n.x.assign(i.bitAnd(Ji(255))),n.y.assign(i.shiftRight(Ji(8)).bitAnd(Ji(255))),n.z.assign(i.shiftRight(Ji(16)).bitAnd(Ji(255))),n}).setLayout({name:"mx_hash_vec3_0",type:"uvec3",inputs:[{name:"x",type:"int"},{name:"y",type:"int"}]}),ji(([e,t,r])=>{const s=Ji(r).toVar(),i=Ji(t).toVar(),n=Ji(e).toVar(),a=en(QT(n,i,s)).toVar(),o=ln().toVar();return o.x.assign(a.bitAnd(Ji(255))),o.y.assign(a.shiftRight(Ji(8)).bitAnd(Ji(255))),o.z.assign(a.shiftRight(Ji(16)).bitAnd(Ji(255))),o}).setLayout({name:"mx_hash_vec3_1",type:"uvec3",inputs:[{name:"x",type:"int"},{name:"y",type:"int"},{name:"z",type:"int"}]})]),JT=Ty([ji(([e])=>{const t=rn(e).toVar(),r=Ji().toVar(),s=Ji().toVar(),i=Zi(FT(t.x,r)).toVar(),n=Zi(FT(t.y,s)).toVar(),a=Zi(YT(i)).toVar(),o=Zi(YT(n)).toVar(),u=Zi(LT(UT(QT(r,s),i,n),UT(QT(r.add(Ji(1)),s),i.sub(1),n),UT(QT(r,s.add(Ji(1))),i,n.sub(1)),UT(QT(r.add(Ji(1)),s.add(Ji(1))),i.sub(1),n.sub(1)),a,o)).toVar();return $T(u)}).setLayout({name:"mx_perlin_noise_float_0",type:"float",inputs:[{name:"p",type:"vec2"}]}),ji(([e])=>{const t=on(e).toVar(),r=Ji().toVar(),s=Ji().toVar(),i=Ji().toVar(),n=Zi(FT(t.x,r)).toVar(),a=Zi(FT(t.y,s)).toVar(),o=Zi(FT(t.z,i)).toVar(),u=Zi(YT(n)).toVar(),l=Zi(YT(a)).toVar(),d=Zi(YT(o)).toVar(),c=Zi(IT(UT(QT(r,s,i),n,a,o),UT(QT(r.add(Ji(1)),s,i),n.sub(1),a,o),UT(QT(r,s.add(Ji(1)),i),n,a.sub(1),o),UT(QT(r.add(Ji(1)),s.add(Ji(1)),i),n.sub(1),a.sub(1),o),UT(QT(r,s,i.add(Ji(1))),n,a,o.sub(1)),UT(QT(r.add(Ji(1)),s,i.add(Ji(1))),n.sub(1),a,o.sub(1)),UT(QT(r,s.add(Ji(1)),i.add(Ji(1))),n,a.sub(1),o.sub(1)),UT(QT(r.add(Ji(1)),s.add(Ji(1)),i.add(Ji(1))),n.sub(1),a.sub(1),o.sub(1)),u,l,d)).toVar();return WT(c)}).setLayout({name:"mx_perlin_noise_float_1",type:"float",inputs:[{name:"p",type:"vec3"}]})]),e_=Ty([ji(([e])=>{const t=rn(e).toVar(),r=Ji().toVar(),s=Ji().toVar(),i=Zi(FT(t.x,r)).toVar(),n=Zi(FT(t.y,s)).toVar(),a=Zi(YT(i)).toVar(),o=Zi(YT(n)).toVar(),u=on(LT(GT(ZT(r,s),i,n),GT(ZT(r.add(Ji(1)),s),i.sub(1),n),GT(ZT(r,s.add(Ji(1))),i,n.sub(1)),GT(ZT(r.add(Ji(1)),s.add(Ji(1))),i.sub(1),n.sub(1)),a,o)).toVar();return $T(u)}).setLayout({name:"mx_perlin_noise_vec3_0",type:"vec3",inputs:[{name:"p",type:"vec2"}]}),ji(([e])=>{const t=on(e).toVar(),r=Ji().toVar(),s=Ji().toVar(),i=Ji().toVar(),n=Zi(FT(t.x,r)).toVar(),a=Zi(FT(t.y,s)).toVar(),o=Zi(FT(t.z,i)).toVar(),u=Zi(YT(n)).toVar(),l=Zi(YT(a)).toVar(),d=Zi(YT(o)).toVar(),c=on(IT(GT(ZT(r,s,i),n,a,o),GT(ZT(r.add(Ji(1)),s,i),n.sub(1),a,o),GT(ZT(r,s.add(Ji(1)),i),n,a.sub(1),o),GT(ZT(r.add(Ji(1)),s.add(Ji(1)),i),n.sub(1),a.sub(1),o),GT(ZT(r,s,i.add(Ji(1))),n,a,o.sub(1)),GT(ZT(r.add(Ji(1)),s,i.add(Ji(1))),n.sub(1),a,o.sub(1)),GT(ZT(r,s.add(Ji(1)),i.add(Ji(1))),n,a.sub(1),o.sub(1)),GT(ZT(r.add(Ji(1)),s.add(Ji(1)),i.add(Ji(1))),n.sub(1),a.sub(1),o.sub(1)),u,l,d)).toVar();return WT(c)}).setLayout({name:"mx_perlin_noise_vec3_1",type:"vec3",inputs:[{name:"p",type:"vec3"}]})]),t_=Ty([ji(([e])=>{const t=Zi(e).toVar(),r=Ji(BT(t)).toVar();return KT(QT(r))}).setLayout({name:"mx_cell_noise_float_0",type:"float",inputs:[{name:"p",type:"float"}]}),ji(([e])=>{const t=rn(e).toVar(),r=Ji(BT(t.x)).toVar(),s=Ji(BT(t.y)).toVar();return KT(QT(r,s))}).setLayout({name:"mx_cell_noise_float_1",type:"float",inputs:[{name:"p",type:"vec2"}]}),ji(([e])=>{const t=on(e).toVar(),r=Ji(BT(t.x)).toVar(),s=Ji(BT(t.y)).toVar(),i=Ji(BT(t.z)).toVar();return KT(QT(r,s,i))}).setLayout({name:"mx_cell_noise_float_2",type:"float",inputs:[{name:"p",type:"vec3"}]}),ji(([e])=>{const t=cn(e).toVar(),r=Ji(BT(t.x)).toVar(),s=Ji(BT(t.y)).toVar(),i=Ji(BT(t.z)).toVar(),n=Ji(BT(t.w)).toVar();return KT(QT(r,s,i,n))}).setLayout({name:"mx_cell_noise_float_3",type:"float",inputs:[{name:"p",type:"vec4"}]})]),r_=Ty([ji(([e])=>{const t=Zi(e).toVar(),r=Ji(BT(t)).toVar();return on(KT(QT(r,Ji(0))),KT(QT(r,Ji(1))),KT(QT(r,Ji(2))))}).setLayout({name:"mx_cell_noise_vec3_0",type:"vec3",inputs:[{name:"p",type:"float"}]}),ji(([e])=>{const t=rn(e).toVar(),r=Ji(BT(t.x)).toVar(),s=Ji(BT(t.y)).toVar();return on(KT(QT(r,s,Ji(0))),KT(QT(r,s,Ji(1))),KT(QT(r,s,Ji(2))))}).setLayout({name:"mx_cell_noise_vec3_1",type:"vec3",inputs:[{name:"p",type:"vec2"}]}),ji(([e])=>{const t=on(e).toVar(),r=Ji(BT(t.x)).toVar(),s=Ji(BT(t.y)).toVar(),i=Ji(BT(t.z)).toVar();return on(KT(QT(r,s,i,Ji(0))),KT(QT(r,s,i,Ji(1))),KT(QT(r,s,i,Ji(2))))}).setLayout({name:"mx_cell_noise_vec3_2",type:"vec3",inputs:[{name:"p",type:"vec3"}]}),ji(([e])=>{const t=cn(e).toVar(),r=Ji(BT(t.x)).toVar(),s=Ji(BT(t.y)).toVar(),i=Ji(BT(t.z)).toVar(),n=Ji(BT(t.w)).toVar();return on(KT(QT(r,s,i,n,Ji(0))),KT(QT(r,s,i,n,Ji(1))),KT(QT(r,s,i,n,Ji(2))))}).setLayout({name:"mx_cell_noise_vec3_3",type:"vec3",inputs:[{name:"p",type:"vec4"}]})]),s_=ji(([e,t,r,s])=>{const i=Zi(s).toVar(),n=Zi(r).toVar(),a=Ji(t).toVar(),o=on(e).toVar(),u=Zi(0).toVar(),l=Zi(1).toVar();return Lh(a,()=>{u.addAssign(l.mul(JT(o))),l.mulAssign(i),o.mulAssign(n)}),u}).setLayout({name:"mx_fractal_noise_float",type:"float",inputs:[{name:"p",type:"vec3"},{name:"octaves",type:"int"},{name:"lacunarity",type:"float"},{name:"diminish",type:"float"}]}),i_=ji(([e,t,r,s])=>{const i=Zi(s).toVar(),n=Zi(r).toVar(),a=Ji(t).toVar(),o=on(e).toVar(),u=on(0).toVar(),l=Zi(1).toVar();return Lh(a,()=>{u.addAssign(l.mul(e_(o))),l.mulAssign(i),o.mulAssign(n)}),u}).setLayout({name:"mx_fractal_noise_vec3",type:"vec3",inputs:[{name:"p",type:"vec3"},{name:"octaves",type:"int"},{name:"lacunarity",type:"float"},{name:"diminish",type:"float"}]}),n_=ji(([e,t,r,s])=>{const i=Zi(s).toVar(),n=Zi(r).toVar(),a=Ji(t).toVar(),o=on(e).toVar();return rn(s_(o,a,n,i),s_(o.add(on(Ji(19),Ji(193),Ji(17))),a,n,i))}).setLayout({name:"mx_fractal_noise_vec2",type:"vec2",inputs:[{name:"p",type:"vec3"},{name:"octaves",type:"int"},{name:"lacunarity",type:"float"},{name:"diminish",type:"float"}]}),a_=ji(([e,t,r,s])=>{const i=Zi(s).toVar(),n=Zi(r).toVar(),a=Ji(t).toVar(),o=on(e).toVar(),u=on(i_(o,a,n,i)).toVar(),l=Zi(s_(o.add(on(Ji(19),Ji(193),Ji(17))),a,n,i)).toVar();return cn(u,l)}).setLayout({name:"mx_fractal_noise_vec4",type:"vec4",inputs:[{name:"p",type:"vec3"},{name:"octaves",type:"int"},{name:"lacunarity",type:"float"},{name:"diminish",type:"float"}]}),o_=Ty([ji(([e,t,r,s,i,n,a])=>{const o=Ji(a).toVar(),u=Zi(n).toVar(),l=Ji(i).toVar(),d=Ji(s).toVar(),c=Ji(r).toVar(),h=Ji(t).toVar(),p=rn(e).toVar(),g=on(r_(rn(h.add(d),c.add(l)))).toVar(),m=rn(g.x,g.y).toVar();m.subAssign(.5),m.mulAssign(u),m.addAssign(.5);const f=rn(rn(Zi(h),Zi(c)).add(m)).toVar(),y=rn(f.sub(p)).toVar();return Ki(o.equal(Ji(2)),()=>co(y.x).add(co(y.y))),Ki(o.equal(Ji(3)),()=>Ro(co(y.x),co(y.y))),Fo(y,y)}).setLayout({name:"mx_worley_distance_0",type:"float",inputs:[{name:"p",type:"vec2"},{name:"x",type:"int"},{name:"y",type:"int"},{name:"xoff",type:"int"},{name:"yoff",type:"int"},{name:"jitter",type:"float"},{name:"metric",type:"int"}]}),ji(([e,t,r,s,i,n,a,o,u])=>{const l=Ji(u).toVar(),d=Zi(o).toVar(),c=Ji(a).toVar(),h=Ji(n).toVar(),p=Ji(i).toVar(),g=Ji(s).toVar(),m=Ji(r).toVar(),f=Ji(t).toVar(),y=on(e).toVar(),b=on(r_(on(f.add(p),m.add(h),g.add(c)))).toVar();b.subAssign(.5),b.mulAssign(d),b.addAssign(.5);const x=on(on(Zi(f),Zi(m),Zi(g)).add(b)).toVar(),T=on(x.sub(y)).toVar();return Ki(l.equal(Ji(2)),()=>co(T.x).add(co(T.y)).add(co(T.z))),Ki(l.equal(Ji(3)),()=>Ro(co(T.x),co(T.y),co(T.z))),Fo(T,T)}).setLayout({name:"mx_worley_distance_1",type:"float",inputs:[{name:"p",type:"vec3"},{name:"x",type:"int"},{name:"y",type:"int"},{name:"z",type:"int"},{name:"xoff",type:"int"},{name:"yoff",type:"int"},{name:"zoff",type:"int"},{name:"jitter",type:"float"},{name:"metric",type:"int"}]})]),u_=ji(([e,t,r])=>{const s=Ji(r).toVar(),i=Zi(t).toVar(),n=rn(e).toVar(),a=Ji().toVar(),o=Ji().toVar(),u=rn(FT(n.x,a),FT(n.y,o)).toVar(),l=Zi(1e6).toVar();return Lh({start:-1,end:Ji(1),name:"x",condition:"<="},({x:e})=>{Lh({start:-1,end:Ji(1),name:"y",condition:"<="},({y:t})=>{const r=Zi(o_(u,e,t,a,o,i,s)).toVar();l.assign(Ao(l,r))})}),Ki(s.equal(Ji(0)),()=>{l.assign(Za(l))}),l}).setLayout({name:"mx_worley_noise_float_0",type:"float",inputs:[{name:"p",type:"vec2"},{name:"jitter",type:"float"},{name:"metric",type:"int"}]}),l_=ji(([e,t,r])=>{const s=Ji(r).toVar(),i=Zi(t).toVar(),n=rn(e).toVar(),a=Ji().toVar(),o=Ji().toVar(),u=rn(FT(n.x,a),FT(n.y,o)).toVar(),l=rn(1e6,1e6).toVar();return Lh({start:-1,end:Ji(1),name:"x",condition:"<="},({x:e})=>{Lh({start:-1,end:Ji(1),name:"y",condition:"<="},({y:t})=>{const r=Zi(o_(u,e,t,a,o,i,s)).toVar();Ki(r.lessThan(l.x),()=>{l.y.assign(l.x),l.x.assign(r)}).ElseIf(r.lessThan(l.y),()=>{l.y.assign(r)})})}),Ki(s.equal(Ji(0)),()=>{l.assign(Za(l))}),l}).setLayout({name:"mx_worley_noise_vec2_0",type:"vec2",inputs:[{name:"p",type:"vec2"},{name:"jitter",type:"float"},{name:"metric",type:"int"}]}),d_=ji(([e,t,r])=>{const s=Ji(r).toVar(),i=Zi(t).toVar(),n=rn(e).toVar(),a=Ji().toVar(),o=Ji().toVar(),u=rn(FT(n.x,a),FT(n.y,o)).toVar(),l=on(1e6,1e6,1e6).toVar();return Lh({start:-1,end:Ji(1),name:"x",condition:"<="},({x:e})=>{Lh({start:-1,end:Ji(1),name:"y",condition:"<="},({y:t})=>{const r=Zi(o_(u,e,t,a,o,i,s)).toVar();Ki(r.lessThan(l.x),()=>{l.z.assign(l.y),l.y.assign(l.x),l.x.assign(r)}).ElseIf(r.lessThan(l.y),()=>{l.z.assign(l.y),l.y.assign(r)}).ElseIf(r.lessThan(l.z),()=>{l.z.assign(r)})})}),Ki(s.equal(Ji(0)),()=>{l.assign(Za(l))}),l}).setLayout({name:"mx_worley_noise_vec3_0",type:"vec3",inputs:[{name:"p",type:"vec2"},{name:"jitter",type:"float"},{name:"metric",type:"int"}]}),c_=Ty([u_,ji(([e,t,r])=>{const s=Ji(r).toVar(),i=Zi(t).toVar(),n=on(e).toVar(),a=Ji().toVar(),o=Ji().toVar(),u=Ji().toVar(),l=on(FT(n.x,a),FT(n.y,o),FT(n.z,u)).toVar(),d=Zi(1e6).toVar();return Lh({start:-1,end:Ji(1),name:"x",condition:"<="},({x:e})=>{Lh({start:-1,end:Ji(1),name:"y",condition:"<="},({y:t})=>{Lh({start:-1,end:Ji(1),name:"z",condition:"<="},({z:r})=>{const n=Zi(o_(l,e,t,r,a,o,u,i,s)).toVar();d.assign(Ao(d,n))})})}),Ki(s.equal(Ji(0)),()=>{d.assign(Za(d))}),d}).setLayout({name:"mx_worley_noise_float_1",type:"float",inputs:[{name:"p",type:"vec3"},{name:"jitter",type:"float"},{name:"metric",type:"int"}]})]),h_=Ty([l_,ji(([e,t,r])=>{const s=Ji(r).toVar(),i=Zi(t).toVar(),n=on(e).toVar(),a=Ji().toVar(),o=Ji().toVar(),u=Ji().toVar(),l=on(FT(n.x,a),FT(n.y,o),FT(n.z,u)).toVar(),d=rn(1e6,1e6).toVar();return Lh({start:-1,end:Ji(1),name:"x",condition:"<="},({x:e})=>{Lh({start:-1,end:Ji(1),name:"y",condition:"<="},({y:t})=>{Lh({start:-1,end:Ji(1),name:"z",condition:"<="},({z:r})=>{const n=Zi(o_(l,e,t,r,a,o,u,i,s)).toVar();Ki(n.lessThan(d.x),()=>{d.y.assign(d.x),d.x.assign(n)}).ElseIf(n.lessThan(d.y),()=>{d.y.assign(n)})})})}),Ki(s.equal(Ji(0)),()=>{d.assign(Za(d))}),d}).setLayout({name:"mx_worley_noise_vec2_1",type:"vec2",inputs:[{name:"p",type:"vec3"},{name:"jitter",type:"float"},{name:"metric",type:"int"}]})]),p_=Ty([d_,ji(([e,t,r])=>{const s=Ji(r).toVar(),i=Zi(t).toVar(),n=on(e).toVar(),a=Ji().toVar(),o=Ji().toVar(),u=Ji().toVar(),l=on(FT(n.x,a),FT(n.y,o),FT(n.z,u)).toVar(),d=on(1e6,1e6,1e6).toVar();return Lh({start:-1,end:Ji(1),name:"x",condition:"<="},({x:e})=>{Lh({start:-1,end:Ji(1),name:"y",condition:"<="},({y:t})=>{Lh({start:-1,end:Ji(1),name:"z",condition:"<="},({z:r})=>{const n=Zi(o_(l,e,t,r,a,o,u,i,s)).toVar();Ki(n.lessThan(d.x),()=>{d.z.assign(d.y),d.y.assign(d.x),d.x.assign(n)}).ElseIf(n.lessThan(d.y),()=>{d.z.assign(d.y),d.y.assign(n)}).ElseIf(n.lessThan(d.z),()=>{d.z.assign(n)})})})}),Ki(s.equal(Ji(0)),()=>{d.assign(Za(d))}),d}).setLayout({name:"mx_worley_noise_vec3_1",type:"vec3",inputs:[{name:"p",type:"vec3"},{name:"jitter",type:"float"},{name:"metric",type:"int"}]})]),g_=ji(([e,t,r,s,i,n,a,o,u,l,d])=>{const c=Ji(e).toVar(),h=rn(t).toVar(),p=rn(r).toVar(),g=rn(s).toVar(),m=Zi(i).toVar(),f=Zi(n).toVar(),y=Zi(a).toVar(),b=tn(o).toVar(),x=Ji(u).toVar(),T=Zi(l).toVar(),_=Zi(d).toVar(),v=h.mul(p).add(g),N=Zi(0).toVar();return Ki(c.equal(Ji(0)),()=>{N.assign(e_(v))}),Ki(c.equal(Ji(1)),()=>{N.assign(r_(v))}),Ki(c.equal(Ji(2)),()=>{N.assign(p_(v,m,Ji(0)))}),Ki(c.equal(Ji(3)),()=>{N.assign(i_(on(v,0),x,T,_))}),N.assign(N.mul(y.sub(f)).add(f)),Ki(b,()=>{N.assign(Ho(N,f,y))}),N}).setLayout({name:"mx_unifiednoise2d",type:"float",inputs:[{name:"noiseType",type:"int"},{name:"texcoord",type:"vec2"},{name:"freq",type:"vec2"},{name:"offset",type:"vec2"},{name:"jitter",type:"float"},{name:"outmin",type:"float"},{name:"outmax",type:"float"},{name:"clampoutput",type:"bool"},{name:"octaves",type:"int"},{name:"lacunarity",type:"float"},{name:"diminish",type:"float"}]}),m_=ji(([e,t,r,s,i,n,a,o,u,l,d])=>{const c=Ji(e).toVar(),h=on(t).toVar(),p=on(r).toVar(),g=on(s).toVar(),m=Zi(i).toVar(),f=Zi(n).toVar(),y=Zi(a).toVar(),b=tn(o).toVar(),x=Ji(u).toVar(),T=Zi(l).toVar(),_=Zi(d).toVar(),v=h.mul(p).add(g),N=Zi(0).toVar();return Ki(c.equal(Ji(0)),()=>{N.assign(e_(v))}),Ki(c.equal(Ji(1)),()=>{N.assign(r_(v))}),Ki(c.equal(Ji(2)),()=>{N.assign(p_(v,m,Ji(0)))}),Ki(c.equal(Ji(3)),()=>{N.assign(i_(v,x,T,_))}),N.assign(N.mul(y.sub(f)).add(f)),Ki(b,()=>{N.assign(Ho(N,f,y))}),N}).setLayout({name:"mx_unifiednoise3d",type:"float",inputs:[{name:"noiseType",type:"int"},{name:"position",type:"vec3"},{name:"freq",type:"vec3"},{name:"offset",type:"vec3"},{name:"jitter",type:"float"},{name:"outmin",type:"float"},{name:"outmax",type:"float"},{name:"clampoutput",type:"bool"},{name:"octaves",type:"int"},{name:"lacunarity",type:"float"},{name:"diminish",type:"float"}]}),f_=ji(([e])=>{const t=e.y,r=e.z,s=on().toVar();return Ki(t.lessThan(1e-4),()=>{s.assign(on(r,r,r))}).Else(()=>{let i=e.x;i=i.sub(eo(i)).mul(6).toVar();const n=Ji(To(i)),a=i.sub(Zi(n)),o=r.mul(t.oneMinus()),u=r.mul(t.mul(a).oneMinus()),l=r.mul(t.mul(a.oneMinus()).oneMinus());Ki(n.equal(Ji(0)),()=>{s.assign(on(r,l,o))}).ElseIf(n.equal(Ji(1)),()=>{s.assign(on(u,r,o))}).ElseIf(n.equal(Ji(2)),()=>{s.assign(on(o,r,l))}).ElseIf(n.equal(Ji(3)),()=>{s.assign(on(o,u,r))}).ElseIf(n.equal(Ji(4)),()=>{s.assign(on(l,o,r))}).Else(()=>{s.assign(on(r,o,u))})}),s}).setLayout({name:"mx_hsvtorgb",type:"vec3",inputs:[{name:"hsv",type:"vec3"}]}),y_=ji(([e])=>{const t=on(e).toVar(),r=Zi(t.x).toVar(),s=Zi(t.y).toVar(),i=Zi(t.z).toVar(),n=Zi(Ao(r,Ao(s,i))).toVar(),a=Zi(Ro(r,Ro(s,i))).toVar(),o=Zi(a.sub(n)).toVar(),u=Zi().toVar(),l=Zi().toVar(),d=Zi().toVar();return d.assign(a),Ki(a.greaterThan(0),()=>{l.assign(o.div(a))}).Else(()=>{l.assign(0)}),Ki(l.lessThanEqual(0),()=>{u.assign(0)}).Else(()=>{Ki(r.greaterThanEqual(a),()=>{u.assign(s.sub(i).div(o))}).ElseIf(s.greaterThanEqual(a),()=>{u.assign(pa(2,i.sub(r).div(o)))}).Else(()=>{u.assign(pa(4,r.sub(s).div(o)))}),u.mulAssign(1/6),Ki(u.lessThan(0),()=>{u.addAssign(1)})}),on(u,l,d)}).setLayout({name:"mx_rgbtohsv",type:"vec3",inputs:[{name:"c",type:"vec3"}]}),b_=ji(([e])=>{const t=on(e).toVar(),r=dn(_a(t,on(.04045))).toVar(),s=on(t.div(12.92)).toVar(),i=on(Io(Ro(t.add(on(.055)),on(0)).div(1.055),on(2.4))).toVar();return zo(s,i,r)}).setLayout({name:"mx_srgb_texture_to_lin_rec709",type:"vec3",inputs:[{name:"color",type:"vec3"}]}),x_=(e,t)=>{e=Zi(e),t=Zi(t);const r=rn(t.dFdx(),t.dFdy()).length().mul(.7071067811865476);return jo(e.sub(r),e.add(r),t)},T_=(e,t,r,s)=>zo(e,t,r[s].clamp()),__=(e,t,r,s,i)=>zo(e,t,x_(r,s[i])),v_=ji(([e,t,r])=>{const s=ro(e).toVar(),i=ga(Zi(.5).mul(t.sub(r)),ud).div(s).toVar(),n=ga(Zi(-.5).mul(t.sub(r)),ud).div(s).toVar(),a=on().toVar();a.x=s.x.greaterThan(Zi(0)).select(i.x,n.x),a.y=s.y.greaterThan(Zi(0)).select(i.y,n.y),a.z=s.z.greaterThan(Zi(0)).select(i.z,n.z);const o=Ao(a.x,a.y,a.z).toVar();return ud.add(s.mul(o)).toVar().sub(r)}),N_=ji(([e,t])=>{const r=e.x,s=e.y,i=e.z;let n=t.element(0).mul(.886227);return n=n.add(t.element(1).mul(1.023328).mul(s)),n=n.add(t.element(2).mul(1.023328).mul(i)),n=n.add(t.element(3).mul(1.023328).mul(r)),n=n.add(t.element(4).mul(.858086).mul(r).mul(s)),n=n.add(t.element(5).mul(.858086).mul(s).mul(i)),n=n.add(t.element(6).mul(i.mul(i).mul(.743125).sub(.247708))),n=n.add(t.element(7).mul(.858086).mul(r).mul(i)),n=n.add(t.element(8).mul(.429043).mul(ma(r,r).sub(ma(s,s)))),n});var S_=Object.freeze({__proto__:null,BRDF_GGX:lg,BRDF_Lambert:Xp,BasicPointShadowFilter:fT,BasicShadowFilter:Zx,Break:Ih,Const:cu,Continue:()=>qu("continue").toStack(),DFGApprox:dg,D_GGX:ag,Discard:Xu,EPSILON:ka,F_Schlick:qp,Fn:ji,INFINITY:Ga,If:Ki,Loop:Lh,NodeAccess:zs,NodeShaderStage:Os,NodeType:Gs,NodeUpdateType:ks,OnMaterialUpdate:e=>nb(ib.MATERIAL,e),OnObjectUpdate:e=>nb(ib.OBJECT,e),PCFShadowFilter:Jx,PCFSoftShadowFilter:eT,PI:za,PI2:Ha,PointShadowFilter:yT,Return:()=>qu("return").toStack(),Schlick_to_F0:hg,ScriptableNodeResources:ix,ShaderNode:Di,Stack:Yi,Switch:(...e)=>ui.Switch(...e),TBNViewMatrix:yc,VSMShadowFilter:tT,V_GGX_SmithCorrelated:ig,Var:du,VarIntent:hu,abs:co,acesFilmicToneMapping:$b,acos:uo,add:pa,addMethodChaining:di,addNodeElement:function(e){console.warn("THREE.TSL: AddNodeElement has been removed in favor of tree-shaking. Trying add",e)},agxToneMapping:Xb,all:$a,alphaT:Ln,and:Sa,anisotropy:In,anisotropyB:Vn,anisotropyT:Dn,any:Wa,append:e=>(console.warn("THREE.TSL: append() has been renamed to Stack()."),Yi(e)),array:aa,arrayBuffer:e=>Vi(new ai(e,"ArrayBuffer")),asin:oo,assign:ua,atan:lo,atan2:Zo,atomicAdd:(e,t)=>Ax(Ex.ATOMIC_ADD,e,t),atomicAnd:(e,t)=>Ax(Ex.ATOMIC_AND,e,t),atomicFunc:Ax,atomicLoad:e=>Ax(Ex.ATOMIC_LOAD,e,null),atomicMax:(e,t)=>Ax(Ex.ATOMIC_MAX,e,t),atomicMin:(e,t)=>Ax(Ex.ATOMIC_MIN,e,t),atomicOr:(e,t)=>Ax(Ex.ATOMIC_OR,e,t),atomicStore:(e,t)=>Ax(Ex.ATOMIC_STORE,e,t),atomicSub:(e,t)=>Ax(Ex.ATOMIC_SUB,e,t),atomicXor:(e,t)=>Ax(Ex.ATOMIC_XOR,e,t),attenuationColor:Kn,attenuationDistance:Xn,attribute:el,attributeArray:(e,t="float")=>{let r,s;!0===t.isStruct?(r=t.layout.getLength(),s=Cs("float")):(r=Ms(t),s=Cs(t));const i=new ob(e,r,s);return Ch(i,t,e)},backgroundBlurriness:pb,backgroundIntensity:gb,backgroundRotation:mb,batch:Eh,bentNormalView:xc,billboarding:wy,bitAnd:Ra,bitNot:Ca,bitOr:Ma,bitXor:Pa,bitangentGeometry:pc,bitangentLocal:gc,bitangentView:mc,bitangentWorld:fc,bitcast:Eo,blendBurn:gp,blendColor:bp,blendDodge:mp,blendOverlay:yp,blendScreen:fp,blur:hm,bool:tn,buffer:hl,bufferAttribute:Bu,bumpMap:Ec,burn:(...e)=>(console.warn('THREE.TSL: "burn" has been renamed. Use "blendBurn" instead.'),gp(e)),bvec2:an,bvec3:dn,bvec4:gn,bypass:zu,cache:ku,call:da,cameraFar:Ml,cameraIndex:Rl,cameraNear:Cl,cameraNormalMatrix:Il,cameraPosition:Dl,cameraProjectionMatrix:Pl,cameraProjectionMatrixInverse:Bl,cameraViewMatrix:Fl,cameraViewport:Vl,cameraWorldMatrix:Ll,cbrt:ko,cdl:Bb,ceil:to,checker:RT,cineonToneMapping:zb,clamp:Ho,clearcoat:An,clearcoatNormalView:Nd,clearcoatRoughness:Rn,code:Qb,color:Qi,colorSpaceToWorking:Nu,colorToDirection:e=>Vi(e).mul(2).sub(1),compute:Uu,computeKernel:Vu,computeSkinning:(e,t=null)=>{const r=new Ph(e);return r.positionNode=Ch(new F(e.geometry.getAttribute("position").array,3),"vec3").setPBO(!0).toReadOnly().element(mh).toVar(),r.skinIndexNode=Ch(new F(new Uint32Array(e.geometry.getAttribute("skinIndex").array),4),"uvec4").setPBO(!0).toReadOnly().element(mh).toVar(),r.skinWeightNode=Ch(new F(e.geometry.getAttribute("skinWeight").array,4),"vec4").setPBO(!0).toReadOnly().element(mh).toVar(),r.bindMatrixNode=ia(e.bindMatrix,"mat4"),r.bindMatrixInverseNode=ia(e.bindMatrixInverse,"mat4"),r.boneMatricesNode=hl(e.skeleton.boneMatrices,"mat4",e.skeleton.bones.length),r.toPositionNode=t,Vi(r)},context:iu,convert:xn,convertColorSpace:(e,t,r)=>Vi(new _u(Vi(e),t,r)),convertToTexture:(e,...t)=>e.isSampleNode||e.isTextureNode?e:e.isPassNode?e.getTextureNode():Jy(e,...t),cos:no,cross:Lo,cubeTexture:Gd,cubeTextureBase:kd,cubeToUV:mT,dFdx:fo,dFdy:yo,dashSize:zn,debug:Zu,decrement:Va,decrementBefore:Ia,defaultBuildStages:$s,defaultShaderStages:Hs,defined:Li,degrees:qa,deltaTime:vy,densityFog:function(e,t){return console.warn('THREE.TSL: "densityFog( color, density )" is deprecated. Use "fog( color, densityFogFactor( density ) )" instead.'),dx(e,lx(t))},densityFogFactor:lx,depth:np,depthPass:(e,t,r)=>Vi(new Ub(Ub.DEPTH,e,t,r)),determinant:No,difference:Bo,diffuseColor:Nn,directPointLight:wT,directionToColor:Pp,directionToFaceDirection:md,dispersion:Yn,distance:Po,div:fa,dodge:(...e)=>(console.warn('THREE.TSL: "dodge" has been renamed. Use "blendDodge" instead.'),mp(e)),dot:Fo,drawIndex:xh,dynamicBufferAttribute:Fu,element:bn,emissive:Sn,equal:ba,equals:wo,equirectUV:Lp,exp:Xa,exp2:Ka,expression:qu,faceDirection:gd,faceForward:qo,faceforward:Jo,float:Zi,floor:eo,fog:dx,fract:so,frameGroup:ea,frameId:Ny,frontFacing:pd,fwidth:_o,gain:(e,t)=>e.lessThan(.5)?gy(e.mul(2),t).div(2):ga(1,gy(ma(ga(1,e),2),t).div(2)),gapSize:Hn,getConstNodeType:Ii,getCurrentStack:Xi,getDirection:um,getDistanceAttenuation:ET,getGeometryRoughness:rg,getNormalFromDepth:rb,getParallaxCorrectNormal:v_,getRoughness:sg,getScreenPosition:tb,getShIrradianceAt:N_,getShadowMaterial:sT,getShadowRenderObjectFunction:aT,getTextureIndex:dy,getViewPosition:eb,globalId:xx,glsl:(e,t)=>Qb(e,t,"glsl"),glslFn:(e,t)=>Jb(e,t,"glsl"),grayscale:Ab,greaterThan:_a,greaterThanEqual:Na,hash:py,highpModelNormalViewMatrix:id,highpModelViewMatrix:sd,hue:Mb,increment:Da,incrementBefore:La,instance:_h,instanceIndex:mh,instancedArray:(e,t="float")=>{let r,s;!0===t.isStruct?(r=t.layout.getLength(),s=Cs("float")):(r=Ms(t),s=Cs(t));const i=new ab(e,r,s);return Ch(i,t,e)},instancedBufferAttribute:Lu,instancedDynamicBufferAttribute:Iu,instancedMesh:Nh,int:Ji,inverse:So,inverseSqrt:Ja,inversesqrt:eu,invocationLocalIndex:bh,invocationSubgroupIndex:yh,ior:Wn,iridescence:Pn,iridescenceIOR:Bn,iridescenceThickness:Fn,ivec2:sn,ivec3:un,ivec4:hn,js:(e,t)=>Qb(e,t,"js"),label:ou,length:po,lengthSq:Go,lessThan:Ta,lessThanEqual:va,lightPosition:Bx,lightProjectionUV:Px,lightShadowMatrix:Mx,lightTargetDirection:Ix,lightTargetPosition:Fx,lightViewPosition:Lx,lightingContext:$h,lights:(e=[])=>Vi(new Ox).setLights(e),linearDepth:ap,linearToneMapping:kb,localId:Tx,log:Ya,log2:Qa,logarithmicDepthToViewZ:(e,t,r)=>{const s=e.mul(Ya(r.div(t)));return Zi(Math.E).pow(s).mul(t).negate()},luminance:Pb,mat2:mn,mat3:fn,mat4:yn,matcapUV:Jm,materialAO:dh,materialAlphaTest:Rc,materialAnisotropy:qc,materialAnisotropyVector:ch,materialAttenuationColor:th,materialAttenuationDistance:eh,materialClearcoat:Gc,materialClearcoatNormal:Hc,materialClearcoatRoughness:zc,materialColor:Cc,materialDispersion:uh,materialEmissive:Pc,materialEnvIntensity:Bd,materialEnvRotation:Fd,materialIOR:Jc,materialIridescence:Xc,materialIridescenceIOR:Kc,materialIridescenceThickness:Yc,materialLightMap:lh,materialLineDashOffset:ah,materialLineDashSize:sh,materialLineGapSize:ih,materialLineScale:rh,materialLineWidth:nh,materialMetalness:Oc,materialNormal:kc,materialOpacity:Bc,materialPointSize:oh,materialReference:qd,materialReflectivity:Vc,materialRefractionRatio:Pd,materialRotation:$c,materialRoughness:Uc,materialSheen:Wc,materialSheenRoughness:jc,materialShininess:Mc,materialSpecular:Fc,materialSpecularColor:Ic,materialSpecularIntensity:Lc,materialSpecularStrength:Dc,materialThickness:Zc,materialTransmission:Qc,max:Ro,maxMipLevel:nl,mediumpModelViewMatrix:rd,metalness:wn,min:Ao,mix:zo,mixElement:Ko,mod:ya,modInt:Ua,modelDirection:ql,modelNormalMatrix:Jl,modelPosition:Kl,modelRadius:Zl,modelScale:Yl,modelViewMatrix:td,modelViewPosition:Ql,modelViewProjection:hh,modelWorldMatrix:Xl,modelWorldMatrixInverse:ed,morphReference:kh,mrt:hy,mul:ma,mx_aastep:x_,mx_add:(e,t=Zi(0))=>pa(e,t),mx_atan2:(e=Zi(0),t=Zi(1))=>lo(e,t),mx_cell_noise_float:(e=tl())=>t_(e.convert("vec2|vec3")),mx_contrast:(e,t=1,r=.5)=>Zi(e).sub(r).mul(t).add(r),mx_divide:(e,t=Zi(1))=>fa(e,t),mx_fractal_noise_float:(e=tl(),t=3,r=2,s=.5,i=1)=>s_(e,Ji(t),r,s).mul(i),mx_fractal_noise_vec2:(e=tl(),t=3,r=2,s=.5,i=1)=>n_(e,Ji(t),r,s).mul(i),mx_fractal_noise_vec3:(e=tl(),t=3,r=2,s=.5,i=1)=>i_(e,Ji(t),r,s).mul(i),mx_fractal_noise_vec4:(e=tl(),t=3,r=2,s=.5,i=1)=>a_(e,Ji(t),r,s).mul(i),mx_frame:()=>Ny,mx_heighttonormal:(e,t)=>(e=on(e),t=Zi(t),Ec(e,t)),mx_hsvtorgb:f_,mx_ifequal:(e,t,r,s)=>e.equal(t).mix(r,s),mx_ifgreater:(e,t,r,s)=>e.greaterThan(t).mix(r,s),mx_ifgreatereq:(e,t,r,s)=>e.greaterThanEqual(t).mix(r,s),mx_invert:(e,t=Zi(1))=>ga(t,e),mx_modulo:(e,t=Zi(1))=>ya(e,t),mx_multiply:(e,t=Zi(1))=>ma(e,t),mx_noise_float:(e=tl(),t=1,r=0)=>JT(e.convert("vec2|vec3")).mul(t).add(r),mx_noise_vec3:(e=tl(),t=1,r=0)=>e_(e.convert("vec2|vec3")).mul(t).add(r),mx_noise_vec4:(e=tl(),t=1,r=0)=>{e=e.convert("vec2|vec3");return cn(e_(e),JT(e.add(rn(19,73)))).mul(t).add(r)},mx_place2d:(e,t=rn(.5,.5),r=rn(1,1),s=Zi(0),i=rn(0,0))=>{let n=e;if(t&&(n=n.sub(t)),r&&(n=n.mul(r)),s){const e=s.mul(Math.PI/180),t=e.cos(),r=e.sin();n=rn(n.x.mul(t).sub(n.y.mul(r)),n.x.mul(r).add(n.y.mul(t)))}return t&&(n=n.add(t)),i&&(n=n.add(i)),n},mx_power:(e,t=Zi(1))=>Io(e,t),mx_ramp4:(e,t,r,s,i=tl())=>{const n=i.x.clamp(),a=i.y.clamp(),o=zo(e,t,n),u=zo(r,s,n);return zo(o,u,a)},mx_ramplr:(e,t,r=tl())=>T_(e,t,r,"x"),mx_ramptb:(e,t,r=tl())=>T_(e,t,r,"y"),mx_rgbtohsv:y_,mx_rotate2d:(e,t)=>{e=rn(e);const r=(t=Zi(t)).mul(Math.PI/180);return sf(e,r)},mx_rotate3d:(e,t,r)=>{e=on(e),t=Zi(t),r=on(r);const s=t.mul(Math.PI/180),i=r.normalize(),n=s.cos(),a=s.sin(),o=Zi(1).sub(n);return e.mul(n).add(i.cross(e).mul(a)).add(i.mul(i.dot(e)).mul(o))},mx_safepower:(e,t=1)=>(e=Zi(e)).abs().pow(t).mul(e.sign()),mx_separate:(e,t=null)=>{if("string"==typeof t){const r={x:0,r:0,y:1,g:1,z:2,b:2,w:3,a:3},s=t.replace(/^out/,"").toLowerCase();if(void 0!==r[s])return e.element(r[s])}if("number"==typeof t)return e.element(t);if("string"==typeof t&&1===t.length){const r={x:0,r:0,y:1,g:1,z:2,b:2,w:3,a:3};if(void 0!==r[t])return e.element(r[t])}return e},mx_splitlr:(e,t,r,s=tl())=>__(e,t,r,s,"x"),mx_splittb:(e,t,r,s=tl())=>__(e,t,r,s,"y"),mx_srgb_texture_to_lin_rec709:b_,mx_subtract:(e,t=Zi(0))=>ga(e,t),mx_timer:()=>_y,mx_transform_uv:(e=1,t=0,r=tl())=>r.mul(e).add(t),mx_unifiednoise2d:(e,t=tl(),r=rn(1,1),s=rn(0,0),i=1,n=0,a=1,o=!1,u=1,l=2,d=.5)=>g_(e,t.convert("vec2|vec3"),r,s,i,n,a,o,u,l,d),mx_unifiednoise3d:(e,t=tl(),r=rn(1,1),s=rn(0,0),i=1,n=0,a=1,o=!1,u=1,l=2,d=.5)=>m_(e,t.convert("vec2|vec3"),r,s,i,n,a,o,u,l,d),mx_worley_noise_float:(e=tl(),t=1)=>c_(e.convert("vec2|vec3"),t,Ji(1)),mx_worley_noise_vec2:(e=tl(),t=1)=>h_(e.convert("vec2|vec3"),t,Ji(1)),mx_worley_noise_vec3:(e=tl(),t=1)=>p_(e.convert("vec2|vec3"),t,Ji(1)),negate:go,neutralToneMapping:Kb,nodeArray:ki,nodeImmutable:zi,nodeObject:Vi,nodeObjectIntent:Ui,nodeObjects:Oi,nodeProxy:Gi,nodeProxyIntent:Hi,normalFlat:bd,normalGeometry:fd,normalLocal:yd,normalMap:_c,normalView:_d,normalViewGeometry:xd,normalWorld:vd,normalWorldGeometry:Td,normalize:ro,not:wa,notEqual:xa,numWorkgroups:yx,objectDirection:kl,objectGroup:ra,objectPosition:zl,objectRadius:Wl,objectScale:Hl,objectViewPosition:$l,objectWorldMatrix:Gl,oneMinus:mo,or:Ea,orthographicDepthToViewZ:(e,t,r)=>t.sub(r).mul(e).sub(t),oscSawtooth:(e=_y)=>e.fract(),oscSine:(e=_y)=>e.add(.75).mul(2*Math.PI).sin().mul(.5).add(.5),oscSquare:(e=_y)=>e.fract().round(),oscTriangle:(e=_y)=>e.add(.5).fract().mul(2).sub(1).abs(),output:Gn,outputStruct:ly,overlay:(...e)=>(console.warn('THREE.TSL: "overlay" has been renamed. Use "blendOverlay" instead.'),yp(e)),overloadingFn:Ty,parabola:gy,parallaxDirection:bc,parallaxUV:(e,t)=>e.sub(bc.mul(t)),parameter:(e,t)=>Vi(new sy(e,t)),pass:(e,t,r)=>Vi(new Ub(Ub.COLOR,e,t,r)),passTexture:(e,t)=>Vi(new Db(e,t)),pcurve:(e,t,r)=>Io(fa(Io(e,t),pa(Io(e,t),Io(ga(1,e),r))),1/t),perspectiveDepthToViewZ:rp,pmremTexture:Um,pointShadow:NT,pointUV:lb,pointWidth:$n,positionGeometry:nd,positionLocal:ad,positionPrevious:od,positionView:dd,positionViewDirection:cd,positionWorld:ud,positionWorldDirection:ld,posterize:Lb,pow:Io,pow2:Do,pow3:Vo,pow4:Uo,premultiplyAlpha:xp,property:_n,radians:ja,rand:Xo,range:gx,rangeFog:function(e,t,r){return console.warn('THREE.TSL: "rangeFog( color, near, far )" is deprecated. Use "fog( color, rangeFogFactor( near, far ) )" instead.'),dx(e,ux(t,r))},rangeFogFactor:ux,reciprocal:xo,reference:$d,referenceBuffer:Wd,reflect:Mo,reflectVector:Dd,reflectView:Ld,reflector:e=>Vi(new Wy(e)),refract:Wo,refractVector:Vd,refractView:Id,reinhardToneMapping:Gb,remap:$u,remapClamp:Wu,renderGroup:ta,renderOutput:Yu,rendererReference:Au,rotate:sf,rotateUV:Sy,roughness:En,round:bo,rtt:Jy,sRGBTransferEOTF:bu,sRGBTransferOETF:xu,sample:(e,t=null)=>Vi(new sb(e,Vi(t))),sampler:e=>(!0===e.isNode?e:ll(e)).convert("sampler"),samplerComparison:e=>(!0===e.isNode?e:ll(e)).convert("samplerComparison"),saturate:$o,saturation:Rb,screen:(...e)=>(console.warn('THREE.TSL: "screen" has been renamed. Use "blendScreen" instead.'),fp(e)),screenCoordinate:vl,screenSize:_l,screenUV:Tl,scriptable:ax,scriptableValue:tx,select:ru,setCurrentStack:qi,setName:au,shaderStages:Ws,shadow:pT,shadowPositionWorld:Gx,shapeCircle:CT,sharedUniformGroup:Jn,sheen:Cn,sheenRoughness:Mn,shiftLeft:Ba,shiftRight:Fa,shininess:kn,sign:ho,sin:io,sinc:(e,t)=>io(za.mul(t.mul(e).sub(1))).div(za.mul(t.mul(e).sub(1))),skinning:Bh,smoothstep:jo,smoothstepElement:Yo,specularColor:Un,specularF90:On,spherizeUV:Ey,split:(e,t)=>Vi(new ti(Vi(e),t)),spritesheetUV:Cy,sqrt:Za,stack:ny,step:Co,stepElement:Qo,storage:Ch,storageBarrier:()=>vx("storage").toStack(),storageObject:(e,t,r)=>(console.warn('THREE.TSL: "storageObject()" is deprecated. Use "storage().setPBO( true )" instead.'),Ch(e,t,r).setPBO(!0)),storageTexture:yb,string:(e="")=>Vi(new ai(e,"string")),struct:(e,t=null)=>{const r=new ay(e,t),s=(...t)=>{let s=null;if(t.length>0)if(t[0].isNode){s={};const r=Object.keys(e);for(let e=0;evx("texture").toStack(),textureBicubic:Bg,textureBicubicLevel:Pg,textureCubeUV:lm,textureLoad:dl,textureSize:sl,textureStore:(e,t,r)=>{const s=yb(e,t,r);return null!==r&&s.toStack(),s},thickness:qn,time:_y,toneMapping:Cu,toneMappingExposure:Mu,toonOutlinePass:(t,r,s=new e(0,0,0),i=.003,n=1)=>Vi(new Ob(t,r,Vi(s),Vi(i),Vi(n))),transformDirection:Oo,transformNormal:Sd,transformNormalToView:Ed,transformedClearcoatNormalView:Rd,transformedNormalView:wd,transformedNormalWorld:Ad,transmission:jn,transpose:vo,triNoise3D:yy,triplanarTexture:(...e)=>My(...e),triplanarTextures:My,trunc:To,uint:en,uniform:ia,uniformArray:ml,uniformCubeTexture:(e=Ud)=>kd(e),uniformFlow:nu,uniformGroup:Zn,uniformTexture:(e=al)=>ll(e),unpremultiplyAlpha:Tp,userData:(e,t,r)=>Vi(new _b(e,t,r)),uv:tl,uvec2:nn,uvec3:ln,uvec4:pn,varying:fu,varyingProperty:vn,vec2:rn,vec3:on,vec4:cn,vectorComponents:js,velocity:wb,vertexColor:pp,vertexIndex:gh,vertexStage:yu,vibrance:Cb,viewZToLogarithmicDepth:sp,viewZToOrthographicDepth:ep,viewZToPerspectiveDepth:tp,viewport:Nl,viewportCoordinate:El,viewportDepthTexture:Zh,viewportLinearDepth:op,viewportMipTexture:Kh,viewportResolution:Al,viewportSafeUV:Ay,viewportSharedTexture:Rp,viewportSize:Sl,viewportTexture:Xh,viewportUV:wl,wgsl:(e,t)=>Qb(e,t,"wgsl"),wgslFn:(e,t)=>Jb(e,t,"wgsl"),workgroupArray:(e,t)=>Vi(new Sx("Workgroup",e,t)),workgroupBarrier:()=>vx("workgroup").toStack(),workgroupId:bx,workingToColorSpace:vu,xor:Aa});const E_=new ry;class w_ extends Nf{constructor(e,t){super(),this.renderer=e,this.nodes=t}update(e,t,r){const s=this.renderer,i=this.nodes.getBackgroundNode(e)||e.background;let n=!1;if(null===i)s._clearColor.getRGB(E_),E_.a=s._clearColor.a;else if(!0===i.isColor)i.getRGB(E_),E_.a=1,n=!0;else if(!0===i.isNode){const o=this.get(e),u=i;E_.copy(s._clearColor);let l=o.backgroundMesh;if(void 0===l){const c=iu(cn(u).mul(gb),{getUV:()=>mb.mul(Td),getTextureLevel:()=>pb});let h=hh;h=h.setZ(h.w);const p=new _p;function g(){i.removeEventListener("dispose",g),l.material.dispose(),l.geometry.dispose()}p.name="Background.material",p.side=S,p.depthTest=!1,p.depthWrite=!1,p.allowOverride=!1,p.fog=!1,p.lights=!1,p.vertexNode=h,p.colorNode=c,o.backgroundMeshNode=c,o.backgroundMesh=l=new X(new Oe(1,32,32),p),l.frustumCulled=!1,l.name="Background.mesh",l.onBeforeRender=function(e,t,r){this.matrixWorld.copyPosition(r.matrixWorld)},i.addEventListener("dispose",g)}const d=u.getCacheKey();o.backgroundCacheKey!==d&&(o.backgroundMeshNode.node=cn(u).mul(gb),o.backgroundMeshNode.needsUpdate=!0,l.material.needsUpdate=!0,o.backgroundCacheKey=d),t.unshift(l,l.geometry,l.material,0,0,null,null)}else console.error("THREE.Renderer: Unsupported background configuration.",i);const a=s.xr.getEnvironmentBlendMode();if("additive"===a?E_.set(0,0,0,1):"alpha-blend"===a&&E_.set(0,0,0,0),!0===s.autoClear||!0===n){const m=r.clearColorValue;m.r=E_.r,m.g=E_.g,m.b=E_.b,m.a=E_.a,!0!==s.backend.isWebGLBackend&&!0!==s.alpha||(m.r*=m.a,m.g*=m.a,m.b*=m.a),r.depthClearValue=s._clearDepth,r.stencilClearValue=s._clearStencil,r.clearColor=!0===s.autoClearColor,r.clearDepth=!0===s.autoClearDepth,r.clearStencil=!0===s.autoClearStencil}else r.clearColor=!1,r.clearDepth=!1,r.clearStencil=!1}}let A_=0;class R_{constructor(e="",t=[],r=0,s=[]){this.name=e,this.bindings=t,this.index=r,this.bindingsReference=s,this.id=A_++}}class C_{constructor(e,t,r,s,i,n,a,o,u,l=[]){this.vertexShader=e,this.fragmentShader=t,this.computeShader=r,this.transforms=l,this.nodeAttributes=s,this.bindings=i,this.updateNodes=n,this.updateBeforeNodes=a,this.updateAfterNodes=o,this.observer=u,this.usedTimes=0}createBindings(){const e=[];for(const t of this.bindings){if(!0!==t.bindings[0].groupNode.shared){const r=new R_(t.name,[],t.index,t);e.push(r);for(const e of t.bindings)r.bindings.push(e.clone())}else e.push(t)}return e}}class M_{constructor(e,t,r=null){this.isNodeAttribute=!0,this.name=e,this.type=t,this.node=r}}class P_{constructor(e,t,r){this.isNodeUniform=!0,this.name=e,this.type=t,this.node=r.getSelf()}get value(){return this.node.value}set value(e){this.node.value=e}get id(){return this.node.id}get groupNode(){return this.node.groupNode}}class B_{constructor(e,t,r=!1,s=null){this.isNodeVar=!0,this.name=e,this.type=t,this.readOnly=r,this.count=s}}class F_ extends B_{constructor(e,t,r=null,s=null){super(e,t),this.needsInterpolation=!1,this.isNodeVarying=!0,this.interpolationType=r,this.interpolationSampling=s}}class L_{constructor(e,t,r=""){this.name=e,this.type=t,this.code=r,Object.defineProperty(this,"isNodeCode",{value:!0})}}let I_=0;class D_{constructor(e=null){this.id=I_++,this.nodesData=new WeakMap,this.parent=e}getData(e){let t=this.nodesData.get(e);return void 0===t&&null!==this.parent&&(t=this.parent.getData(e)),t}setData(e,t){this.nodesData.set(e,t)}}class V_{constructor(e,t){this.name=e,this.members=t,this.output=!1}}class U_{constructor(e,t){this.name=e,this.value=t,this.boundary=0,this.itemSize=0,this.offset=0}setValue(e){this.value=e}getValue(){return this.value}}class O_ extends U_{constructor(e,t=0){super(e,t),this.isNumberUniform=!0,this.boundary=4,this.itemSize=1}}class k_ extends U_{constructor(e,r=new t){super(e,r),this.isVector2Uniform=!0,this.boundary=8,this.itemSize=2}}class G_ extends U_{constructor(e,t=new r){super(e,t),this.isVector3Uniform=!0,this.boundary=16,this.itemSize=3}}class z_ extends U_{constructor(e,t=new s){super(e,t),this.isVector4Uniform=!0,this.boundary=16,this.itemSize=4}}class H_ extends U_{constructor(t,r=new e){super(t,r),this.isColorUniform=!0,this.boundary=16,this.itemSize=3}}class $_ extends U_{constructor(e,t=new i){super(e,t),this.isMatrix2Uniform=!0,this.boundary=8,this.itemSize=4}}class W_ extends U_{constructor(e,t=new n){super(e,t),this.isMatrix3Uniform=!0,this.boundary=48,this.itemSize=12}}class j_ extends U_{constructor(e,t=new a){super(e,t),this.isMatrix4Uniform=!0,this.boundary=64,this.itemSize=16}}class q_ extends O_{constructor(e){super(e.name,e.value),this.nodeUniform=e}getValue(){return this.nodeUniform.value}getType(){return this.nodeUniform.type}}class X_ extends k_{constructor(e){super(e.name,e.value),this.nodeUniform=e}getValue(){return this.nodeUniform.value}getType(){return this.nodeUniform.type}}class K_ extends G_{constructor(e){super(e.name,e.value),this.nodeUniform=e}getValue(){return this.nodeUniform.value}getType(){return this.nodeUniform.type}}class Y_ extends z_{constructor(e){super(e.name,e.value),this.nodeUniform=e}getValue(){return this.nodeUniform.value}getType(){return this.nodeUniform.type}}class Q_ extends H_{constructor(e){super(e.name,e.value),this.nodeUniform=e}getValue(){return this.nodeUniform.value}getType(){return this.nodeUniform.type}}class Z_ extends $_{constructor(e){super(e.name,e.value),this.nodeUniform=e}getValue(){return this.nodeUniform.value}getType(){return this.nodeUniform.type}}class J_ extends W_{constructor(e){super(e.name,e.value),this.nodeUniform=e}getValue(){return this.nodeUniform.value}getType(){return this.nodeUniform.type}}class ev extends j_{constructor(e){super(e.name,e.value),this.nodeUniform=e}getValue(){return this.nodeUniform.value}getType(){return this.nodeUniform.type}}const tv=new WeakMap,rv=new Map([[Int8Array,"int"],[Int16Array,"int"],[Int32Array,"int"],[Uint8Array,"uint"],[Uint16Array,"uint"],[Uint32Array,"uint"],[Float32Array,"float"]]),sv=e=>/e/g.test(e)?String(e).replace(/\+/g,""):(e=Number(e))+(e%1?"":".0");class iv{constructor(e,t,r){this.object=e,this.material=e&&e.material||null,this.geometry=e&&e.geometry||null,this.renderer=t,this.parser=r,this.scene=null,this.camera=null,this.nodes=[],this.sequentialNodes=[],this.updateNodes=[],this.updateBeforeNodes=[],this.updateAfterNodes=[],this.hashNodes={},this.observer=null,this.lightsNode=null,this.environmentNode=null,this.fogNode=null,this.clippingContext=null,this.vertexShader=null,this.fragmentShader=null,this.computeShader=null,this.flowNodes={vertex:[],fragment:[],compute:[]},this.flowCode={vertex:"",fragment:"",compute:""},this.uniforms={vertex:[],fragment:[],compute:[],index:0},this.structs={vertex:[],fragment:[],compute:[],index:0},this.types={vertex:[],fragment:[],compute:[],index:0},this.bindings={vertex:{},fragment:{},compute:{}},this.bindingsIndexes={},this.bindGroups=null,this.attributes=[],this.bufferAttributes=[],this.varyings=[],this.codes={},this.vars={},this.declarations={},this.flow={code:""},this.chaining=[],this.stack=ny(),this.stacks=[],this.tab="\t",this.currentFunctionNode=null,this.context={material:this.material},this.cache=new D_,this.globalCache=this.cache,this.flowsData=new WeakMap,this.shaderStage=null,this.buildStage=null,this.subBuildLayers=[],this.currentStack=null,this.subBuildFn=null}getBindGroupsCache(){let e=tv.get(this.renderer);return void 0===e&&(e=new bf,tv.set(this.renderer,e)),e}createRenderTarget(e,t,r){return new ue(e,t,r)}createCubeRenderTarget(e,t){return new Ip(e,t)}includes(e){return this.nodes.includes(e)}getOutputStructName(){}_getBindGroup(e,t){const r=this.getBindGroupsCache(),s=[];let i,n=!0;for(const e of t)s.push(e),n=n&&!0!==e.groupNode.shared;return n?(i=r.get(s),void 0===i&&(i=new R_(e,s,this.bindingsIndexes[e].group,s),r.set(s,i))):i=new R_(e,s,this.bindingsIndexes[e].group,s),i}getBindGroupArray(e,t){const r=this.bindings[t];let s=r[e];return void 0===s&&(void 0===this.bindingsIndexes[e]&&(this.bindingsIndexes[e]={binding:0,group:Object.keys(this.bindingsIndexes).length}),r[e]=s=[]),s}getBindings(){let e=this.bindGroups;if(null===e){const t={},r=this.bindings;for(const e of Ws)for(const s in r[e]){const i=r[e][s];(t[s]||(t[s]=[])).push(...i)}e=[];for(const r in t){const s=t[r],i=this._getBindGroup(r,s);e.push(i)}this.bindGroups=e}return e}sortBindingGroups(){const e=this.getBindings();e.sort((e,t)=>e.bindings[0].groupNode.order-t.bindings[0].groupNode.order);for(let t=0;t=0?`${Math.round(n)}u`:"0u";if("bool"===i)return n?"true":"false";if("color"===i)return`${this.getType("vec3")}( ${sv(n.r)}, ${sv(n.g)}, ${sv(n.b)} )`;const a=this.getTypeLength(i),o=this.getComponentType(i),u=e=>this.generateConst(o,e);if(2===a)return`${this.getType(i)}( ${u(n.x)}, ${u(n.y)} )`;if(3===a)return`${this.getType(i)}( ${u(n.x)}, ${u(n.y)}, ${u(n.z)} )`;if(4===a&&"mat2"!==i)return`${this.getType(i)}( ${u(n.x)}, ${u(n.y)}, ${u(n.z)}, ${u(n.w)} )`;if(a>=4&&n&&(n.isMatrix2||n.isMatrix3||n.isMatrix4))return`${this.getType(i)}( ${n.elements.map(u).join(", ")} )`;if(a>4)return`${this.getType(i)}()`;throw new Error(`NodeBuilder: Type '${i}' not found in generate constant attempt.`)}getType(e){return"color"===e?"vec3":e}hasGeometryAttribute(e){return this.geometry&&void 0!==this.geometry.getAttribute(e)}getAttribute(e,t){const r=this.attributes;for(const t of r)if(t.name===e)return t;const s=new M_(e,t);return this.registerDeclaration(s),r.push(s),s}getPropertyName(e){return e.name}isVector(e){return/vec\d/.test(e)}isMatrix(e){return/mat\d/.test(e)}isReference(e){return"void"===e||"property"===e||"sampler"===e||"samplerComparison"===e||"texture"===e||"cubeTexture"===e||"storageTexture"===e||"depthTexture"===e||"texture3D"===e}needsToWorkingColorSpace(){return!1}getComponentTypeFromTexture(e){const t=e.type;if(e.isDataTexture){if(t===_)return"int";if(t===T)return"uint"}return"float"}getElementType(e){return"mat2"===e?"vec2":"mat3"===e?"vec3":"mat4"===e?"vec4":this.getComponentType(e)}getComponentType(e){if("float"===(e=this.getVectorType(e))||"bool"===e||"int"===e||"uint"===e)return e;const t=/(b|i|u|)(vec|mat)([2-4])/.exec(e);return null===t?null:"b"===t[1]?"bool":"i"===t[1]?"int":"u"===t[1]?"uint":"float"}getVectorType(e){return"color"===e?"vec3":"texture"===e||"cubeTexture"===e||"storageTexture"===e||"texture3D"===e?"vec4":e}getTypeFromLength(e,t="float"){if(1===e)return t;let r=Rs(e);const s="float"===t?"":t[0];return!0===/mat2/.test(t)&&(r=r.replace("vec","mat")),s+r}getTypeFromArray(e){return rv.get(e.constructor)}isInteger(e){return/int|uint|(i|u)vec/.test(e)}getTypeFromAttribute(e){let t=e;e.isInterleavedBufferAttribute&&(t=e.data);const r=t.array,s=e.itemSize,i=e.normalized;let n;return e instanceof ze||!0===i||(n=this.getTypeFromArray(r)),this.getTypeFromLength(s,n)}getTypeLength(e){const t=this.getVectorType(e),r=/vec([2-4])/.exec(t);return null!==r?Number(r[1]):"float"===t||"bool"===t||"int"===t||"uint"===t?1:!0===/mat2/.test(e)?4:!0===/mat3/.test(e)?9:!0===/mat4/.test(e)?16:0}getVectorFromMatrix(e){return e.replace("mat","vec")}changeComponentType(e,t){return this.getTypeFromLength(this.getTypeLength(e),t)}getIntegerType(e){const t=this.getComponentType(e);return"int"===t||"uint"===t?e:this.changeComponentType(e,"int")}addStack(){return this.stack=ny(this.stack),this.stacks.push(Xi()||this.stack),qi(this.stack),this.stack}removeStack(){const e=this.stack;return this.stack=e.parent,qi(this.stacks.pop()),e}getDataFromNode(e,t=this.shaderStage,r=null){let s=(r=null===r?e.isGlobal(this)?this.globalCache:this.cache:r).getData(e);void 0===s&&(s={},r.setData(e,s)),void 0===s[t]&&(s[t]={});let i=s[t];const n=s.any?s.any.subBuilds:null,a=this.getClosestSubBuild(n);return a&&(void 0===i.subBuildsCache&&(i.subBuildsCache={}),i=i.subBuildsCache[a]||(i.subBuildsCache[a]={}),i.subBuilds=n),i}getNodeProperties(e,t="any"){const r=this.getDataFromNode(e,t);return r.properties||(r.properties={outputNode:null})}getBufferAttributeFromNode(e,t){const r=this.getDataFromNode(e);let s=r.bufferAttribute;if(void 0===s){const i=this.uniforms.index++;s=new M_("nodeAttribute"+i,t,e),this.bufferAttributes.push(s),r.bufferAttribute=s}return s}getStructTypeNode(e,t=this.shaderStage){return this.types[t][e]||null}getStructTypeFromNode(e,t,r=null,s=this.shaderStage){const i=this.getDataFromNode(e,s,this.globalCache);let n=i.structType;if(void 0===n){const a=this.structs.index++;null===r&&(r="StructType"+a),n=new V_(r,t),this.structs[s].push(n),this.types[s][r]=e,i.structType=n}return n}getOutputStructTypeFromNode(e,t){const r=this.getStructTypeFromNode(e,t,"OutputType","fragment");return r.output=!0,r}getUniformFromNode(e,t,r=this.shaderStage,s=null){const i=this.getDataFromNode(e,r,this.globalCache);let n=i.uniform;if(void 0===n){const a=this.uniforms.index++;n=new P_(s||"nodeUniform"+a,t,e),this.uniforms[r].push(n),this.registerDeclaration(n),i.uniform=n}return n}getVarFromNode(e,t=null,r=e.getNodeType(this),s=this.shaderStage,i=!1){const n=this.getDataFromNode(e,s),a=this.getSubBuildProperty("variable",n.subBuilds);let o=n[a];if(void 0===o){const u=i?"_const":"_var",l=this.vars[s]||(this.vars[s]=[]),d=this.vars[u]||(this.vars[u]=0);null===t&&(t=(i?"nodeConst":"nodeVar")+d,this.vars[u]++),"variable"!==a&&(t=this.getSubBuildProperty(t,n.subBuilds));const c=e.getArrayCount(this);o=new B_(t,r,i,c),i||l.push(o),this.registerDeclaration(o),n[a]=o}return o}isDeterministic(e){if(e.isMathNode)return this.isDeterministic(e.aNode)&&(!e.bNode||this.isDeterministic(e.bNode))&&(!e.cNode||this.isDeterministic(e.cNode));if(e.isOperatorNode)return this.isDeterministic(e.aNode)&&(!e.bNode||this.isDeterministic(e.bNode));if(e.isArrayNode){if(null!==e.values)for(const t of e.values)if(!this.isDeterministic(t))return!1;return!0}return!!e.isConstNode}getVaryingFromNode(e,t=null,r=e.getNodeType(this),s=null,i=null){const n=this.getDataFromNode(e,"any"),a=this.getSubBuildProperty("varying",n.subBuilds);let o=n[a];if(void 0===o){const e=this.varyings,u=e.length;null===t&&(t="nodeVarying"+u),"varying"!==a&&(t=this.getSubBuildProperty(t,n.subBuilds)),o=new F_(t,r,s,i),e.push(o),this.registerDeclaration(o),n[a]=o}return o}registerDeclaration(e){const t=this.shaderStage,r=this.declarations[t]||(this.declarations[t]={}),s=this.getPropertyName(e);let i=1,n=s;for(;void 0!==r[n];)n=s+"_"+i++;i>1&&(e.name=n,console.warn(`THREE.TSL: Declaration name '${s}' of '${e.type}' already in use. Renamed to '${n}'.`)),r[n]=e}getCodeFromNode(e,t,r=this.shaderStage){const s=this.getDataFromNode(e);let i=s.code;if(void 0===i){const e=this.codes[r]||(this.codes[r]=[]),n=e.length;i=new L_("nodeCode"+n,t),e.push(i),s.code=i}return i}addFlowCodeHierarchy(e,t){const{flowCodes:r,flowCodeBlock:s}=this.getDataFromNode(e);let i=!0,n=t;for(;n;){if(!0===s.get(n)){i=!1;break}n=this.getDataFromNode(n).parentNodeBlock}if(i)for(const e of r)this.addLineFlowCode(e)}addLineFlowCodeBlock(e,t,r){const s=this.getDataFromNode(e),i=s.flowCodes||(s.flowCodes=[]),n=s.flowCodeBlock||(s.flowCodeBlock=new WeakMap);i.push(t),n.set(r,!0)}addLineFlowCode(e,t=null){return""===e||(null!==t&&this.context.nodeBlock&&this.addLineFlowCodeBlock(t,e,this.context.nodeBlock),e=this.tab+e,/;\s*$/.test(e)||(e+=";\n"),this.flow.code+=e),this}addFlowCode(e){return this.flow.code+=e,this}addFlowTab(){return this.tab+="\t",this}removeFlowTab(){return this.tab=this.tab.slice(0,-1),this}getFlowData(e){return this.flowsData.get(e)}flowNode(e){const t=e.getNodeType(this),r=this.flowChildNode(e,t);return this.flowsData.set(e,r),r}addInclude(e){null!==this.currentFunctionNode&&this.currentFunctionNode.includes.push(e)}buildFunctionNode(e){const t=new Zb,r=this.currentFunctionNode;return this.currentFunctionNode=t,t.code=this.buildFunctionCode(e),this.currentFunctionNode=r,t}flowShaderNode(e){const t=e.layout,r={[Symbol.iterator](){let e=0;const t=Object.values(this);return{next:()=>({value:t[e],done:e++>=t.length})}}};for(const e of t.inputs)r[e.name]=new sy(e.type,e.name);e.layout=null;const s=e.call(r),i=this.flowStagesNode(s,t.type);return e.layout=t,i}flowBuildStage(e,t,r=null){const s=this.getBuildStage();this.setBuildStage(t);const i=e.build(this,r);return this.setBuildStage(s),i}flowStagesNode(e,t=null){const r=this.flow,s=this.vars,i=this.declarations,n=this.cache,a=this.buildStage,o=this.stack,u={code:""};this.flow=u,this.vars={},this.declarations={},this.cache=new D_,this.stack=ny();for(const r of $s)this.setBuildStage(r),u.result=e.build(this,t);return u.vars=this.getVars(this.shaderStage),this.flow=r,this.vars=s,this.declarations=i,this.cache=n,this.stack=o,this.setBuildStage(a),u}getFunctionOperator(){return null}buildFunctionCode(){console.warn("Abstract function.")}flowChildNode(e,t=null){const r=this.flow,s={code:""};return this.flow=s,s.result=e.build(this,t),this.flow=r,s}flowNodeFromShaderStage(e,t,r=null,s=null){const i=this.tab,n=this.cache,a=this.shaderStage,o=this.context;this.setShaderStage(e);const u={...this.context};delete u.nodeBlock,this.cache=this.globalCache,this.tab="\t",this.context=u;let l=null;if("generate"===this.buildStage){const i=this.flowChildNode(t,r);null!==s&&(i.code+=`${this.tab+s} = ${i.result};\n`),this.flowCode[e]=this.flowCode[e]+i.code,l=i}else l=t.build(this);return this.setShaderStage(a),this.cache=n,this.tab=i,this.context=o,l}getAttributesArray(){return this.attributes.concat(this.bufferAttributes)}getAttributes(){console.warn("Abstract function.")}getVaryings(){console.warn("Abstract function.")}getVar(e,t,r=null){return`${null!==r?this.generateArrayDeclaration(e,r):this.getType(e)} ${t}`}getVars(e){let t="";const r=this.vars[e];if(void 0!==r)for(const e of r)t+=`${this.getVar(e.type,e.name)}; `;return t}getUniforms(){console.warn("Abstract function.")}getCodes(e){const t=this.codes[e];let r="";if(void 0!==t)for(const e of t)r+=e.code+"\n";return r}getHash(){return this.vertexShader+this.fragmentShader+this.computeShader}setShaderStage(e){this.shaderStage=e}getShaderStage(){return this.shaderStage}setBuildStage(e){this.buildStage=e}getBuildStage(){return this.buildStage}buildCode(){console.warn("Abstract function.")}get subBuild(){return this.subBuildLayers[this.subBuildLayers.length-1]||null}addSubBuild(e){this.subBuildLayers.push(e)}removeSubBuild(){return this.subBuildLayers.pop()}getClosestSubBuild(e){let t;if(t=e&&e.isNode?e.isShaderCallNodeInternal?e.shaderNode.subBuilds:e.isStackNode?[e.subBuild]:this.getDataFromNode(e,"any").subBuilds:e instanceof Set?[...e]:e,!t)return null;const r=this.subBuildLayers;for(let e=t.length-1;e>=0;e--){const s=t[e];if(r.includes(s))return s}return null}getSubBuildOutput(e){return this.getSubBuildProperty("outputNode",e)}getSubBuildProperty(e="",t=null){let r,s;return r=null!==t?this.getClosestSubBuild(t):this.subBuildFn,s=r?e?r+"_"+e:r:e,s}build(){const{object:e,material:t,renderer:r}=this;if(null!==t){let e=r.library.fromMaterial(t);null===e&&(console.error(`NodeMaterial: Material "${t.type}" is not compatible.`),e=new _p),e.build(this)}else this.addFlow("compute",e);for(const e of $s){this.setBuildStage(e),this.context.vertex&&this.context.vertex.isNode&&this.flowNodeFromShaderStage("vertex",this.context.vertex);for(const t of Ws){this.setShaderStage(t);const r=this.flowNodes[t];for(const t of r)"generate"===e?this.flowNode(t):t.build(this)}}return this.setBuildStage(null),this.setShaderStage(null),this.buildCode(),this.buildUpdateNodes(),this}getNodeUniform(e,t){if("float"===t||"int"===t||"uint"===t)return new q_(e);if("vec2"===t||"ivec2"===t||"uvec2"===t)return new X_(e);if("vec3"===t||"ivec3"===t||"uvec3"===t)return new K_(e);if("vec4"===t||"ivec4"===t||"uvec4"===t)return new Y_(e);if("color"===t)return new Q_(e);if("mat2"===t)return new Z_(e);if("mat3"===t)return new J_(e);if("mat4"===t)return new ev(e);throw new Error(`Uniform "${t}" not declared.`)}format(e,t,r){if((t=this.getVectorType(t))===(r=this.getVectorType(r))||null===r||this.isReference(r))return e;const s=this.getTypeLength(t),i=this.getTypeLength(r);return 16===s&&9===i?`${this.getType(r)}( ${e}[ 0 ].xyz, ${e}[ 1 ].xyz, ${e}[ 2 ].xyz )`:9===s&&4===i?`${this.getType(r)}( ${e}[ 0 ].xy, ${e}[ 1 ].xy )`:s>4||i>4||0===i?e:s===i?`${this.getType(r)}( ${e} )`:s>i?(e="bool"===r?`all( ${e} )`:`${e}.${"xyz".slice(0,i)}`,this.format(e,this.getTypeFromLength(i,this.getComponentType(t)),r)):4===i&&s>1?`${this.getType(r)}( ${this.format(e,t,"vec3")}, 1.0 )`:2===s?`${this.getType(r)}( ${this.format(e,t,"vec2")}, 0.0 )`:(1===s&&i>1&&t!==this.getComponentType(r)&&(e=`${this.getType(this.getComponentType(r))}( ${e} )`),`${this.getType(r)}( ${e} )`)}getSignature(){return`// Three.js r${He} - Node System\n`}}class nv{constructor(){this.time=0,this.deltaTime=0,this.frameId=0,this.renderId=0,this.updateMap=new WeakMap,this.updateBeforeMap=new WeakMap,this.updateAfterMap=new WeakMap,this.renderer=null,this.material=null,this.camera=null,this.object=null,this.scene=null}_getMaps(e,t){let r=e.get(t);return void 0===r&&(r={renderMap:new WeakMap,frameMap:new WeakMap},e.set(t,r)),r}updateBeforeNode(e){const t=e.getUpdateBeforeType(),r=e.updateReference(this);if(t===ks.FRAME){const{frameMap:t}=this._getMaps(this.updateBeforeMap,r);t.get(r)!==this.frameId&&!1!==e.updateBefore(this)&&t.set(r,this.frameId)}else if(t===ks.RENDER){const{renderMap:t}=this._getMaps(this.updateBeforeMap,r);t.get(r)!==this.renderId&&!1!==e.updateBefore(this)&&t.set(r,this.renderId)}else t===ks.OBJECT&&e.updateBefore(this)}updateAfterNode(e){const t=e.getUpdateAfterType(),r=e.updateReference(this);if(t===ks.FRAME){const{frameMap:t}=this._getMaps(this.updateAfterMap,r);t.get(r)!==this.frameId&&!1!==e.updateAfter(this)&&t.set(r,this.frameId)}else if(t===ks.RENDER){const{renderMap:t}=this._getMaps(this.updateAfterMap,r);t.get(r)!==this.renderId&&!1!==e.updateAfter(this)&&t.set(r,this.renderId)}else t===ks.OBJECT&&e.updateAfter(this)}updateNode(e){const t=e.getUpdateType(),r=e.updateReference(this);if(t===ks.FRAME){const{frameMap:t}=this._getMaps(this.updateMap,r);t.get(r)!==this.frameId&&!1!==e.update(this)&&t.set(r,this.frameId)}else if(t===ks.RENDER){const{renderMap:t}=this._getMaps(this.updateMap,r);t.get(r)!==this.renderId&&!1!==e.update(this)&&t.set(r,this.renderId)}else t===ks.OBJECT&&e.update(this)}update(){this.frameId++,void 0===this.lastTime&&(this.lastTime=performance.now()),this.deltaTime=(performance.now()-this.lastTime)/1e3,this.lastTime=performance.now(),this.time+=this.deltaTime}}class av{constructor(e,t,r=null,s="",i=!1){this.type=e,this.name=t,this.count=r,this.qualifier=s,this.isConst=i}}av.isNodeFunctionInput=!0;class ov extends ST{static get type(){return"DirectionalLightNode"}constructor(e=null){super(e)}setupDirect(){const e=this.colorNode;return{lightDirection:Ix(this.light),lightColor:e}}}const uv=new a,lv=new a;let dv=null;class cv extends ST{static get type(){return"RectAreaLightNode"}constructor(e=null){super(e),this.halfHeight=ia(new r).setGroup(ta),this.halfWidth=ia(new r).setGroup(ta),this.updateType=ks.RENDER}update(e){super.update(e);const{light:t}=this,r=e.camera.matrixWorldInverse;lv.identity(),uv.copy(t.matrixWorld),uv.premultiply(r),lv.extractRotation(uv),this.halfWidth.value.set(.5*t.width,0,0),this.halfHeight.value.set(0,.5*t.height,0),this.halfWidth.value.applyMatrix4(lv),this.halfHeight.value.applyMatrix4(lv)}setupDirectRectArea(e){let t,r;e.isAvailable("float32Filterable")?(t=ll(dv.LTC_FLOAT_1),r=ll(dv.LTC_FLOAT_2)):(t=ll(dv.LTC_HALF_1),r=ll(dv.LTC_HALF_2));const{colorNode:s,light:i}=this;return{lightColor:s,lightPosition:Lx(i),halfWidth:this.halfWidth,halfHeight:this.halfHeight,ltc_1:t,ltc_2:r}}static setLTC(e){dv=e}}class hv extends ST{static get type(){return"SpotLightNode"}constructor(e=null){super(e),this.coneCosNode=ia(0).setGroup(ta),this.penumbraCosNode=ia(0).setGroup(ta),this.cutoffDistanceNode=ia(0).setGroup(ta),this.decayExponentNode=ia(0).setGroup(ta),this.colorNode=ia(this.color).setGroup(ta)}update(e){super.update(e);const{light:t}=this;this.coneCosNode.value=Math.cos(t.angle),this.penumbraCosNode.value=Math.cos(t.angle*(1-t.penumbra)),this.cutoffDistanceNode.value=t.distance,this.decayExponentNode.value=t.decay}getSpotAttenuation(e,t){const{coneCosNode:r,penumbraCosNode:s}=this;return jo(r,s,t)}getLightCoord(e){const t=e.getNodeProperties(this);let r=t.projectionUV;return void 0===r&&(r=Px(this.light,e.context.positionWorld),t.projectionUV=r),r}setupDirect(e){const{colorNode:t,cutoffDistanceNode:r,decayExponentNode:s,light:i}=this,n=this.getLightVector(e),a=n.normalize(),o=a.dot(Ix(i)),u=this.getSpotAttenuation(e,o),l=n.length(),d=ET({lightDistance:l,cutoffDistance:r,decayExponent:s});let c,h,p=t.mul(u).mul(d);if(i.colorNode?(h=this.getLightCoord(e),c=i.colorNode(h)):i.map&&(h=this.getLightCoord(e),c=ll(i.map,h.xy).onRenderUpdate(()=>i.map)),c){p=h.mul(2).sub(1).abs().lessThan(1).all().select(p.mul(c),p)}return{lightColor:p,lightDirection:a}}}class pv extends hv{static get type(){return"IESSpotLightNode"}getSpotAttenuation(e,t){const r=this.light.iesMap;let s=null;if(r&&!0===r.isTexture){const e=t.acos().mul(1/Math.PI);s=ll(r,rn(e,0),0).r}else s=super.getSpotAttenuation(t);return s}}const gv=ji(([e,t])=>{const r=e.abs().sub(t);return po(Ro(r,0)).add(Ao(Ro(r.x,r.y),0))});class mv extends hv{static get type(){return"ProjectorLightNode"}update(e){super.update(e);const t=this.light;if(this.penumbraCosNode.value=Math.min(Math.cos(t.angle*(1-t.penumbra)),.99999),null===t.aspect){let e=1;null!==t.map&&(e=t.map.width/t.map.height),t.shadow.aspect=e}else t.shadow.aspect=t.aspect}getSpotAttenuation(e){const t=Zi(0),r=this.penumbraCosNode,s=Mx(this.light).mul(e.context.positionWorld||ud);return Ki(s.w.greaterThan(0),()=>{const e=s.xyz.div(s.w),i=gv(e.xy.sub(rn(.5)),rn(.5)),n=fa(-1,ga(1,uo(r)).sub(1));t.assign($o(i.mul(-2).mul(n)))}),t}}class fv extends ST{static get type(){return"AmbientLightNode"}constructor(e=null){super(e)}setup({context:e}){e.irradiance.addAssign(this.colorNode)}}class yv extends ST{static get type(){return"HemisphereLightNode"}constructor(t=null){super(t),this.lightPositionNode=Bx(t),this.lightDirectionNode=this.lightPositionNode.normalize(),this.groundColorNode=ia(new e).setGroup(ta)}update(e){const{light:t}=this;super.update(e),this.lightPositionNode.object3d=t,this.groundColorNode.value.copy(t.groundColor).multiplyScalar(t.intensity)}setup(e){const{colorNode:t,groundColorNode:r,lightDirectionNode:s}=this,i=vd.dot(s).mul(.5).add(.5),n=zo(r,t,i);e.context.irradiance.addAssign(n)}}class bv extends ST{static get type(){return"LightProbeNode"}constructor(e=null){super(e);const t=[];for(let e=0;e<9;e++)t.push(new r);this.lightProbe=ml(t)}update(e){const{light:t}=this;super.update(e);for(let e=0;e<9;e++)this.lightProbe.array[e].copy(t.sh.coefficients[e]).multiplyScalar(t.intensity)}setup(e){const t=N_(vd,this.lightProbe);e.context.irradiance.addAssign(t)}}class xv{parseFunction(){console.warn("Abstract function.")}}class Tv{constructor(e,t,r="",s=""){this.type=e,this.inputs=t,this.name=r,this.precision=s}getCode(){console.warn("Abstract function.")}}Tv.isNodeFunction=!0;const _v=/^\s*(highp|mediump|lowp)?\s*([a-z_0-9]+)\s*([a-z_0-9]+)?\s*\(([\s\S]*?)\)/i,vv=/[a-z_0-9]+/gi,Nv="#pragma main";class Sv extends Tv{constructor(e){const{type:t,inputs:r,name:s,precision:i,inputsCode:n,blockCode:a,headerCode:o}=(e=>{const t=(e=e.trim()).indexOf(Nv),r=-1!==t?e.slice(t+12):e,s=r.match(_v);if(null!==s&&5===s.length){const i=s[4],n=[];let a=null;for(;null!==(a=vv.exec(i));)n.push(a);const o=[];let u=0;for(;u0||e.backgroundBlurriness>0&&0===t.backgroundBlurriness;if(t.background!==r||s){const i=this.getCacheNode("background",r,()=>{if(!0===r.isCubeTexture||r.mapping===Z||r.mapping===J||r.mapping===he){if(e.backgroundBlurriness>0||r.mapping===he)return Um(r);{let e;return e=!0===r.isCubeTexture?Gd(r):ll(r),kp(e)}}if(!0===r.isTexture)return ll(r,Tl.flipY()).setUpdateMatrix(!0);!0!==r.isColor&&console.error("WebGPUNodes: Unsupported background configuration.",r)},s);t.backgroundNode=i,t.background=r,t.backgroundBlurriness=e.backgroundBlurriness}}else t.backgroundNode&&(delete t.backgroundNode,delete t.background)}getCacheNode(e,t,r,s=!1){const i=this.cacheLib[e]||(this.cacheLib[e]=new WeakMap);let n=i.get(t);return(void 0===n||s)&&(n=r(),i.set(t,n)),n}updateFog(e){const t=this.get(e),r=e.fog;if(r){if(t.fog!==r){const e=this.getCacheNode("fog",r,()=>{if(r.isFogExp2){const e=$d("color","color",r).setGroup(ta),t=$d("density","float",r).setGroup(ta);return dx(e,lx(t))}if(r.isFog){const e=$d("color","color",r).setGroup(ta),t=$d("near","float",r).setGroup(ta),s=$d("far","float",r).setGroup(ta);return dx(e,ux(t,s))}console.error("THREE.Renderer: Unsupported fog configuration.",r)});t.fogNode=e,t.fog=r}}else delete t.fogNode,delete t.fog}updateEnvironment(e){const t=this.get(e),r=e.environment;if(r){if(t.environment!==r){const e=this.getCacheNode("environment",r,()=>!0===r.isCubeTexture?Gd(r):!0===r.isTexture?ll(r):void console.error("Nodes: Unsupported environment configuration.",r));t.environmentNode=e,t.environment=r}}else t.environmentNode&&(delete t.environmentNode,delete t.environment)}getNodeFrame(e=this.renderer,t=null,r=null,s=null,i=null){const n=this.nodeFrame;return n.renderer=e,n.scene=t,n.object=r,n.camera=s,n.material=i,n}getNodeFrameForRender(e){return this.getNodeFrame(e.renderer,e.scene,e.object,e.camera,e.material)}getOutputCacheKey(){const e=this.renderer;return e.toneMapping+","+e.currentColorSpace+","+e.xr.isPresenting}hasOutputChange(e){return wv.get(e)!==this.getOutputCacheKey()}getOutputNode(e){const t=this.renderer,r=this.getOutputCacheKey(),s=e.isArrayTexture?Tb(e,on(Tl,fl("gl_ViewID_OVR"))).renderOutput(t.toneMapping,t.currentColorSpace):ll(e,Tl).renderOutput(t.toneMapping,t.currentColorSpace);return wv.set(e,r),s}updateBefore(e){const t=e.getNodeBuilderState();for(const r of t.updateBeforeNodes)this.getNodeFrameForRender(e).updateBeforeNode(r)}updateAfter(e){const t=e.getNodeBuilderState();for(const r of t.updateAfterNodes)this.getNodeFrameForRender(e).updateAfterNode(r)}updateForCompute(e){const t=this.getNodeFrame(),r=this.getForCompute(e);for(const e of r.updateNodes)t.updateNode(e)}updateForRender(e){const t=this.getNodeFrameForRender(e),r=e.getNodeBuilderState();for(const e of r.updateNodes)t.updateNode(e)}needsRefresh(e){const t=this.getNodeFrameForRender(e);return e.getMonitor().needsRefresh(e,t)}dispose(){super.dispose(),this.nodeFrame=new nv,this.nodeBuilderCache=new Map,this.cacheLib={}}}const Mv=new Me;class Pv{constructor(e=null){this.version=0,this.clipIntersection=null,this.cacheKey="",this.shadowPass=!1,this.viewNormalMatrix=new n,this.clippingGroupContexts=new WeakMap,this.intersectionPlanes=[],this.unionPlanes=[],this.parentVersion=null,null!==e&&(this.viewNormalMatrix=e.viewNormalMatrix,this.clippingGroupContexts=e.clippingGroupContexts,this.shadowPass=e.shadowPass,this.viewMatrix=e.viewMatrix)}projectPlanes(e,t,r){const s=e.length;for(let i=0;i0,alpha:!0,depth:t.depth,stencil:t.stencil,framebufferScaleFactor:this.getFramebufferScaleFactor()},i=new XRWebGLLayer(e,s,r);this._glBaseLayer=i,e.updateRenderState({baseLayer:i}),t.setPixelRatio(1),t._setXRLayerSize(i.framebufferWidth,i.framebufferHeight),this._xrRenderTarget=new Ov(i.framebufferWidth,i.framebufferHeight,{format:de,type:Ce,colorSpace:t.outputColorSpace,stencilBuffer:t.stencil,resolveDepthBuffer:!1===i.ignoreDepthValues,resolveStencilBuffer:!1===i.ignoreDepthValues}),this._xrRenderTarget._isOpaqueFramebuffer=!0,this._referenceSpace=await e.requestReferenceSpace(this.getReferenceSpaceType())}this.setFoveation(this.getFoveation()),t._animation.setAnimationLoop(this._onAnimationFrame),t._animation.setContext(e),t._animation.start(),this.isPresenting=!0,this.dispatchEvent({type:"sessionstart"})}}updateCamera(e){const t=this._session;if(null===t)return;const r=e.near,s=e.far,i=this._cameraXR,n=this._cameraL,a=this._cameraR;i.near=a.near=n.near=r,i.far=a.far=n.far=s,i.isMultiViewCamera=this._useMultiview,this._currentDepthNear===i.near&&this._currentDepthFar===i.far||(t.updateRenderState({depthNear:i.near,depthFar:i.far}),this._currentDepthNear=i.near,this._currentDepthFar=i.far),i.layers.mask=6|e.layers.mask,n.layers.mask=3&i.layers.mask,a.layers.mask=5&i.layers.mask;const o=e.parent,u=i.cameras;Hv(i,o);for(let e=0;e=0&&(r[n]=null,t[n].disconnect(i))}for(let s=0;s=r.length){r.push(i),n=e;break}if(null===r[e]){r[e]=i,n=e;break}}if(-1===n)break}const a=t[n];a&&a.connect(i)}}function qv(e){return"quad"===e.type?this._glBinding.createQuadLayer({transform:new XRRigidTransform(e.translation,e.quaternion),width:e.width/2,height:e.height/2,space:this._referenceSpace,viewPixelWidth:e.pixelwidth,viewPixelHeight:e.pixelheight,clearOnAccess:!1}):this._glBinding.createCylinderLayer({transform:new XRRigidTransform(e.translation,e.quaternion),radius:e.radius,centralAngle:e.centralAngle,aspectRatio:e.aspectRatio,space:this._referenceSpace,viewPixelWidth:e.pixelwidth,viewPixelHeight:e.pixelheight,clearOnAccess:!1})}function Xv(e,t){if(void 0===t)return;const r=this._cameraXR,i=this._renderer,n=i.backend,a=this._glBaseLayer,o=this.getReferenceSpace(),u=t.getViewerPose(o);if(this._xrFrame=t,null!==u){const e=u.views;null!==this._glBaseLayer&&n.setXRTarget(a.framebuffer);let t=!1;e.length!==r.cameras.length&&(r.cameras.length=0,t=!0);for(let i=0;i{await this.compileAsync(e,t);const s=this._renderLists.get(e,t),i=this._renderContexts.get(e,t,this._renderTarget),n=e.overrideMaterial||r.material,a=this._objects.get(r,n,e,t,s.lightsNode,i,i.clippingContext),{fragmentShader:o,vertexShader:u}=a.getNodeBuilderState();return{fragmentShader:o,vertexShader:u}}}}async init(){if(this._initialized)throw new Error("Renderer: Backend has already been initialized.");return null!==this._initPromise||(this._initPromise=new Promise(async(e,t)=>{let r=this.backend;try{await r.init(this)}catch(e){if(null===this._getFallback)return void t(e);try{this.backend=r=this._getFallback(e),await r.init(this)}catch(e){return void t(e)}}this._nodes=new Cv(this,r),this._animation=new yf(this._nodes,this.info),this._attributes=new Cf(r),this._background=new w_(this,this._nodes),this._geometries=new Bf(this._attributes,this.info),this._textures=new ty(this,r,this.info),this._pipelines=new Of(r,this._nodes),this._bindings=new kf(r,this._nodes,this._textures,this._attributes,this._pipelines,this.info),this._objects=new vf(this,this._nodes,this._geometries,this._pipelines,this._bindings,this.info),this._renderLists=new jf(this.lighting),this._bundles=new Lv,this._renderContexts=new Jf,this._animation.start(),this._initialized=!0,e(this)})),this._initPromise}get coordinateSystem(){return this.backend.coordinateSystem}async compileAsync(e,t,r=null){if(!0===this._isDeviceLost)return;!1===this._initialized&&await this.init();const s=this._nodes.nodeFrame,i=s.renderId,n=this._currentRenderContext,a=this._currentRenderObjectFunction,o=this._compilationPromises,u=!0===e.isScene?e:Kv;null===r&&(r=e);const l=this._renderTarget,d=this._renderContexts.get(r,t,l),c=this._activeMipmapLevel,h=[];this._currentRenderContext=d,this._currentRenderObjectFunction=this.renderObject,this._handleObjectFunction=this._createObjectPipeline,this._compilationPromises=h,s.renderId++,s.update(),d.depth=this.depth,d.stencil=this.stencil,d.clippingContext||(d.clippingContext=new Pv),d.clippingContext.updateGlobal(u,t),u.onBeforeRender(this,e,t,l);const p=this._renderLists.get(e,t);if(p.begin(),this._projectObject(e,t,0,p,d.clippingContext),r!==e&&r.traverseVisible(function(e){e.isLight&&e.layers.test(t.layers)&&p.pushLight(e)}),p.finish(),null!==l){this._textures.updateRenderTarget(l,c);const e=this._textures.get(l);d.textures=e.textures,d.depthTexture=e.depthTexture}else d.textures=null,d.depthTexture=null;this._background.update(u,p,d);const g=p.opaque,m=p.transparent,f=p.transparentDoublePass,y=p.lightsNode;!0===this.opaque&&g.length>0&&this._renderObjects(g,t,u,y),!0===this.transparent&&m.length>0&&this._renderTransparents(m,f,t,u,y),s.renderId=i,this._currentRenderContext=n,this._currentRenderObjectFunction=a,this._compilationPromises=o,this._handleObjectFunction=this._renderObjectDirect,await Promise.all(h)}async renderAsync(e,t){!1===this._initialized&&await this.init(),this._renderScene(e,t)}async waitForGPU(){await this.backend.waitForGPU()}set highPrecision(e){!0===e?(this.overrideNodes.modelViewMatrix=sd,this.overrideNodes.modelNormalViewMatrix=id):this.highPrecision&&(this.overrideNodes.modelViewMatrix=null,this.overrideNodes.modelNormalViewMatrix=null)}get highPrecision(){return this.overrideNodes.modelViewMatrix===sd&&this.overrideNodes.modelNormalViewMatrix===id}setMRT(e){return this._mrt=e,this}getMRT(){return this._mrt}getColorBufferType(){return this._colorBufferType}_onDeviceLost(e){let t=`THREE.WebGPURenderer: ${e.api} Device Lost:\n\nMessage: ${e.message}`;e.reason&&(t+=`\nReason: ${e.reason}`),console.error(t),this._isDeviceLost=!0}_renderBundle(e,t,r){const{bundleGroup:s,camera:i,renderList:n}=e,a=this._currentRenderContext,o=this._bundles.get(s,i),u=this.backend.get(o);void 0===u.renderContexts&&(u.renderContexts=new Set);const l=s.version!==u.version,d=!1===u.renderContexts.has(a)||l;if(u.renderContexts.add(a),d){this.backend.beginBundle(a),(void 0===u.renderObjects||l)&&(u.renderObjects=[]),this._currentRenderBundle=o;const{transparentDoublePass:e,transparent:d,opaque:c}=n;!0===this.opaque&&c.length>0&&this._renderObjects(c,i,t,r),!0===this.transparent&&d.length>0&&this._renderTransparents(d,e,i,t,r),this._currentRenderBundle=null,this.backend.finishBundle(a,o),u.version=s.version}else{const{renderObjects:e}=u;for(let t=0,r=e.length;t>=c,p.viewportValue.height>>=c,p.viewportValue.minDepth=x,p.viewportValue.maxDepth=T,p.viewport=!1===p.viewportValue.equals(Qv),p.scissorValue.copy(y).multiplyScalar(b).floor(),p.scissor=this._scissorTest&&!1===p.scissorValue.equals(Qv),p.scissorValue.width>>=c,p.scissorValue.height>>=c,p.clippingContext||(p.clippingContext=new Pv),p.clippingContext.updateGlobal(u,t),u.onBeforeRender(this,e,t,h);const _=t.isArrayCamera?Jv:Zv;t.isArrayCamera||(eN.multiplyMatrices(t.projectionMatrix,t.matrixWorldInverse),_.setFromProjectionMatrix(eN,t.coordinateSystem,t.reversedDepth));const v=this._renderLists.get(e,t);if(v.begin(),this._projectObject(e,t,0,v,p.clippingContext),v.finish(),!0===this.sortObjects&&v.sort(this._opaqueSort,this._transparentSort),null!==h){this._textures.updateRenderTarget(h,c);const e=this._textures.get(h);p.textures=e.textures,p.depthTexture=e.depthTexture,p.width=e.width,p.height=e.height,p.renderTarget=h,p.depth=h.depthBuffer,p.stencil=h.stencilBuffer}else p.textures=null,p.depthTexture=null,p.width=this.domElement.width,p.height=this.domElement.height,p.depth=this.depth,p.stencil=this.stencil;p.width>>=c,p.height>>=c,p.activeCubeFace=d,p.activeMipmapLevel=c,p.occlusionQueryCount=v.occlusionQueryCount,this._background.update(u,v,p),p.camera=t,this.backend.beginRender(p);const{bundles:N,lightsNode:S,transparentDoublePass:E,transparent:w,opaque:A}=v;return N.length>0&&this._renderBundles(N,u,S),!0===this.opaque&&A.length>0&&this._renderObjects(A,t,u,S),!0===this.transparent&&w.length>0&&this._renderTransparents(w,E,t,u,S),this.backend.finishRender(p),i.renderId=n,this._currentRenderContext=a,this._currentRenderObjectFunction=o,null!==s&&(this.setRenderTarget(l,d,c),this._renderOutput(h)),u.onAfterRender(this,e,t,h),p}_setXRLayerSize(e,t){this._width=e,this._height=t,this.setViewport(0,0,e,t)}_renderOutput(e){const t=this._quad;this._nodes.hasOutputChange(e.texture)&&(t.material.fragmentNode=this._nodes.getOutputNode(e.texture),t.material.needsUpdate=!0);const r=this.autoClear,s=this.xr.enabled;this.autoClear=!1,this.xr.enabled=!1,this._renderScene(t,t.camera,!1),this.autoClear=r,this.xr.enabled=s}getMaxAnisotropy(){return this.backend.getMaxAnisotropy()}getActiveCubeFace(){return this._activeCubeFace}getActiveMipmapLevel(){return this._activeMipmapLevel}async setAnimationLoop(e){!1===this._initialized&&await this.init(),this._animation.setAnimationLoop(e)}async getArrayBufferAsync(e){return await this.backend.getArrayBufferAsync(e)}getContext(){return this.backend.getContext()}getPixelRatio(){return this._pixelRatio}getDrawingBufferSize(e){return e.set(this._width*this._pixelRatio,this._height*this._pixelRatio).floor()}getSize(e){return e.set(this._width,this._height)}setPixelRatio(e=1){this._pixelRatio!==e&&(this._pixelRatio=e,this.setSize(this._width,this._height,!1))}setDrawingBufferSize(e,t,r){this.xr&&this.xr.isPresenting||(this._width=e,this._height=t,this._pixelRatio=r,this.domElement.width=Math.floor(e*r),this.domElement.height=Math.floor(t*r),this.setViewport(0,0,e,t),this._initialized&&this.backend.updateSize())}setSize(e,t,r=!0){this.xr&&this.xr.isPresenting||(this._width=e,this._height=t,this.domElement.width=Math.floor(e*this._pixelRatio),this.domElement.height=Math.floor(t*this._pixelRatio),!0===r&&(this.domElement.style.width=e+"px",this.domElement.style.height=t+"px"),this.setViewport(0,0,e,t),this._initialized&&this.backend.updateSize())}setOpaqueSort(e){this._opaqueSort=e}setTransparentSort(e){this._transparentSort=e}getScissor(e){const t=this._scissor;return e.x=t.x,e.y=t.y,e.width=t.width,e.height=t.height,e}setScissor(e,t,r,s){const i=this._scissor;e.isVector4?i.copy(e):i.set(e,t,r,s)}getScissorTest(){return this._scissorTest}setScissorTest(e){this._scissorTest=e,this.backend.setScissorTest(e)}getViewport(e){return e.copy(this._viewport)}setViewport(e,t,r,s,i=0,n=1){const a=this._viewport;e.isVector4?a.copy(e):a.set(e,t,r,s),a.minDepth=i,a.maxDepth=n}getClearColor(e){return e.copy(this._clearColor)}setClearColor(e,t=1){this._clearColor.set(e),this._clearColor.a=t}getClearAlpha(){return this._clearColor.a}setClearAlpha(e){this._clearColor.a=e}getClearDepth(){return this._clearDepth}setClearDepth(e){this._clearDepth=e}getClearStencil(){return this._clearStencil}setClearStencil(e){this._clearStencil=e}isOccluded(e){const t=this._currentRenderContext;return t&&this.backend.isOccluded(t,e)}clear(e=!0,t=!0,r=!0){if(!1===this._initialized)return console.warn("THREE.Renderer: .clear() called before the backend is initialized. Try using .clearAsync() instead."),this.clearAsync(e,t,r);const s=this._renderTarget||this._getFrameBufferTarget();let i=null;if(null!==s){this._textures.updateRenderTarget(s);const e=this._textures.get(s);i=this._renderContexts.getForClear(s),i.textures=e.textures,i.depthTexture=e.depthTexture,i.width=e.width,i.height=e.height,i.renderTarget=s,i.depth=s.depthBuffer,i.stencil=s.stencilBuffer,i.clearColorValue=this.backend.getClearColor(),i.activeCubeFace=this.getActiveCubeFace(),i.activeMipmapLevel=this.getActiveMipmapLevel()}this.backend.clear(e,t,r,i),null!==s&&null===this._renderTarget&&this._renderOutput(s)}clearColor(){return this.clear(!0,!1,!1)}clearDepth(){return this.clear(!1,!0,!1)}clearStencil(){return this.clear(!1,!1,!0)}async clearAsync(e=!0,t=!0,r=!0){!1===this._initialized&&await this.init(),this.clear(e,t,r)}async clearColorAsync(){this.clearAsync(!0,!1,!1)}async clearDepthAsync(){this.clearAsync(!1,!0,!1)}async clearStencilAsync(){this.clearAsync(!1,!1,!0)}get currentToneMapping(){return this.isOutputTarget?this.toneMapping:p}get currentColorSpace(){return this.isOutputTarget?this.outputColorSpace:c.workingColorSpace}get isOutputTarget(){return this._renderTarget===this._outputRenderTarget||null===this._renderTarget}dispose(){this.info.dispose(),this.backend.dispose(),this._animation.dispose(),this._objects.dispose(),this._pipelines.dispose(),this._nodes.dispose(),this._bindings.dispose(),this._renderLists.dispose(),this._renderContexts.dispose(),this._textures.dispose(),null!==this._frameBufferTarget&&this._frameBufferTarget.dispose(),Object.values(this.backend.timestampQueryPool).forEach(e=>{null!==e&&e.dispose()}),this.setRenderTarget(null),this.setAnimationLoop(null)}setRenderTarget(e,t=0,r=0){this._renderTarget=e,this._activeCubeFace=t,this._activeMipmapLevel=r}getRenderTarget(){return this._renderTarget}setOutputRenderTarget(e){this._outputRenderTarget=e}getOutputRenderTarget(){return this._outputRenderTarget}_resetXRState(){this.backend.setXRTarget(null),this.setOutputRenderTarget(null),this.setRenderTarget(null),this._frameBufferTarget.dispose(),this._frameBufferTarget=null}setRenderObjectFunction(e){this._renderObjectFunction=e}getRenderObjectFunction(){return this._renderObjectFunction}compute(e,t=null){if(!0===this._isDeviceLost)return;if(!1===this._initialized)return console.warn("THREE.Renderer: .compute() called before the backend is initialized. Try using .computeAsync() instead."),this.computeAsync(e);const r=this._nodes.nodeFrame,s=r.renderId;this.info.calls++,this.info.compute.calls++,this.info.compute.frameCalls++,r.renderId=this.info.calls;const i=this.backend,n=this._pipelines,a=this._bindings,o=this._nodes,u=Array.isArray(e)?e:[e];if(void 0===u[0]||!0!==u[0].isComputeNode)throw new Error("THREE.Renderer: .compute() expects a ComputeNode.");i.beginCompute(e);for(const r of u){if(!1===n.has(r)){const e=()=>{r.removeEventListener("dispose",e),n.delete(r),a.delete(r),o.delete(r)};r.addEventListener("dispose",e);const t=r.onInitFunction;null!==t&&t.call(r,{renderer:this})}o.updateForCompute(r),a.updateForCompute(r);const s=a.getForCompute(r),u=n.getForCompute(r,s);i.compute(e,r,s,u,t)}i.finishCompute(e),r.renderId=s}async computeAsync(e,t=null){!1===this._initialized&&await this.init(),this.compute(e,t)}async hasFeatureAsync(e){return!1===this._initialized&&await this.init(),this.backend.hasFeature(e)}async resolveTimestampsAsync(e="render"){return!1===this._initialized&&await this.init(),this.backend.resolveTimestampsAsync(e)}hasFeature(e){return!1===this._initialized?(console.warn("THREE.Renderer: .hasFeature() called before the backend is initialized. Try using .hasFeatureAsync() instead."),!1):this.backend.hasFeature(e)}hasInitialized(){return this._initialized}async initTextureAsync(e){!1===this._initialized&&await this.init(),this._textures.updateTexture(e)}initTexture(e){!1===this._initialized&&console.warn("THREE.Renderer: .initTexture() called before the backend is initialized. Try using .initTextureAsync() instead."),this._textures.updateTexture(e)}copyFramebufferToTexture(e,t=null){if(null!==t)if(t.isVector2)t=tN.set(t.x,t.y,e.image.width,e.image.height).floor();else{if(!t.isVector4)return void console.error("THREE.Renderer.copyFramebufferToTexture: Invalid rectangle.");t=tN.copy(t).floor()}else t=tN.set(0,0,e.image.width,e.image.height);let r,s=this._currentRenderContext;null!==s?r=s.renderTarget:(r=this._renderTarget||this._getFrameBufferTarget(),null!==r&&(this._textures.updateRenderTarget(r),s=this._textures.get(r))),this._textures.updateTexture(e,{renderTarget:r}),this.backend.copyFramebufferToTexture(e,s,t)}copyTextureToTexture(e,t,r=null,s=null,i=0,n=0){this._textures.updateTexture(e),this._textures.updateTexture(t),this.backend.copyTextureToTexture(e,t,r,s,i,n)}async readRenderTargetPixelsAsync(e,t,r,s,i,n=0,a=0){return this.backend.copyTextureToBuffer(e.textures[n],t,r,s,i,a)}_projectObject(e,t,r,s,i){if(!1===e.visible)return;if(e.layers.test(t.layers))if(e.isGroup)r=e.renderOrder,e.isClippingGroup&&e.enabled&&(i=i.getGroupContext(e));else if(e.isLOD)!0===e.autoUpdate&&e.update(t);else if(e.isLight)s.pushLight(e);else if(e.isSprite){const n=t.isArrayCamera?Jv:Zv;if(!e.frustumCulled||n.intersectsSprite(e,t)){!0===this.sortObjects&&tN.setFromMatrixPosition(e.matrixWorld).applyMatrix4(eN);const{geometry:t,material:n}=e;n.visible&&s.push(e,t,n,r,tN.z,null,i)}}else if(e.isLineLoop)console.error("THREE.Renderer: Objects of type THREE.LineLoop are not supported. Please use THREE.Line or THREE.LineSegments.");else if(e.isMesh||e.isLine||e.isPoints){const n=t.isArrayCamera?Jv:Zv;if(!e.frustumCulled||n.intersectsObject(e,t)){const{geometry:t,material:n}=e;if(!0===this.sortObjects&&(null===t.boundingSphere&&t.computeBoundingSphere(),tN.copy(t.boundingSphere.center).applyMatrix4(e.matrixWorld).applyMatrix4(eN)),Array.isArray(n)){const a=t.groups;for(let o=0,u=a.length;o0){for(const{material:e}of t)e.side=S;this._renderObjects(t,r,s,i,"backSide");for(const{material:e}of t)e.side=je;this._renderObjects(e,r,s,i);for(const{material:e}of t)e.side=E}else this._renderObjects(e,r,s,i)}_renderObjects(e,t,r,s,i=null){for(let n=0,a=e.length;n0,e.isShadowPassMaterial&&(e.side=null===i.shadowSide?i.side:i.shadowSide,i.depthNode&&i.depthNode.isNode&&(c=e.depthNode,e.depthNode=i.depthNode),i.castShadowNode&&i.castShadowNode.isNode&&(d=e.colorNode,e.colorNode=i.castShadowNode),i.castShadowPositionNode&&i.castShadowPositionNode.isNode&&(l=e.positionNode,e.positionNode=i.castShadowPositionNode)),i=e}!0===i.transparent&&i.side===E&&!1===i.forceSinglePass?(i.side=S,this._handleObjectFunction(e,i,t,r,a,n,o,"backSide"),i.side=je,this._handleObjectFunction(e,i,t,r,a,n,o,u),i.side=E):this._handleObjectFunction(e,i,t,r,a,n,o,u),void 0!==l&&(t.overrideMaterial.positionNode=l),void 0!==c&&(t.overrideMaterial.depthNode=c),void 0!==d&&(t.overrideMaterial.colorNode=d),e.onAfterRender(this,t,r,s,i,n)}_renderObjectDirect(e,t,r,s,i,n,a,o){const u=this._objects.get(e,t,r,s,i,this._currentRenderContext,a,o);u.drawRange=e.geometry.drawRange,u.group=n;const l=this._nodes.needsRefresh(u);if(l&&(this._nodes.updateBefore(u),this._geometries.updateForRender(u),this._nodes.updateForRender(u),this._bindings.updateForRender(u)),this._pipelines.updateForRender(u),null!==this._currentRenderBundle){this.backend.get(this._currentRenderBundle).renderObjects.push(u),u.bundle=this._currentRenderBundle.bundleGroup}this.backend.draw(u,this.info),l&&this._nodes.updateAfter(u)}_createObjectPipeline(e,t,r,s,i,n,a,o){const u=this._objects.get(e,t,r,s,i,this._currentRenderContext,a,o);u.drawRange=e.geometry.drawRange,u.group=n,this._nodes.updateBefore(u),this._geometries.updateForRender(u),this._nodes.updateForRender(u),this._bindings.updateForRender(u),this._pipelines.getForRender(u,this._compilationPromises),this._nodes.updateAfter(u)}get compile(){return this.compileAsync}}class sN{constructor(e=""){this.name=e,this.visibility=0}setVisibility(e){this.visibility|=e}clone(){return Object.assign(new this.constructor,this)}}class iN extends sN{constructor(e,t=null){super(e),this.isBuffer=!0,this.bytesPerElement=Float32Array.BYTES_PER_ELEMENT,this._buffer=t}get byteLength(){return(e=this._buffer.byteLength)+(Rf-e%Rf)%Rf;var e}get buffer(){return this._buffer}update(){return!0}}class nN extends iN{constructor(e,t=null){super(e,t),this.isUniformBuffer=!0}}let aN=0;class oN extends nN{constructor(e,t){super("UniformBuffer_"+aN++,e?e.value:null),this.nodeUniform=e,this.groupNode=t}get buffer(){return this.nodeUniform.value}}class uN extends nN{constructor(e){super(e),this.isUniformsGroup=!0,this._values=null,this.uniforms=[]}addUniform(e){return this.uniforms.push(e),this}removeUniform(e){const t=this.uniforms.indexOf(e);return-1!==t&&this.uniforms.splice(t,1),this}get values(){return null===this._values&&(this._values=Array.from(this.buffer)),this._values}get buffer(){let e=this._buffer;if(null===e){const t=this.byteLength;e=new Float32Array(new ArrayBuffer(t)),this._buffer=e}return e}get byteLength(){const e=this.bytesPerElement;let t=0;for(let r=0,s=this.uniforms.length;r{this.texture=null},this.texture=t,this.version=t?t.version:0,this.generation=null,this.isSampler=!0}set texture(e){this._texture!==e&&(this._texture&&this._texture.removeEventListener("dispose",this._onDisposeTexture),this._texture=e,this.generation=null,this.version=0,this._texture&&this._texture.addEventListener("dispose",this._onDisposeTexture))}get texture(){return this._texture}update(){const{texture:e,version:t}=this;return t!==e.version&&(this.version=e.version,!0)}}let hN=0;class pN extends cN{constructor(e,t){super(e,t),this.id=hN++,this.store=!1,this.isSampledTexture=!0}}class gN extends pN{constructor(e,t,r,s=null){super(e,t?t.value:null),this.textureNode=t,this.groupNode=r,this.access=s}update(){const{textureNode:e}=this;return this.texture!==e.value?(this.texture=e.value,!0):super.update()}}class mN extends gN{constructor(e,t,r,s=null){super(e,t,r,s),this.isSampledCubeTexture=!0}}class fN extends gN{constructor(e,t,r,s=null){super(e,t,r,s),this.isSampledTexture3D=!0}}const yN={textureDimensions:"textureSize",equals:"equal"},bN={low:"lowp",medium:"mediump",high:"highp"},xN={swizzleAssign:!0,storageBuffer:!1},TN={perspective:"smooth",linear:"noperspective"},_N={centroid:"centroid"},vN="\nprecision highp float;\nprecision highp int;\nprecision highp sampler2D;\nprecision highp sampler3D;\nprecision highp samplerCube;\nprecision highp sampler2DArray;\n\nprecision highp usampler2D;\nprecision highp usampler3D;\nprecision highp usamplerCube;\nprecision highp usampler2DArray;\n\nprecision highp isampler2D;\nprecision highp isampler3D;\nprecision highp isamplerCube;\nprecision highp isampler2DArray;\n\nprecision lowp sampler2DShadow;\nprecision lowp sampler2DArrayShadow;\nprecision lowp samplerCubeShadow;\n";class NN extends iv{constructor(e,t){super(e,t,new Ev),this.uniformGroups={},this.transforms=[],this.extensions={},this.builtins={vertex:[],fragment:[],compute:[]}}needsToWorkingColorSpace(e){return!0===e.isVideoTexture&&e.colorSpace!==b}getMethod(e){return yN[e]||e}getTernary(e,t,r){return`${e} ? ${t} : ${r}`}getOutputStructName(){return""}buildFunctionCode(e){const t=e.layout,r=this.flowShaderNode(e),s=[];for(const e of t.inputs)s.push(this.getType(e.type)+" "+e.name);return`${this.getType(t.type)} ${t.name}( ${s.join(", ")} ) {\n\n\t${r.vars}\n\n${r.code}\n\treturn ${r.result};\n\n}`}setupPBO(e){const t=e.value;if(void 0===t.pbo){const e=t.array,r=t.count*t.itemSize,{itemSize:s}=t,i=t.array.constructor.name.toLowerCase().includes("int");let n=i?it:nt;2===s?n=i?lt:Ve:3===s?n=i?dt:ct:4===s&&(n=i?ht:de);const a={Float32Array:I,Uint8Array:Ce,Uint16Array:ut,Uint32Array:T,Int8Array:ot,Int16Array:at,Int32Array:_,Uint8ClampedArray:Ce},o=Math.pow(2,Math.ceil(Math.log2(Math.sqrt(r/s))));let u=Math.ceil(r/s/o);o*u*s0?s:"";t=`${e.name} {\n\t${r} ${i.name}[${n}];\n};\n`}else{t=`${this.getVectorType(i.type)} ${this.getPropertyName(i,e)};`,n=!0}const a=i.node.precision;if(null!==a&&(t=bN[a]+" "+t),n){t="\t"+t;const e=i.groupNode.name;(s[e]||(s[e]=[])).push(t)}else t="uniform "+t,r.push(t)}let i="";for(const t in s){const r=s[t];i+=this._getGLSLUniformStruct(e+"_"+t,r.join("\n"))+"\n"}return i+=r.join("\n"),i}getTypeFromAttribute(e){let t=super.getTypeFromAttribute(e);if(/^[iu]/.test(t)&&e.gpuType!==_){let r=e;e.isInterleavedBufferAttribute&&(r=e.data);const s=r.array;!1==(s instanceof Uint32Array||s instanceof Int32Array)&&(t=t.slice(1))}return t}getAttributes(e){let t="";if("vertex"===e||"compute"===e){const e=this.getAttributesArray();let r=0;for(const s of e)t+=`layout( location = ${r++} ) in ${s.type} ${s.name};\n`}return t}getStructMembers(e){const t=[];for(const r of e.members)t.push(`\t${r.type} ${r.name};`);return t.join("\n")}getStructs(e){const t=[],r=this.structs[e],s=[];for(const e of r)if(e.output)for(const t of e.members)s.push(`layout( location = ${t.index} ) out ${t.type} ${t.name};`);else{let r="struct "+e.name+" {\n";r+=this.getStructMembers(e),r+="\n};\n",t.push(r)}return 0===s.length&&s.push("layout( location = 0 ) out vec4 fragColor;"),"\n"+s.join("\n")+"\n\n"+t.join("\n")}getVaryings(e){let t="";const r=this.varyings;if("vertex"===e||"compute"===e)for(const s of r){"compute"===e&&(s.needsInterpolation=!0);const r=this.getType(s.type);if(s.needsInterpolation)if(s.interpolationType){t+=`${TN[s.interpolationType]||s.interpolationType} ${_N[s.interpolationSampling]||""} out ${r} ${s.name};\n`}else{t+=`${r.includes("int")||r.includes("uv")||r.includes("iv")?"flat ":""}out ${r} ${s.name};\n`}else t+=`${r} ${s.name};\n`}else if("fragment"===e)for(const e of r)if(e.needsInterpolation){const r=this.getType(e.type);if(e.interpolationType){t+=`${TN[e.interpolationType]||e.interpolationType} ${_N[e.interpolationSampling]||""} in ${r} ${e.name};\n`}else{t+=`${r.includes("int")||r.includes("uv")||r.includes("iv")?"flat ":""}in ${r} ${e.name};\n`}}for(const r of this.builtins[e])t+=`${r};\n`;return t}getVertexIndex(){return"uint( gl_VertexID )"}getInstanceIndex(){return"uint( gl_InstanceID )"}getInvocationLocalIndex(){return`uint( gl_InstanceID ) % ${this.object.workgroupSize.reduce((e,t)=>e*t,1)}u`}getDrawIndex(){return this.renderer.backend.extensions.has("WEBGL_multi_draw")?"uint( gl_DrawID )":null}getFrontFacing(){return"gl_FrontFacing"}getFragCoord(){return"gl_FragCoord.xy"}getFragDepth(){return"gl_FragDepth"}enableExtension(e,t,r=this.shaderStage){const s=this.extensions[r]||(this.extensions[r]=new Map);!1===s.has(e)&&s.set(e,{name:e,behavior:t})}getExtensions(e){const t=[];if("vertex"===e){const t=this.renderer.backend.extensions;this.object.isBatchedMesh&&t.has("WEBGL_multi_draw")&&this.enableExtension("GL_ANGLE_multi_draw","require",e)}const r=this.extensions[e];if(void 0!==r)for(const{name:e,behavior:s}of r.values())t.push(`#extension ${e} : ${s}`);return t.join("\n")}getClipDistance(){return"gl_ClipDistance"}isAvailable(e){let t=xN[e];if(void 0===t){let r;switch(t=!1,e){case"float32Filterable":r="OES_texture_float_linear";break;case"clipDistance":r="WEBGL_clip_cull_distance"}if(void 0!==r){const e=this.renderer.backend.extensions;e.has(r)&&(e.get(r),t=!0)}xN[e]=t}return t}isFlipY(){return!0}enableHardwareClipping(e){this.enableExtension("GL_ANGLE_clip_cull_distance","require"),this.builtins.vertex.push(`out float gl_ClipDistance[ ${e} ]`)}enableMultiview(){this.enableExtension("GL_OVR_multiview2","require","fragment"),this.enableExtension("GL_OVR_multiview2","require","vertex"),this.builtins.vertex.push("layout(num_views = 2) in")}registerTransform(e,t){this.transforms.push({varyingName:e,attributeNode:t})}getTransforms(){const e=this.transforms;let t="";for(let r=0;r0&&(r+="\n"),r+=`\t// flow -> ${n}\n\t`),r+=`${s.code}\n\t`,e===i&&"compute"!==t&&(r+="// result\n\t","vertex"===t?(r+="gl_Position = ",r+=`${s.result};`):"fragment"===t&&(e.outputNode.isOutputStructNode||(r+="fragColor = ",r+=`${s.result};`)))}const n=e[t];n.extensions=this.getExtensions(t),n.uniforms=this.getUniforms(t),n.attributes=this.getAttributes(t),n.varyings=this.getVaryings(t),n.vars=this.getVars(t),n.structs=this.getStructs(t),n.codes=this.getCodes(t),n.transforms=this.getTransforms(t),n.flow=r}null!==this.material?(this.vertexShader=this._getGLSLVertexCode(e.vertex),this.fragmentShader=this._getGLSLFragmentCode(e.fragment)):this.computeShader=this._getGLSLVertexCode(e.compute)}getUniformFromNode(e,t,r,s=null){const i=super.getUniformFromNode(e,t,r,s),n=this.getDataFromNode(e,r,this.globalCache);let a=n.uniformGPU;if(void 0===a){const s=e.groupNode,o=s.name,u=this.getBindGroupArray(o,r);if("texture"===t)a=new gN(i.name,i.node,s),u.push(a);else if("cubeTexture"===t)a=new mN(i.name,i.node,s),u.push(a);else if("texture3D"===t)a=new fN(i.name,i.node,s),u.push(a);else if("buffer"===t){e.name=`NodeBuffer_${e.id}`,i.name=`buffer${e.id}`;const t=new oN(e,s);t.name=e.name,u.push(t),a=t}else{const e=this.uniformGroups[r]||(this.uniformGroups[r]={});let n=e[o];void 0===n&&(n=new dN(r+"_"+o,s),e[o]=n,u.push(n)),a=this.getNodeUniform(i,t),n.addUniform(a)}n.uniformGPU=a}return i}}let SN=null,EN=null;class wN{constructor(e={}){this.parameters=Object.assign({},e),this.data=new WeakMap,this.renderer=null,this.domElement=null,this.timestampQueryPool={render:null,compute:null},this.trackTimestamp=!0===e.trackTimestamp}async init(e){this.renderer=e}get coordinateSystem(){}beginRender(){}finishRender(){}beginCompute(){}finishCompute(){}draw(){}compute(){}createProgram(){}destroyProgram(){}createBindings(){}updateBindings(){}updateBinding(){}createRenderPipeline(){}createComputePipeline(){}needsRenderUpdate(){}getRenderCacheKey(){}createNodeBuilder(){}createSampler(){}destroySampler(){}createDefaultTexture(){}createTexture(){}updateTexture(){}generateMipmaps(){}destroyTexture(){}async copyTextureToBuffer(){}copyTextureToTexture(){}copyFramebufferToTexture(){}createAttribute(){}createIndexAttribute(){}createStorageAttribute(){}updateAttribute(){}destroyAttribute(){}getContext(){}updateSize(){}updateViewport(){}isOccluded(){}async resolveTimestampsAsync(e="render"){if(!this.trackTimestamp)return void pt("WebGPURenderer: Timestamp tracking is disabled.");const t=this.timestampQueryPool[e];if(!t)return void pt(`WebGPURenderer: No timestamp query pool for type '${e}' found.`);const r=await t.resolveQueriesAsync();return this.renderer.info[e].timestamp=r,r}async waitForGPU(){}async getArrayBufferAsync(){}async hasFeatureAsync(){}hasFeature(){}getMaxAnisotropy(){}getDrawingBufferSize(){return SN=SN||new t,this.renderer.getDrawingBufferSize(SN)}setScissorTest(){}getClearColor(){const e=this.renderer;return EN=EN||new ry,e.getClearColor(EN),EN.getRGB(EN),EN}getDomElement(){let e=this.domElement;return null===e&&(e=void 0!==this.parameters.canvas?this.parameters.canvas:gt(),"setAttribute"in e&&e.setAttribute("data-engine",`three.js r${He} webgpu`),this.domElement=e),e}set(e,t){this.data.set(e,t)}get(e){let t=this.data.get(e);return void 0===t&&(t={},this.data.set(e,t)),t}has(e){return this.data.has(e)}delete(e){this.data.delete(e)}dispose(){}}let AN,RN,CN=0;class MN{constructor(e,t){this.buffers=[e.bufferGPU,t],this.type=e.type,this.bufferType=e.bufferType,this.pbo=e.pbo,this.byteLength=e.byteLength,this.bytesPerElement=e.BYTES_PER_ELEMENT,this.version=e.version,this.isInteger=e.isInteger,this.activeBufferIndex=0,this.baseId=e.id}get id(){return`${this.baseId}|${this.activeBufferIndex}`}get bufferGPU(){return this.buffers[this.activeBufferIndex]}get transformBuffer(){return this.buffers[1^this.activeBufferIndex]}switchBuffers(){this.activeBufferIndex^=1}}class PN{constructor(e){this.backend=e}createAttribute(e,t){const r=this.backend,{gl:s}=r,i=e.array,n=e.usage||s.STATIC_DRAW,a=e.isInterleavedBufferAttribute?e.data:e,o=r.get(a);let u,l=o.bufferGPU;if(void 0===l&&(l=this._createBuffer(s,t,i,n),o.bufferGPU=l,o.bufferType=t,o.version=a.version),i instanceof Float32Array)u=s.FLOAT;else if("undefined"!=typeof Float16Array&&i instanceof Float16Array)u=s.HALF_FLOAT;else if(i instanceof Uint16Array)u=e.isFloat16BufferAttribute?s.HALF_FLOAT:s.UNSIGNED_SHORT;else if(i instanceof Int16Array)u=s.SHORT;else if(i instanceof Uint32Array)u=s.UNSIGNED_INT;else if(i instanceof Int32Array)u=s.INT;else if(i instanceof Int8Array)u=s.BYTE;else if(i instanceof Uint8Array)u=s.UNSIGNED_BYTE;else{if(!(i instanceof Uint8ClampedArray))throw new Error("THREE.WebGLBackend: Unsupported buffer data format: "+i);u=s.UNSIGNED_BYTE}let d={bufferGPU:l,bufferType:t,type:u,byteLength:i.byteLength,bytesPerElement:i.BYTES_PER_ELEMENT,version:e.version,pbo:e.pbo,isInteger:u===s.INT||u===s.UNSIGNED_INT||e.gpuType===_,id:CN++};if(e.isStorageBufferAttribute||e.isStorageInstancedBufferAttribute){const e=this._createBuffer(s,t,i,n);d=new MN(d,e)}r.set(e,d)}updateAttribute(e){const t=this.backend,{gl:r}=t,s=e.array,i=e.isInterleavedBufferAttribute?e.data:e,n=t.get(i),a=n.bufferType,o=e.isInterleavedBufferAttribute?e.data.updateRanges:e.updateRanges;if(r.bindBuffer(a,n.bufferGPU),0===o.length)r.bufferSubData(a,0,s);else{for(let e=0,t=o.length;e1?this.enable(s.SAMPLE_ALPHA_TO_COVERAGE):this.disable(s.SAMPLE_ALPHA_TO_COVERAGE),r>0&&this.currentClippingPlanes!==r){const e=12288;for(let t=0;t<8;t++)t{!function i(){const n=e.clientWaitSync(t,e.SYNC_FLUSH_COMMANDS_BIT,0);if(n===e.WAIT_FAILED)return e.deleteSync(t),void s();n!==e.TIMEOUT_EXPIRED?(e.deleteSync(t),r()):requestAnimationFrame(i)}()})}}let LN,IN,DN,VN=!1;class UN{constructor(e){this.backend=e,this.gl=e.gl,this.extensions=e.extensions,this.defaultTextures={},!1===VN&&(this._init(),VN=!0)}_init(){const e=this.gl;LN={[Sr]:e.REPEAT,[Nr]:e.CLAMP_TO_EDGE,[vr]:e.MIRRORED_REPEAT},IN={[v]:e.NEAREST,[Er]:e.NEAREST_MIPMAP_NEAREST,[Ge]:e.NEAREST_MIPMAP_LINEAR,[Y]:e.LINEAR,[ke]:e.LINEAR_MIPMAP_NEAREST,[V]:e.LINEAR_MIPMAP_LINEAR},DN={[Br]:e.NEVER,[Pr]:e.ALWAYS,[De]:e.LESS,[Mr]:e.LEQUAL,[Cr]:e.EQUAL,[Rr]:e.GEQUAL,[Ar]:e.GREATER,[wr]:e.NOTEQUAL}}getGLTextureType(e){const{gl:t}=this;let r;return r=!0===e.isCubeTexture?t.TEXTURE_CUBE_MAP:!0===e.isArrayTexture||!0===e.isDataArrayTexture||!0===e.isCompressedArrayTexture?t.TEXTURE_2D_ARRAY:!0===e.isData3DTexture?t.TEXTURE_3D:t.TEXTURE_2D,r}getInternalFormat(e,t,r,s,i=!1){const{gl:n,extensions:a}=this;if(null!==e){if(void 0!==n[e])return n[e];console.warn("THREE.WebGLRenderer: Attempt to use non-existing WebGL internal format '"+e+"'")}let o=t;if(t===n.RED&&(r===n.FLOAT&&(o=n.R32F),r===n.HALF_FLOAT&&(o=n.R16F),r===n.UNSIGNED_BYTE&&(o=n.R8),r===n.UNSIGNED_SHORT&&(o=n.R16),r===n.UNSIGNED_INT&&(o=n.R32UI),r===n.BYTE&&(o=n.R8I),r===n.SHORT&&(o=n.R16I),r===n.INT&&(o=n.R32I)),t===n.RED_INTEGER&&(r===n.UNSIGNED_BYTE&&(o=n.R8UI),r===n.UNSIGNED_SHORT&&(o=n.R16UI),r===n.UNSIGNED_INT&&(o=n.R32UI),r===n.BYTE&&(o=n.R8I),r===n.SHORT&&(o=n.R16I),r===n.INT&&(o=n.R32I)),t===n.RG&&(r===n.FLOAT&&(o=n.RG32F),r===n.HALF_FLOAT&&(o=n.RG16F),r===n.UNSIGNED_BYTE&&(o=n.RG8),r===n.UNSIGNED_SHORT&&(o=n.RG16),r===n.UNSIGNED_INT&&(o=n.RG32UI),r===n.BYTE&&(o=n.RG8I),r===n.SHORT&&(o=n.RG16I),r===n.INT&&(o=n.RG32I)),t===n.RG_INTEGER&&(r===n.UNSIGNED_BYTE&&(o=n.RG8UI),r===n.UNSIGNED_SHORT&&(o=n.RG16UI),r===n.UNSIGNED_INT&&(o=n.RG32UI),r===n.BYTE&&(o=n.RG8I),r===n.SHORT&&(o=n.RG16I),r===n.INT&&(o=n.RG32I)),t===n.RGB){const e=i?Fr:c.getTransfer(s);r===n.FLOAT&&(o=n.RGB32F),r===n.HALF_FLOAT&&(o=n.RGB16F),r===n.UNSIGNED_BYTE&&(o=n.RGB8),r===n.UNSIGNED_SHORT&&(o=n.RGB16),r===n.UNSIGNED_INT&&(o=n.RGB32UI),r===n.BYTE&&(o=n.RGB8I),r===n.SHORT&&(o=n.RGB16I),r===n.INT&&(o=n.RGB32I),r===n.UNSIGNED_BYTE&&(o=e===h?n.SRGB8:n.RGB8),r===n.UNSIGNED_SHORT_5_6_5&&(o=n.RGB565),r===n.UNSIGNED_SHORT_5_5_5_1&&(o=n.RGB5_A1),r===n.UNSIGNED_SHORT_4_4_4_4&&(o=n.RGB4),r===n.UNSIGNED_INT_5_9_9_9_REV&&(o=n.RGB9_E5),r===n.UNSIGNED_INT_10F_11F_11F_REV&&(o=n.R11F_G11F_B10F)}if(t===n.RGB_INTEGER&&(r===n.UNSIGNED_BYTE&&(o=n.RGB8UI),r===n.UNSIGNED_SHORT&&(o=n.RGB16UI),r===n.UNSIGNED_INT&&(o=n.RGB32UI),r===n.BYTE&&(o=n.RGB8I),r===n.SHORT&&(o=n.RGB16I),r===n.INT&&(o=n.RGB32I)),t===n.RGBA){const e=i?Fr:c.getTransfer(s);r===n.FLOAT&&(o=n.RGBA32F),r===n.HALF_FLOAT&&(o=n.RGBA16F),r===n.UNSIGNED_BYTE&&(o=n.RGBA8),r===n.UNSIGNED_SHORT&&(o=n.RGBA16),r===n.UNSIGNED_INT&&(o=n.RGBA32UI),r===n.BYTE&&(o=n.RGBA8I),r===n.SHORT&&(o=n.RGBA16I),r===n.INT&&(o=n.RGBA32I),r===n.UNSIGNED_BYTE&&(o=e===h?n.SRGB8_ALPHA8:n.RGBA8),r===n.UNSIGNED_SHORT_4_4_4_4&&(o=n.RGBA4),r===n.UNSIGNED_SHORT_5_5_5_1&&(o=n.RGB5_A1)}return t===n.RGBA_INTEGER&&(r===n.UNSIGNED_BYTE&&(o=n.RGBA8UI),r===n.UNSIGNED_SHORT&&(o=n.RGBA16UI),r===n.UNSIGNED_INT&&(o=n.RGBA32UI),r===n.BYTE&&(o=n.RGBA8I),r===n.SHORT&&(o=n.RGBA16I),r===n.INT&&(o=n.RGBA32I)),t===n.DEPTH_COMPONENT&&(r===n.UNSIGNED_SHORT&&(o=n.DEPTH_COMPONENT16),r===n.UNSIGNED_INT&&(o=n.DEPTH_COMPONENT24),r===n.FLOAT&&(o=n.DEPTH_COMPONENT32F)),t===n.DEPTH_STENCIL&&r===n.UNSIGNED_INT_24_8&&(o=n.DEPTH24_STENCIL8),o!==n.R16F&&o!==n.R32F&&o!==n.RG16F&&o!==n.RG32F&&o!==n.RGBA16F&&o!==n.RGBA32F||a.get("EXT_color_buffer_float"),o}setTextureParameters(e,t){const{gl:r,extensions:s,backend:i}=this,n=c.getPrimaries(c.workingColorSpace),a=t.colorSpace===b?null:c.getPrimaries(t.colorSpace),o=t.colorSpace===b||n===a?r.NONE:r.BROWSER_DEFAULT_WEBGL;r.pixelStorei(r.UNPACK_FLIP_Y_WEBGL,t.flipY),r.pixelStorei(r.UNPACK_PREMULTIPLY_ALPHA_WEBGL,t.premultiplyAlpha),r.pixelStorei(r.UNPACK_ALIGNMENT,t.unpackAlignment),r.pixelStorei(r.UNPACK_COLORSPACE_CONVERSION_WEBGL,o),r.texParameteri(e,r.TEXTURE_WRAP_S,LN[t.wrapS]),r.texParameteri(e,r.TEXTURE_WRAP_T,LN[t.wrapT]),e!==r.TEXTURE_3D&&e!==r.TEXTURE_2D_ARRAY||t.isArrayTexture||r.texParameteri(e,r.TEXTURE_WRAP_R,LN[t.wrapR]),r.texParameteri(e,r.TEXTURE_MAG_FILTER,IN[t.magFilter]);const u=void 0!==t.mipmaps&&t.mipmaps.length>0,l=t.minFilter===Y&&u?V:t.minFilter;if(r.texParameteri(e,r.TEXTURE_MIN_FILTER,IN[l]),t.compareFunction&&(r.texParameteri(e,r.TEXTURE_COMPARE_MODE,r.COMPARE_REF_TO_TEXTURE),r.texParameteri(e,r.TEXTURE_COMPARE_FUNC,DN[t.compareFunction])),!0===s.has("EXT_texture_filter_anisotropic")){if(t.magFilter===v)return;if(t.minFilter!==Ge&&t.minFilter!==V)return;if(t.type===I&&!1===s.has("OES_texture_float_linear"))return;if(t.anisotropy>1){const n=s.get("EXT_texture_filter_anisotropic");r.texParameterf(e,n.TEXTURE_MAX_ANISOTROPY_EXT,Math.min(t.anisotropy,i.getMaxAnisotropy()))}}}createDefaultTexture(e){const{gl:t,backend:r,defaultTextures:s}=this,i=this.getGLTextureType(e);let n=s[i];void 0===n&&(n=t.createTexture(),r.state.bindTexture(i,n),t.texParameteri(i,t.TEXTURE_MIN_FILTER,t.NEAREST),t.texParameteri(i,t.TEXTURE_MAG_FILTER,t.NEAREST),s[i]=n),r.set(e,{textureGPU:n,glTextureType:i,isDefault:!0})}createTexture(e,t){const{gl:r,backend:s}=this,{levels:i,width:n,height:a,depth:o}=t,u=s.utils.convert(e.format,e.colorSpace),l=s.utils.convert(e.type),d=this.getInternalFormat(e.internalFormat,u,l,e.colorSpace,e.isVideoTexture),c=r.createTexture(),h=this.getGLTextureType(e);s.state.bindTexture(h,c),this.setTextureParameters(h,e),e.isArrayTexture||e.isDataArrayTexture||e.isCompressedArrayTexture?r.texStorage3D(r.TEXTURE_2D_ARRAY,i,d,n,a,o):e.isData3DTexture?r.texStorage3D(r.TEXTURE_3D,i,d,n,a,o):e.isVideoTexture||r.texStorage2D(h,i,d,n,a),s.set(e,{textureGPU:c,glTextureType:h,glFormat:u,glType:l,glInternalFormat:d})}copyBufferToTexture(e,t){const{gl:r,backend:s}=this,{textureGPU:i,glTextureType:n,glFormat:a,glType:o}=s.get(t),{width:u,height:l}=t.source.data;r.bindBuffer(r.PIXEL_UNPACK_BUFFER,e),s.state.bindTexture(n,i),r.pixelStorei(r.UNPACK_FLIP_Y_WEBGL,!1),r.pixelStorei(r.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!1),r.texSubImage2D(n,0,0,0,u,l,a,o,0),r.bindBuffer(r.PIXEL_UNPACK_BUFFER,null),s.state.unbindTexture()}updateTexture(e,t){const{gl:r}=this,{width:s,height:i}=t,{textureGPU:n,glTextureType:a,glFormat:o,glType:u,glInternalFormat:l}=this.backend.get(e);if(!e.isRenderTargetTexture&&void 0!==n)if(this.backend.state.bindTexture(a,n),this.setTextureParameters(a,e),e.isCompressedTexture){const s=e.mipmaps,i=t.image;for(let t=0;t0){const t=Lr(s.width,s.height,e.format,e.type);for(const i of e.layerUpdates){const e=s.data.subarray(i*t/s.data.BYTES_PER_ELEMENT,(i+1)*t/s.data.BYTES_PER_ELEMENT);r.texSubImage3D(r.TEXTURE_2D_ARRAY,0,0,0,i,s.width,s.height,1,o,u,e)}e.clearLayerUpdates()}else r.texSubImage3D(r.TEXTURE_2D_ARRAY,0,0,0,0,s.width,s.height,s.depth,o,u,s.data)}else if(e.isData3DTexture){const e=t.image;r.texSubImage3D(r.TEXTURE_3D,0,0,0,0,e.width,e.height,e.depth,o,u,e.data)}else if(e.isVideoTexture)e.update(),r.texImage2D(a,0,l,o,u,t.image);else{const e=ON(t.image);r.texSubImage2D(a,0,0,0,s,i,o,u,e)}}generateMipmaps(e){const{gl:t,backend:r}=this,{textureGPU:s,glTextureType:i}=r.get(e);r.state.bindTexture(i,s),t.generateMipmap(i)}deallocateRenderBuffers(e){const{gl:t,backend:r}=this;if(e){const s=r.get(e);if(s.renderBufferStorageSetup=void 0,s.framebuffers){for(const e in s.framebuffers)t.deleteFramebuffer(s.framebuffers[e]);delete s.framebuffers}if(s.depthRenderbuffer&&(t.deleteRenderbuffer(s.depthRenderbuffer),delete s.depthRenderbuffer),s.stencilRenderbuffer&&(t.deleteRenderbuffer(s.stencilRenderbuffer),delete s.stencilRenderbuffer),s.msaaFrameBuffer&&(t.deleteFramebuffer(s.msaaFrameBuffer),delete s.msaaFrameBuffer),s.msaaRenderbuffers){for(let e=0;e0,c=t.renderTarget?t.renderTarget.height:this.backend.getDrawingBufferSize().y;if(d){const r=0!==a||0!==o;let d,h;if(!0===e.isDepthTexture?(d=s.DEPTH_BUFFER_BIT,h=s.DEPTH_ATTACHMENT,t.stencil&&(d|=s.STENCIL_BUFFER_BIT)):(d=s.COLOR_BUFFER_BIT,h=s.COLOR_ATTACHMENT0),r){const e=this.backend.get(t.renderTarget),r=e.framebuffers[t.getCacheKey()],h=e.msaaFrameBuffer;i.bindFramebuffer(s.DRAW_FRAMEBUFFER,r),i.bindFramebuffer(s.READ_FRAMEBUFFER,h);const p=c-o-l;s.blitFramebuffer(a,p,a+u,p+l,a,p,a+u,p+l,d,s.NEAREST),i.bindFramebuffer(s.READ_FRAMEBUFFER,r),i.bindTexture(s.TEXTURE_2D,n),s.copyTexSubImage2D(s.TEXTURE_2D,0,0,0,a,p,u,l),i.unbindTexture()}else{const e=s.createFramebuffer();i.bindFramebuffer(s.DRAW_FRAMEBUFFER,e),s.framebufferTexture2D(s.DRAW_FRAMEBUFFER,h,s.TEXTURE_2D,n,0),s.blitFramebuffer(0,0,u,l,0,0,u,l,d,s.NEAREST),s.deleteFramebuffer(e)}}else i.bindTexture(s.TEXTURE_2D,n),s.copyTexSubImage2D(s.TEXTURE_2D,0,0,0,a,c-l-o,u,l),i.unbindTexture();e.generateMipmaps&&this.generateMipmaps(e),this.backend._setFramebuffer(t)}setupRenderBufferStorage(e,t,r,s=!1){const{gl:i}=this,n=t.renderTarget,{depthTexture:a,depthBuffer:o,stencilBuffer:u,width:l,height:d}=n;if(i.bindRenderbuffer(i.RENDERBUFFER,e),o&&!u){let t=i.DEPTH_COMPONENT24;if(!0===s){this.extensions.get("WEBGL_multisampled_render_to_texture").renderbufferStorageMultisampleEXT(i.RENDERBUFFER,n.samples,t,l,d)}else r>0?(a&&a.isDepthTexture&&a.type===i.FLOAT&&(t=i.DEPTH_COMPONENT32F),i.renderbufferStorageMultisample(i.RENDERBUFFER,r,t,l,d)):i.renderbufferStorage(i.RENDERBUFFER,t,l,d);i.framebufferRenderbuffer(i.FRAMEBUFFER,i.DEPTH_ATTACHMENT,i.RENDERBUFFER,e)}else o&&u&&(r>0?i.renderbufferStorageMultisample(i.RENDERBUFFER,r,i.DEPTH24_STENCIL8,l,d):i.renderbufferStorage(i.RENDERBUFFER,i.DEPTH_STENCIL,l,d),i.framebufferRenderbuffer(i.FRAMEBUFFER,i.DEPTH_STENCIL_ATTACHMENT,i.RENDERBUFFER,e));i.bindRenderbuffer(i.RENDERBUFFER,null)}async copyTextureToBuffer(e,t,r,s,i,n){const{backend:a,gl:o}=this,{textureGPU:u,glFormat:l,glType:d}=this.backend.get(e),c=o.createFramebuffer();o.bindFramebuffer(o.READ_FRAMEBUFFER,c);const h=e.isCubeTexture?o.TEXTURE_CUBE_MAP_POSITIVE_X+n:o.TEXTURE_2D;o.framebufferTexture2D(o.READ_FRAMEBUFFER,o.COLOR_ATTACHMENT0,h,u,0);const p=this._getTypedArrayType(d),g=s*i*this._getBytesPerTexel(d,l),m=o.createBuffer();o.bindBuffer(o.PIXEL_PACK_BUFFER,m),o.bufferData(o.PIXEL_PACK_BUFFER,g,o.STREAM_READ),o.readPixels(t,r,s,i,l,d,0),o.bindBuffer(o.PIXEL_PACK_BUFFER,null),await a.utils._clientWaitAsync();const f=new p(g/p.BYTES_PER_ELEMENT);return o.bindBuffer(o.PIXEL_PACK_BUFFER,m),o.getBufferSubData(o.PIXEL_PACK_BUFFER,0,f),o.bindBuffer(o.PIXEL_PACK_BUFFER,null),o.deleteFramebuffer(c),f}_getTypedArrayType(e){const{gl:t}=this;if(e===t.UNSIGNED_BYTE)return Uint8Array;if(e===t.UNSIGNED_SHORT_4_4_4_4)return Uint16Array;if(e===t.UNSIGNED_SHORT_5_5_5_1)return Uint16Array;if(e===t.UNSIGNED_SHORT_5_6_5)return Uint16Array;if(e===t.UNSIGNED_SHORT)return Uint16Array;if(e===t.UNSIGNED_INT)return Uint32Array;if(e===t.HALF_FLOAT)return Uint16Array;if(e===t.FLOAT)return Float32Array;throw new Error(`Unsupported WebGL type: ${e}`)}_getBytesPerTexel(e,t){const{gl:r}=this;let s=0;return e===r.UNSIGNED_BYTE&&(s=1),e!==r.UNSIGNED_SHORT_4_4_4_4&&e!==r.UNSIGNED_SHORT_5_5_5_1&&e!==r.UNSIGNED_SHORT_5_6_5&&e!==r.UNSIGNED_SHORT&&e!==r.HALF_FLOAT||(s=2),e!==r.UNSIGNED_INT&&e!==r.FLOAT||(s=4),t===r.RGBA?4*s:t===r.RGB?3*s:t===r.ALPHA?s:void 0}}function ON(e){return e.isDataTexture?e.image.data:"undefined"!=typeof HTMLImageElement&&e instanceof HTMLImageElement||"undefined"!=typeof HTMLCanvasElement&&e instanceof HTMLCanvasElement||"undefined"!=typeof ImageBitmap&&e instanceof ImageBitmap||"undefined"!=typeof OffscreenCanvas&&e instanceof OffscreenCanvas?e:e.data}class kN{constructor(e){this.backend=e,this.gl=this.backend.gl,this.availableExtensions=this.gl.getSupportedExtensions(),this.extensions={}}get(e){let t=this.extensions[e];return void 0===t&&(t=this.gl.getExtension(e),this.extensions[e]=t),t}has(e){return this.availableExtensions.includes(e)}}class GN{constructor(e){this.backend=e,this.maxAnisotropy=null}getMaxAnisotropy(){if(null!==this.maxAnisotropy)return this.maxAnisotropy;const e=this.backend.gl,t=this.backend.extensions;if(!0===t.has("EXT_texture_filter_anisotropic")){const r=t.get("EXT_texture_filter_anisotropic");this.maxAnisotropy=e.getParameter(r.MAX_TEXTURE_MAX_ANISOTROPY_EXT)}else this.maxAnisotropy=0;return this.maxAnisotropy}}const zN={WEBGL_multi_draw:"WEBGL_multi_draw",WEBGL_compressed_texture_astc:"texture-compression-astc",WEBGL_compressed_texture_etc:"texture-compression-etc2",WEBGL_compressed_texture_etc1:"texture-compression-etc1",WEBGL_compressed_texture_pvrtc:"texture-compression-pvrtc",WEBKIT_WEBGL_compressed_texture_pvrtc:"texture-compression-pvrtc",WEBGL_compressed_texture_s3tc:"texture-compression-bc",EXT_texture_compression_bptc:"texture-compression-bptc",EXT_disjoint_timer_query_webgl2:"timestamp-query",OVR_multiview2:"OVR_multiview2"};class HN{constructor(e){this.gl=e.gl,this.extensions=e.extensions,this.info=e.renderer.info,this.mode=null,this.index=0,this.type=null,this.object=null}render(e,t){const{gl:r,mode:s,object:i,type:n,info:a,index:o}=this;0!==o?r.drawElements(s,t,n,e):r.drawArrays(s,e,t),a.update(i,t,1)}renderInstances(e,t,r){const{gl:s,mode:i,type:n,index:a,object:o,info:u}=this;0!==r&&(0!==a?s.drawElementsInstanced(i,t,n,e,r):s.drawArraysInstanced(i,e,t,r),u.update(o,t,r))}renderMultiDraw(e,t,r){const{extensions:s,mode:i,object:n,info:a}=this;if(0===r)return;const o=s.get("WEBGL_multi_draw");if(null===o)for(let s=0;sthis.maxQueries)return pt(`WebGPUTimestampQueryPool [${this.type}]: Maximum number of queries exceeded, when using trackTimestamp it is necessary to resolves the queries via renderer.resolveTimestampsAsync( THREE.TimestampQuery.${this.type.toUpperCase()} ).`),null;const t=this.currentQueryIndex;return this.currentQueryIndex+=2,this.queryStates.set(t,"inactive"),this.queryOffsets.set(e.id,t),t}beginQuery(e){if(!this.trackTimestamp||this.isDisposed)return;const t=this.queryOffsets.get(e.id);if(null==t)return;if(null!==this.activeQuery)return;const r=this.queries[t];if(r)try{"inactive"===this.queryStates.get(t)&&(this.gl.beginQuery(this.ext.TIME_ELAPSED_EXT,r),this.activeQuery=t,this.queryStates.set(t,"started"))}catch(e){console.error("Error in beginQuery:",e),this.activeQuery=null,this.queryStates.set(t,"inactive")}}endQuery(e){if(!this.trackTimestamp||this.isDisposed)return;const t=this.queryOffsets.get(e.id);if(null!=t&&this.activeQuery===t)try{this.gl.endQuery(this.ext.TIME_ELAPSED_EXT),this.queryStates.set(t,"ended"),this.activeQuery=null}catch(e){console.error("Error in endQuery:",e),this.queryStates.set(t,"inactive"),this.activeQuery=null}}async resolveQueriesAsync(){if(!this.trackTimestamp||this.pendingResolve)return this.lastValue;this.pendingResolve=!0;try{const e=[];for(const[t,r]of this.queryStates)if("ended"===r){const r=this.queries[t];e.push(this.resolveQuery(r))}if(0===e.length)return this.lastValue;const t=(await Promise.all(e)).reduce((e,t)=>e+t,0);return this.lastValue=t,this.currentQueryIndex=0,this.queryOffsets.clear(),this.queryStates.clear(),this.activeQuery=null,t}catch(e){return console.error("Error resolving queries:",e),this.lastValue}finally{this.pendingResolve=!1}}async resolveQuery(e){return new Promise(t=>{if(this.isDisposed)return void t(this.lastValue);let r,s=!1;const i=e=>{s||(s=!0,r&&(clearTimeout(r),r=null),t(e))},n=()=>{if(this.isDisposed)i(this.lastValue);else try{if(this.gl.getParameter(this.ext.GPU_DISJOINT_EXT))return void i(this.lastValue);if(!this.gl.getQueryParameter(e,this.gl.QUERY_RESULT_AVAILABLE))return void(r=setTimeout(n,1));const s=this.gl.getQueryParameter(e,this.gl.QUERY_RESULT);t(Number(s)/1e6)}catch(e){console.error("Error checking query:",e),t(this.lastValue)}};n()})}dispose(){if(!this.isDisposed&&(this.isDisposed=!0,this.trackTimestamp)){for(const e of this.queries)this.gl.deleteQuery(e);this.queries=[],this.queryStates.clear(),this.queryOffsets.clear(),this.lastValue=0,this.activeQuery=null}}}class jN extends wN{constructor(e={}){super(e),this.isWebGLBackend=!0,this.attributeUtils=null,this.extensions=null,this.capabilities=null,this.textureUtils=null,this.bufferRenderer=null,this.gl=null,this.state=null,this.utils=null,this.vaoCache={},this.transformFeedbackCache={},this.discard=!1,this.disjoint=null,this.parallel=null,this._currentContext=null,this._knownBindings=new WeakSet,this._supportsInvalidateFramebuffer="undefined"!=typeof navigator&&/OculusBrowser/g.test(navigator.userAgent),this._xrFramebuffer=null}init(e){super.init(e);const t=this.parameters,r={antialias:e.samples>0,alpha:!0,depth:e.depth,stencil:e.stencil},s=void 0!==t.context?t.context:e.domElement.getContext("webgl2",r);function i(t){t.preventDefault();const r={api:"WebGL",message:t.statusMessage||"Unknown reason",reason:null,originalEvent:t};e.onDeviceLost(r)}this._onContextLost=i,e.domElement.addEventListener("webglcontextlost",i,!1),this.gl=s,this.extensions=new kN(this),this.capabilities=new GN(this),this.attributeUtils=new PN(this),this.textureUtils=new UN(this),this.bufferRenderer=new HN(this),this.state=new BN(this),this.utils=new FN(this),this.extensions.get("EXT_color_buffer_float"),this.extensions.get("WEBGL_clip_cull_distance"),this.extensions.get("OES_texture_float_linear"),this.extensions.get("EXT_color_buffer_half_float"),this.extensions.get("WEBGL_multisampled_render_to_texture"),this.extensions.get("WEBGL_render_shared_exponent"),this.extensions.get("WEBGL_multi_draw"),this.extensions.get("OVR_multiview2"),this.disjoint=this.extensions.get("EXT_disjoint_timer_query_webgl2"),this.parallel=this.extensions.get("KHR_parallel_shader_compile")}get coordinateSystem(){return l}async getArrayBufferAsync(e){return await this.attributeUtils.getArrayBufferAsync(e)}async waitForGPU(){await this.utils._clientWaitAsync()}async makeXRCompatible(){!0!==this.gl.getContextAttributes().xrCompatible&&await this.gl.makeXRCompatible()}setXRTarget(e){this._xrFramebuffer=e}setXRRenderTargetTextures(e,t,r=null){const s=this.gl;if(this.set(e.texture,{textureGPU:t,glInternalFormat:s.RGBA8}),null!==r){const t=e.stencilBuffer?s.DEPTH24_STENCIL8:s.DEPTH_COMPONENT24;this.set(e.depthTexture,{textureGPU:r,glInternalFormat:t}),!0===this.extensions.has("WEBGL_multisampled_render_to_texture")&&!0===e._autoAllocateDepthBuffer&&!1===e.multiview&&console.warn("THREE.WebGLBackend: Render-to-texture extension was disabled because an external texture was provided"),e._autoAllocateDepthBuffer=!1}}initTimestampQuery(e){if(!this.disjoint||!this.trackTimestamp)return;const t=e.isComputeNode?"compute":"render";this.timestampQueryPool[t]||(this.timestampQueryPool[t]=new WN(this.gl,t,2048));const r=this.timestampQueryPool[t];null!==r.allocateQueriesForContext(e)&&r.beginQuery(e)}prepareTimestampBuffer(e){if(!this.disjoint||!this.trackTimestamp)return;const t=e.isComputeNode?"compute":"render";this.timestampQueryPool[t].endQuery(e)}getContext(){return this.gl}beginRender(e){const{state:t}=this,r=this.get(e);if(e.viewport)this.updateViewport(e);else{const{width:e,height:r}=this.getDrawingBufferSize();t.viewport(0,0,e,r)}if(e.scissor){const{x:r,y:s,width:i,height:n}=e.scissorValue;t.scissor(r,e.height-n-s,i,n)}this.initTimestampQuery(e),r.previousContext=this._currentContext,this._currentContext=e,this._setFramebuffer(e),this.clear(e.clearColor,e.clearDepth,e.clearStencil,e,!1);const s=e.occlusionQueryCount;s>0&&(r.currentOcclusionQueries=r.occlusionQueries,r.currentOcclusionQueryObjects=r.occlusionQueryObjects,r.lastOcclusionObject=null,r.occlusionQueries=new Array(s),r.occlusionQueryObjects=new Array(s),r.occlusionQueryIndex=0)}finishRender(e){const{gl:t,state:r}=this,s=this.get(e),i=s.previousContext;r.resetVertexState();const n=e.occlusionQueryCount;n>0&&(n>s.occlusionQueryIndex&&t.endQuery(t.ANY_SAMPLES_PASSED),this.resolveOccludedAsync(e));const a=e.textures;if(null!==a)for(let e=0;e0&&!1===this._useMultisampledExtension(o)){const i=s.framebuffers[e.getCacheKey()];let n=t.COLOR_BUFFER_BIT;o.resolveDepthBuffer&&(o.depthBuffer&&(n|=t.DEPTH_BUFFER_BIT),o.stencilBuffer&&o.resolveStencilBuffer&&(n|=t.STENCIL_BUFFER_BIT));const a=s.msaaFrameBuffer,u=s.msaaRenderbuffers,l=e.textures,d=l.length>1;if(r.bindFramebuffer(t.READ_FRAMEBUFFER,a),r.bindFramebuffer(t.DRAW_FRAMEBUFFER,i),d)for(let e=0;e{let a=0;for(let t=0;t{t.isBatchedMesh?null!==t._multiDrawInstances?(pt("THREE.WebGLBackend: renderMultiDrawInstances has been deprecated and will be removed in r184. Append to renderMultiDraw arguments and use indirection."),b.renderMultiDrawInstances(t._multiDrawStarts,t._multiDrawCounts,t._multiDrawCount,t._multiDrawInstances)):this.hasFeature("WEBGL_multi_draw")?b.renderMultiDraw(t._multiDrawStarts,t._multiDrawCounts,t._multiDrawCount):pt("THREE.WebGLRenderer: WEBGL_multi_draw not supported."):T>1?b.renderInstances(_,x,T):b.render(_,x)};if(!0===e.camera.isArrayCamera&&e.camera.cameras.length>0&&!1===e.camera.isMultiViewCamera){const r=this.get(e.camera),s=e.camera.cameras,i=e.getBindingGroup("cameraIndex").bindings[0];if(void 0===r.indexesGPU||r.indexesGPU.length!==s.length){const e=new Uint32Array([0,0,0,0]),t=[];for(let r=0,i=s.length;r{const i=this.parallel,n=()=>{r.getProgramParameter(a,i.COMPLETION_STATUS_KHR)?(this._completeCompile(e,s),t()):requestAnimationFrame(n)};n()});return void t.push(i)}this._completeCompile(e,s)}_handleSource(e,t){const r=e.split("\n"),s=[],i=Math.max(t-6,0),n=Math.min(t+6,r.length);for(let e=i;e":" "} ${i}: ${r[e]}`)}return s.join("\n")}_getShaderErrors(e,t,r){const s=e.getShaderParameter(t,e.COMPILE_STATUS),i=(e.getShaderInfoLog(t)||"").trim();if(s&&""===i)return"";const n=/ERROR: 0:(\d+)/.exec(i);if(n){const s=parseInt(n[1]);return r.toUpperCase()+"\n\n"+i+"\n\n"+this._handleSource(e.getShaderSource(t),s)}return i}_logProgramError(e,t,r){if(this.renderer.debug.checkShaderErrors){const s=this.gl,i=(s.getProgramInfoLog(e)||"").trim();if(!1===s.getProgramParameter(e,s.LINK_STATUS))if("function"==typeof this.renderer.debug.onShaderError)this.renderer.debug.onShaderError(s,e,r,t);else{const n=this._getShaderErrors(s,r,"vertex"),a=this._getShaderErrors(s,t,"fragment");console.error("THREE.WebGLProgram: Shader Error "+s.getError()+" - VALIDATE_STATUS "+s.getProgramParameter(e,s.VALIDATE_STATUS)+"\n\nProgram Info Log: "+i+"\n"+n+"\n"+a)}else""!==i&&console.warn("THREE.WebGLProgram: Program Info Log:",i)}}_completeCompile(e,t){const{state:r,gl:s}=this,i=this.get(t),{programGPU:n,fragmentShader:a,vertexShader:o}=i;!1===s.getProgramParameter(n,s.LINK_STATUS)&&this._logProgramError(n,a,o),r.useProgram(n);const u=e.getBindings();this._setupBindings(u,n),this.set(t,{programGPU:n})}createComputePipeline(e,t){const{state:r,gl:s}=this,i={stage:"fragment",code:"#version 300 es\nprecision highp float;\nvoid main() {}"};this.createProgram(i);const{computeProgram:n}=e,a=s.createProgram(),o=this.get(i).shaderGPU,u=this.get(n).shaderGPU,l=n.transforms,d=[],c=[];for(let e=0;ezN[t]===e),r=this.extensions;for(let e=0;e1,h=!0===i.isXRRenderTarget,p=!0===h&&!0===i._hasExternalTextures;let g=n.msaaFrameBuffer,m=n.depthRenderbuffer;const f=this.extensions.get("WEBGL_multisampled_render_to_texture"),y=this.extensions.get("OVR_multiview2"),b=this._useMultisampledExtension(i),x=Kf(e);let T;if(l?(n.cubeFramebuffers||(n.cubeFramebuffers={}),T=n.cubeFramebuffers[x]):h&&!1===p?T=this._xrFramebuffer:(n.framebuffers||(n.framebuffers={}),T=n.framebuffers[x]),void 0===T){T=t.createFramebuffer(),r.bindFramebuffer(t.FRAMEBUFFER,T);const s=e.textures,o=[];if(l){n.cubeFramebuffers[x]=T;const{textureGPU:e}=this.get(s[0]),r=this.renderer._activeCubeFace;t.framebufferTexture2D(t.FRAMEBUFFER,t.COLOR_ATTACHMENT0,t.TEXTURE_CUBE_MAP_POSITIVE_X+r,e,0)}else{n.framebuffers[x]=T;for(let r=0;r0&&!1===b&&!i.multiview){if(void 0===g){const s=[];g=t.createFramebuffer(),r.bindFramebuffer(t.FRAMEBUFFER,g);const i=[],l=e.textures;for(let r=0;r0&&!0===this.extensions.has("WEBGL_multisampled_render_to_texture")&&!1!==e._autoAllocateDepthBuffer}dispose(){const e=this.extensions.get("WEBGL_lose_context");e&&e.loseContext(),this.renderer.domElement.removeEventListener("webglcontextlost",this._onContextLost)}}const qN="point-list",XN="line-list",KN="line-strip",YN="triangle-list",QN="triangle-strip",ZN="never",JN="less",eS="equal",tS="less-equal",rS="greater",sS="not-equal",iS="greater-equal",nS="always",aS="store",oS="load",uS="clear",lS="ccw",dS="none",cS="front",hS="back",pS="uint16",gS="uint32",mS="r8unorm",fS="r8snorm",yS="r8uint",bS="r8sint",xS="r16uint",TS="r16sint",_S="r16float",vS="rg8unorm",NS="rg8snorm",SS="rg8uint",ES="rg8sint",wS="r32uint",AS="r32sint",RS="r32float",CS="rg16uint",MS="rg16sint",PS="rg16float",BS="rgba8unorm",FS="rgba8unorm-srgb",LS="rgba8snorm",IS="rgba8uint",DS="rgba8sint",VS="bgra8unorm",US="bgra8unorm-srgb",OS="rgb9e5ufloat",kS="rgb10a2unorm",GS="rgb10a2unorm",zS="rg32uint",HS="rg32sint",$S="rg32float",WS="rgba16uint",jS="rgba16sint",qS="rgba16float",XS="rgba32uint",KS="rgba32sint",YS="rgba32float",QS="depth16unorm",ZS="depth24plus",JS="depth24plus-stencil8",eE="depth32float",tE="depth32float-stencil8",rE="bc1-rgba-unorm",sE="bc1-rgba-unorm-srgb",iE="bc2-rgba-unorm",nE="bc2-rgba-unorm-srgb",aE="bc3-rgba-unorm",oE="bc3-rgba-unorm-srgb",uE="bc4-r-unorm",lE="bc4-r-snorm",dE="bc5-rg-unorm",cE="bc5-rg-snorm",hE="bc6h-rgb-ufloat",pE="bc6h-rgb-float",gE="bc7-rgba-unorm",mE="bc7-rgba-srgb",fE="etc2-rgb8unorm",yE="etc2-rgb8unorm-srgb",bE="etc2-rgb8a1unorm",xE="etc2-rgb8a1unorm-srgb",TE="etc2-rgba8unorm",_E="etc2-rgba8unorm-srgb",vE="eac-r11unorm",NE="eac-r11snorm",SE="eac-rg11unorm",EE="eac-rg11snorm",wE="astc-4x4-unorm",AE="astc-4x4-unorm-srgb",RE="astc-5x4-unorm",CE="astc-5x4-unorm-srgb",ME="astc-5x5-unorm",PE="astc-5x5-unorm-srgb",BE="astc-6x5-unorm",FE="astc-6x5-unorm-srgb",LE="astc-6x6-unorm",IE="astc-6x6-unorm-srgb",DE="astc-8x5-unorm",VE="astc-8x5-unorm-srgb",UE="astc-8x6-unorm",OE="astc-8x6-unorm-srgb",kE="astc-8x8-unorm",GE="astc-8x8-unorm-srgb",zE="astc-10x5-unorm",HE="astc-10x5-unorm-srgb",$E="astc-10x6-unorm",WE="astc-10x6-unorm-srgb",jE="astc-10x8-unorm",qE="astc-10x8-unorm-srgb",XE="astc-10x10-unorm",KE="astc-10x10-unorm-srgb",YE="astc-12x10-unorm",QE="astc-12x10-unorm-srgb",ZE="astc-12x12-unorm",JE="astc-12x12-unorm-srgb",ew="clamp-to-edge",tw="repeat",rw="mirror-repeat",sw="linear",iw="nearest",nw="zero",aw="one",ow="src",uw="one-minus-src",lw="src-alpha",dw="one-minus-src-alpha",cw="dst",hw="one-minus-dst",pw="dst-alpha",gw="one-minus-dst-alpha",mw="src-alpha-saturated",fw="constant",yw="one-minus-constant",bw="add",xw="subtract",Tw="reverse-subtract",_w="min",vw="max",Nw=0,Sw=15,Ew="keep",ww="zero",Aw="replace",Rw="invert",Cw="increment-clamp",Mw="decrement-clamp",Pw="increment-wrap",Bw="decrement-wrap",Fw="storage",Lw="read-only-storage",Iw="write-only",Dw="read-only",Vw="read-write",Uw="non-filtering",Ow="comparison",kw="float",Gw="unfilterable-float",zw="depth",Hw="sint",$w="uint",Ww="2d",jw="3d",qw="2d",Xw="2d-array",Kw="cube",Yw="3d",Qw="all",Zw="vertex",Jw="instance",eA={CoreFeaturesAndLimits:"core-features-and-limits",DepthClipControl:"depth-clip-control",Depth32FloatStencil8:"depth32float-stencil8",TextureCompressionBC:"texture-compression-bc",TextureCompressionBCSliced3D:"texture-compression-bc-sliced-3d",TextureCompressionETC2:"texture-compression-etc2",TextureCompressionASTC:"texture-compression-astc",TextureCompressionASTCSliced3D:"texture-compression-astc-sliced-3d",TimestampQuery:"timestamp-query",IndirectFirstInstance:"indirect-first-instance",ShaderF16:"shader-f16",RG11B10UFloat:"rg11b10ufloat-renderable",BGRA8UNormStorage:"bgra8unorm-storage",Float32Filterable:"float32-filterable",Float32Blendable:"float32-blendable",ClipDistances:"clip-distances",DualSourceBlending:"dual-source-blending",Subgroups:"subgroups",TextureFormatsTier1:"texture-formats-tier1",TextureFormatsTier2:"texture-formats-tier2"};class tA extends cN{constructor(e,t,r){super(e,t?t.value:null),this.textureNode=t,this.groupNode=r}update(){this.texture=this.textureNode.value}}class rA extends iN{constructor(e,t){super(e,t?t.array:null),this.attribute=t,this.isStorageBuffer=!0}}let sA=0;class iA extends rA{constructor(e,t){super("StorageBuffer_"+sA++,e?e.value:null),this.nodeUniform=e,this.access=e?e.access:zs.READ_WRITE,this.groupNode=t}get buffer(){return this.nodeUniform.value}}class nA extends Nf{constructor(e){super(),this.device=e;this.mipmapSampler=e.createSampler({minFilter:sw}),this.flipYSampler=e.createSampler({minFilter:iw}),this.transferPipelines={},this.flipYPipelines={},this.mipmapVertexShaderModule=e.createShaderModule({label:"mipmapVertex",code:"\nstruct VarysStruct {\n\t@builtin( position ) Position: vec4,\n\t@location( 0 ) vTex : vec2\n};\n\n@vertex\nfn main( @builtin( vertex_index ) vertexIndex : u32 ) -> VarysStruct {\n\n\tvar Varys : VarysStruct;\n\n\tvar pos = array< vec2, 4 >(\n\t\tvec2( -1.0, 1.0 ),\n\t\tvec2( 1.0, 1.0 ),\n\t\tvec2( -1.0, -1.0 ),\n\t\tvec2( 1.0, -1.0 )\n\t);\n\n\tvar tex = array< vec2, 4 >(\n\t\tvec2( 0.0, 0.0 ),\n\t\tvec2( 1.0, 0.0 ),\n\t\tvec2( 0.0, 1.0 ),\n\t\tvec2( 1.0, 1.0 )\n\t);\n\n\tVarys.vTex = tex[ vertexIndex ];\n\tVarys.Position = vec4( pos[ vertexIndex ], 0.0, 1.0 );\n\n\treturn Varys;\n\n}\n"}),this.mipmapFragmentShaderModule=e.createShaderModule({label:"mipmapFragment",code:"\n@group( 0 ) @binding( 0 )\nvar imgSampler : sampler;\n\n@group( 0 ) @binding( 1 )\nvar img : texture_2d;\n\n@fragment\nfn main( @location( 0 ) vTex : vec2 ) -> @location( 0 ) vec4 {\n\n\treturn textureSample( img, imgSampler, vTex );\n\n}\n"}),this.flipYFragmentShaderModule=e.createShaderModule({label:"flipYFragment",code:"\n@group( 0 ) @binding( 0 )\nvar imgSampler : sampler;\n\n@group( 0 ) @binding( 1 )\nvar img : texture_2d;\n\n@fragment\nfn main( @location( 0 ) vTex : vec2 ) -> @location( 0 ) vec4 {\n\n\treturn textureSample( img, imgSampler, vec2( vTex.x, 1.0 - vTex.y ) );\n\n}\n"})}getTransferPipeline(e){let t=this.transferPipelines[e];return void 0===t&&(t=this.device.createRenderPipeline({label:`mipmap-${e}`,vertex:{module:this.mipmapVertexShaderModule,entryPoint:"main"},fragment:{module:this.mipmapFragmentShaderModule,entryPoint:"main",targets:[{format:e}]},primitive:{topology:QN,stripIndexFormat:gS},layout:"auto"}),this.transferPipelines[e]=t),t}getFlipYPipeline(e){let t=this.flipYPipelines[e];return void 0===t&&(t=this.device.createRenderPipeline({label:`flipY-${e}`,vertex:{module:this.mipmapVertexShaderModule,entryPoint:"main"},fragment:{module:this.flipYFragmentShaderModule,entryPoint:"main",targets:[{format:e}]},primitive:{topology:QN,stripIndexFormat:gS},layout:"auto"}),this.flipYPipelines[e]=t),t}flipY(e,t,r=0){const s=t.format,{width:i,height:n}=t.size,a=this.getTransferPipeline(s),o=this.getFlipYPipeline(s),u=this.device.createTexture({size:{width:i,height:n,depthOrArrayLayers:1},format:s,usage:GPUTextureUsage.RENDER_ATTACHMENT|GPUTextureUsage.TEXTURE_BINDING}),l=e.createView({baseMipLevel:0,mipLevelCount:1,dimension:qw,baseArrayLayer:r}),d=u.createView({baseMipLevel:0,mipLevelCount:1,dimension:qw,baseArrayLayer:0}),c=this.device.createCommandEncoder({}),h=(e,t,r)=>{const s=e.getBindGroupLayout(0),i=this.device.createBindGroup({layout:s,entries:[{binding:0,resource:this.flipYSampler},{binding:1,resource:t}]}),n=c.beginRenderPass({colorAttachments:[{view:r,loadOp:uS,storeOp:aS,clearValue:[0,0,0,0]}]});n.setPipeline(e),n.setBindGroup(0,i),n.draw(4,1,0,0),n.end()};h(a,l,d),h(o,d,l),this.device.queue.submit([c.finish()]),u.destroy()}generateMipmaps(e,t,r=0){const s=this.get(e);void 0===s.useCount&&(s.useCount=0,s.layers=[]);const i=s.layers[r]||this._mipmapCreateBundles(e,t,r),n=this.device.createCommandEncoder({});this._mipmapRunBundles(n,i),this.device.queue.submit([n.finish()]),0!==s.useCount&&(s.layers[r]=i),s.useCount++}_mipmapCreateBundles(e,t,r){const s=this.getTransferPipeline(t.format),i=s.getBindGroupLayout(0);let n=e.createView({baseMipLevel:0,mipLevelCount:1,dimension:qw,baseArrayLayer:r});const a=[];for(let o=1;o1;for(let a=0;a]*\s*([a-z_0-9]+(?:<[\s\S]+?>)?)/i,cA=/([a-z_0-9]+)\s*:\s*([a-z_0-9]+(?:<[\s\S]+?>)?)/gi,hA={f32:"float",i32:"int",u32:"uint",bool:"bool","vec2":"vec2","vec2":"ivec2","vec2":"uvec2","vec2":"bvec2",vec2f:"vec2",vec2i:"ivec2",vec2u:"uvec2",vec2b:"bvec2","vec3":"vec3","vec3":"ivec3","vec3":"uvec3","vec3":"bvec3",vec3f:"vec3",vec3i:"ivec3",vec3u:"uvec3",vec3b:"bvec3","vec4":"vec4","vec4":"ivec4","vec4":"uvec4","vec4":"bvec4",vec4f:"vec4",vec4i:"ivec4",vec4u:"uvec4",vec4b:"bvec4","mat2x2":"mat2",mat2x2f:"mat2","mat3x3":"mat3",mat3x3f:"mat3","mat4x4":"mat4",mat4x4f:"mat4",sampler:"sampler",texture_1d:"texture",texture_2d:"texture",texture_2d_array:"texture",texture_multisampled_2d:"cubeTexture",texture_depth_2d:"depthTexture",texture_depth_2d_array:"depthTexture",texture_depth_multisampled_2d:"depthTexture",texture_depth_cube:"depthTexture",texture_depth_cube_array:"depthTexture",texture_3d:"texture3D",texture_cube:"cubeTexture",texture_cube_array:"cubeTexture",texture_storage_1d:"storageTexture",texture_storage_2d:"storageTexture",texture_storage_2d_array:"storageTexture",texture_storage_3d:"storageTexture"};class pA extends Tv{constructor(e){const{type:t,inputs:r,name:s,inputsCode:i,blockCode:n,outputType:a}=(e=>{const t=(e=e.trim()).match(dA);if(null!==t&&4===t.length){const r=t[2],s=[];let i=null;for(;null!==(i=cA.exec(r));)s.push({name:i[1],type:i[2]});const n=[];for(let e=0;e "+this.outputType:"";return`fn ${e} ( ${this.inputsCode.trim()} ) ${t}`+this.blockCode}}class gA extends xv{parseFunction(e){return new pA(e)}}const mA="undefined"!=typeof self?self.GPUShaderStage:{VERTEX:1,FRAGMENT:2,COMPUTE:4},fA={[zs.READ_ONLY]:"read",[zs.WRITE_ONLY]:"write",[zs.READ_WRITE]:"read_write"},yA={[Sr]:"repeat",[Nr]:"clamp",[vr]:"mirror"},bA={vertex:mA?mA.VERTEX:1,fragment:mA?mA.FRAGMENT:2,compute:mA?mA.COMPUTE:4},xA={instance:!0,swizzleAssign:!1,storageBuffer:!0},TA={"^^":"tsl_xor"},_A={float:"f32",int:"i32",uint:"u32",bool:"bool",color:"vec3",vec2:"vec2",ivec2:"vec2",uvec2:"vec2",bvec2:"vec2",vec3:"vec3",ivec3:"vec3",uvec3:"vec3",bvec3:"vec3",vec4:"vec4",ivec4:"vec4",uvec4:"vec4",bvec4:"vec4",mat2:"mat2x2",mat3:"mat3x3",mat4:"mat4x4"},vA={},NA={tsl_xor:new Yb("fn tsl_xor( a : bool, b : bool ) -> bool { return ( a || b ) && !( a && b ); }"),mod_float:new Yb("fn tsl_mod_float( x : f32, y : f32 ) -> f32 { return x - y * floor( x / y ); }"),mod_vec2:new Yb("fn tsl_mod_vec2( x : vec2f, y : vec2f ) -> vec2f { return x - y * floor( x / y ); }"),mod_vec3:new Yb("fn tsl_mod_vec3( x : vec3f, y : vec3f ) -> vec3f { return x - y * floor( x / y ); }"),mod_vec4:new Yb("fn tsl_mod_vec4( x : vec4f, y : vec4f ) -> vec4f { return x - y * floor( x / y ); }"),equals_bool:new Yb("fn tsl_equals_bool( a : bool, b : bool ) -> bool { return a == b; }"),equals_bvec2:new Yb("fn tsl_equals_bvec2( a : vec2f, b : vec2f ) -> vec2 { return vec2( a.x == b.x, a.y == b.y ); }"),equals_bvec3:new Yb("fn tsl_equals_bvec3( a : vec3f, b : vec3f ) -> vec3 { return vec3( a.x == b.x, a.y == b.y, a.z == b.z ); }"),equals_bvec4:new Yb("fn tsl_equals_bvec4( a : vec4f, b : vec4f ) -> vec4 { return vec4( a.x == b.x, a.y == b.y, a.z == b.z, a.w == b.w ); }"),repeatWrapping_float:new Yb("fn tsl_repeatWrapping_float( coord: f32 ) -> f32 { return fract( coord ); }"),mirrorWrapping_float:new Yb("fn tsl_mirrorWrapping_float( coord: f32 ) -> f32 { let mirrored = fract( coord * 0.5 ) * 2.0; return 1.0 - abs( 1.0 - mirrored ); }"),clampWrapping_float:new Yb("fn tsl_clampWrapping_float( coord: f32 ) -> f32 { return clamp( coord, 0.0, 1.0 ); }"),biquadraticTexture:new Yb("\nfn tsl_biquadraticTexture( map : texture_2d, coord : vec2f, iRes : vec2u, level : u32 ) -> vec4f {\n\n\tlet res = vec2f( iRes );\n\n\tlet uvScaled = coord * res;\n\tlet uvWrapping = ( ( uvScaled % res ) + res ) % res;\n\n\t// https://www.shadertoy.com/view/WtyXRy\n\n\tlet uv = uvWrapping - 0.5;\n\tlet iuv = floor( uv );\n\tlet f = fract( uv );\n\n\tlet rg1 = textureLoad( map, vec2u( iuv + vec2( 0.5, 0.5 ) ) % iRes, level );\n\tlet rg2 = textureLoad( map, vec2u( iuv + vec2( 1.5, 0.5 ) ) % iRes, level );\n\tlet rg3 = textureLoad( map, vec2u( iuv + vec2( 0.5, 1.5 ) ) % iRes, level );\n\tlet rg4 = textureLoad( map, vec2u( iuv + vec2( 1.5, 1.5 ) ) % iRes, level );\n\n\treturn mix( mix( rg1, rg2, f.x ), mix( rg3, rg4, f.x ), f.y );\n\n}\n")},SA={dFdx:"dpdx",dFdy:"- dpdy",mod_float:"tsl_mod_float",mod_vec2:"tsl_mod_vec2",mod_vec3:"tsl_mod_vec3",mod_vec4:"tsl_mod_vec4",equals_bool:"tsl_equals_bool",equals_bvec2:"tsl_equals_bvec2",equals_bvec3:"tsl_equals_bvec3",equals_bvec4:"tsl_equals_bvec4",inversesqrt:"inverseSqrt",bitcast:"bitcast"};"undefined"!=typeof navigator&&/Windows/g.test(navigator.userAgent)&&(NA.pow_float=new Yb("fn tsl_pow_float( a : f32, b : f32 ) -> f32 { return select( -pow( -a, b ), pow( a, b ), a > 0.0 ); }"),NA.pow_vec2=new Yb("fn tsl_pow_vec2( a : vec2f, b : vec2f ) -> vec2f { return vec2f( tsl_pow_float( a.x, b.x ), tsl_pow_float( a.y, b.y ) ); }",[NA.pow_float]),NA.pow_vec3=new Yb("fn tsl_pow_vec3( a : vec3f, b : vec3f ) -> vec3f { return vec3f( tsl_pow_float( a.x, b.x ), tsl_pow_float( a.y, b.y ), tsl_pow_float( a.z, b.z ) ); }",[NA.pow_float]),NA.pow_vec4=new Yb("fn tsl_pow_vec4( a : vec4f, b : vec4f ) -> vec4f { return vec4f( tsl_pow_float( a.x, b.x ), tsl_pow_float( a.y, b.y ), tsl_pow_float( a.z, b.z ), tsl_pow_float( a.w, b.w ) ); }",[NA.pow_float]),SA.pow_float="tsl_pow_float",SA.pow_vec2="tsl_pow_vec2",SA.pow_vec3="tsl_pow_vec3",SA.pow_vec4="tsl_pow_vec4");let EA="";!0!==("undefined"!=typeof navigator&&/Firefox|Deno/g.test(navigator.userAgent))&&(EA+="diagnostic( off, derivative_uniformity );\n");class wA extends iv{constructor(e,t){super(e,t,new gA),this.uniformGroups={},this.builtins={},this.directives={},this.scopedArrays=new Map}_generateTextureSample(e,t,r,s,i=this.shaderStage){return"fragment"===i?s?`textureSample( ${t}, ${t}_sampler, ${r}, ${s} )`:`textureSample( ${t}, ${t}_sampler, ${r} )`:this.generateTextureSampleLevel(e,t,r,"0",s)}generateTextureSampleLevel(e,t,r,s,i){return!1===this.isUnfilterable(e)?`textureSampleLevel( ${t}, ${t}_sampler, ${r}, ${s} )`:this.isFilteredTexture(e)?this.generateFilteredTexture(e,t,r,s):this.generateTextureLod(e,t,r,i,s)}generateWrapFunction(e){const t=`tsl_coord_${yA[e.wrapS]}S_${yA[e.wrapT]}_${e.isData3DTexture?"3d":"2d"}T`;let r=vA[t];if(void 0===r){const s=[],i=e.isData3DTexture?"vec3f":"vec2f";let n=`fn ${t}( coord : ${i} ) -> ${i} {\n\n\treturn ${i}(\n`;const a=(e,t)=>{e===Sr?(s.push(NA.repeatWrapping_float),n+=`\t\ttsl_repeatWrapping_float( coord.${t} )`):e===Nr?(s.push(NA.clampWrapping_float),n+=`\t\ttsl_clampWrapping_float( coord.${t} )`):e===vr?(s.push(NA.mirrorWrapping_float),n+=`\t\ttsl_mirrorWrapping_float( coord.${t} )`):(n+=`\t\tcoord.${t}`,console.warn(`WebGPURenderer: Unsupported texture wrap type "${e}" for vertex shader.`))};a(e.wrapS,"x"),n+=",\n",a(e.wrapT,"y"),e.isData3DTexture&&(n+=",\n",a(e.wrapR,"z")),n+="\n\t);\n\n}\n",vA[t]=r=new Yb(n,s)}return r.build(this),t}generateArrayDeclaration(e,t){return`array< ${this.getType(e)}, ${t} >`}generateTextureDimension(e,t,r){const s=this.getDataFromNode(e,this.shaderStage,this.globalCache);void 0===s.dimensionsSnippet&&(s.dimensionsSnippet={});let i=s.dimensionsSnippet[r];if(void 0===s.dimensionsSnippet[r]){let n,a;const{primarySamples:o}=this.renderer.backend.utils.getTextureSampleData(e),u=o>1;a=e.isData3DTexture?"vec3":"vec2",n=u||e.isStorageTexture?t:`${t}${r?`, u32( ${r} )`:""}`,i=new uu(new ju(`textureDimensions( ${n} )`,a)),s.dimensionsSnippet[r]=i,(e.isArrayTexture||e.isDataArrayTexture||e.isData3DTexture)&&(s.arrayLayerCount=new uu(new ju(`textureNumLayers(${t})`,"u32"))),e.isTextureCube&&(s.cubeFaceCount=new uu(new ju("6u","u32")))}return i.build(this)}generateFilteredTexture(e,t,r,s="0u"){this._include("biquadraticTexture");return`tsl_biquadraticTexture( ${t}, ${this.generateWrapFunction(e)}( ${r} ), ${this.generateTextureDimension(e,t,s)}, u32( ${s} ) )`}generateTextureLod(e,t,r,s,i="0u"){const n=this.generateWrapFunction(e),a=this.generateTextureDimension(e,t,i),o=e.isData3DTexture?"vec3":"vec2",u=`${o}( ${n}( ${r} ) * ${o}( ${a} ) )`;return this.generateTextureLoad(e,t,u,s,i)}generateTextureLoad(e,t,r,s,i="0u"){let n;return s?n=`textureLoad( ${t}, ${r}, ${s}, u32( ${i} ) )`:(n=`textureLoad( ${t}, ${r}, u32( ${i} ) )`,this.renderer.backend.compatibilityMode&&e.isDepthTexture&&(n+=".x")),n}generateTextureStore(e,t,r,s,i){let n;return n=s?`textureStore( ${t}, ${r}, ${s}, ${i} )`:`textureStore( ${t}, ${r}, ${i} )`,n}isSampleCompare(e){return!0===e.isDepthTexture&&null!==e.compareFunction}isUnfilterable(e){return"float"!==this.getComponentTypeFromTexture(e)||!this.isAvailable("float32Filterable")&&!0===e.isDataTexture&&e.type===I||!1===this.isSampleCompare(e)&&e.minFilter===v&&e.magFilter===v||this.renderer.backend.utils.getTextureSampleData(e).primarySamples>1}generateTexture(e,t,r,s,i=this.shaderStage){let n=null;return n=this.isUnfilterable(e)?this.generateTextureLod(e,t,r,s,"0",i):this._generateTextureSample(e,t,r,s,i),n}generateTextureGrad(e,t,r,s,i,n=this.shaderStage){if("fragment"===n)return`textureSampleGrad( ${t}, ${t}_sampler, ${r}, ${s[0]}, ${s[1]} )`;console.error(`WebGPURenderer: THREE.TextureNode.gradient() does not support ${n} shader.`)}generateTextureCompare(e,t,r,s,i,n=this.shaderStage){if("fragment"===n)return!0===e.isDepthTexture&&!0===e.isArrayTexture?`textureSampleCompare( ${t}, ${t}_sampler, ${r}, ${i}, ${s} )`:`textureSampleCompare( ${t}, ${t}_sampler, ${r}, ${s} )`;console.error(`WebGPURenderer: THREE.DepthTexture.compareFunction() does not support ${n} shader.`)}generateTextureLevel(e,t,r,s,i){return!1===this.isUnfilterable(e)?`textureSampleLevel( ${t}, ${t}_sampler, ${r}, ${s} )`:this.isFilteredTexture(e)?this.generateFilteredTexture(e,t,r,s):this.generateTextureLod(e,t,r,i,s)}generateTextureBias(e,t,r,s,i,n=this.shaderStage){if("fragment"===n)return`textureSampleBias( ${t}, ${t}_sampler, ${r}, ${s} )`;console.error(`WebGPURenderer: THREE.TextureNode.biasNode does not support ${n} shader.`)}getPropertyName(e,t=this.shaderStage){if(!0===e.isNodeVarying&&!0===e.needsInterpolation){if("vertex"===t)return`varyings.${e.name}`}else if(!0===e.isNodeUniform){const t=e.name,r=e.type;return"texture"===r||"cubeTexture"===r||"storageTexture"===r||"texture3D"===r?t:"buffer"===r||"storageBuffer"===r||"indirectStorageBuffer"===r?this.isCustomStruct(e)?t:t+".value":e.groupNode.name+"."+t}return super.getPropertyName(e)}getOutputStructName(){return"output"}getFunctionOperator(e){const t=TA[e];return void 0!==t?(this._include(t),t):null}getNodeAccess(e,t){return"compute"!==t?!0===e.isAtomic?(console.warn("WebGPURenderer: Atomic operations are only supported in compute shaders."),zs.READ_WRITE):zs.READ_ONLY:e.access}getStorageAccess(e,t){return fA[this.getNodeAccess(e,t)]}getUniformFromNode(e,t,r,s=null){const i=super.getUniformFromNode(e,t,r,s),n=this.getDataFromNode(e,r,this.globalCache);if(void 0===n.uniformGPU){let a;const o=e.groupNode,u=o.name,l=this.getBindGroupArray(u,r);if("texture"===t||"cubeTexture"===t||"storageTexture"===t||"texture3D"===t){let s=null;const n=this.getNodeAccess(e,r);if("texture"===t||"storageTexture"===t?s=!0===e.value.is3DTexture?new fN(i.name,i.node,o,n):new gN(i.name,i.node,o,n):"cubeTexture"===t?s=new mN(i.name,i.node,o,n):"texture3D"===t&&(s=new fN(i.name,i.node,o,n)),s.store=!0===e.isStorageTextureNode,s.setVisibility(bA[r]),!1===this.isUnfilterable(e.value)&&!1===s.store){const e=new tA(`${i.name}_sampler`,i.node,o);e.setVisibility(bA[r]),l.push(e,s),a=[e,s]}else l.push(s),a=[s]}else if("buffer"===t||"storageBuffer"===t||"indirectStorageBuffer"===t){const n=new("buffer"===t?oN:iA)(e,o);n.setVisibility(bA[r]),l.push(n),a=n,i.name=s||"NodeBuffer_"+i.id}else{const e=this.uniformGroups[r]||(this.uniformGroups[r]={});let s=e[u];void 0===s&&(s=new dN(u,o),s.setVisibility(bA[r]),e[u]=s,l.push(s)),a=this.getNodeUniform(i,t),s.addUniform(a)}n.uniformGPU=a}return i}getBuiltin(e,t,r,s=this.shaderStage){const i=this.builtins[s]||(this.builtins[s]=new Map);return!1===i.has(e)&&i.set(e,{name:e,property:t,type:r}),t}hasBuiltin(e,t=this.shaderStage){return void 0!==this.builtins[t]&&this.builtins[t].has(e)}getVertexIndex(){return"vertex"===this.shaderStage?this.getBuiltin("vertex_index","vertexIndex","u32","attribute"):"vertexIndex"}buildFunctionCode(e){const t=e.layout,r=this.flowShaderNode(e),s=[];for(const e of t.inputs)s.push(e.name+" : "+this.getType(e.type));let i=`fn ${t.name}( ${s.join(", ")} ) -> ${this.getType(t.type)} {\n${r.vars}\n${r.code}\n`;return r.result&&(i+=`\treturn ${r.result};\n`),i+="\n}\n",i}getInstanceIndex(){return"vertex"===this.shaderStage?this.getBuiltin("instance_index","instanceIndex","u32","attribute"):"instanceIndex"}getInvocationLocalIndex(){return this.getBuiltin("local_invocation_index","invocationLocalIndex","u32","attribute")}getSubgroupSize(){return this.enableSubGroups(),this.getBuiltin("subgroup_size","subgroupSize","u32","attribute")}getInvocationSubgroupIndex(){return this.enableSubGroups(),this.getBuiltin("subgroup_invocation_id","invocationSubgroupIndex","u32","attribute")}getSubgroupIndex(){return this.enableSubGroups(),this.getBuiltin("subgroup_id","subgroupIndex","u32","attribute")}getDrawIndex(){return null}getFrontFacing(){return this.getBuiltin("front_facing","isFront","bool")}getFragCoord(){return this.getBuiltin("position","fragCoord","vec4")+".xy"}getFragDepth(){return"output."+this.getBuiltin("frag_depth","depth","f32","output")}getClipDistance(){return"varyings.hw_clip_distances"}isFlipY(){return!1}enableDirective(e,t=this.shaderStage){(this.directives[t]||(this.directives[t]=new Set)).add(e)}getDirectives(e){const t=[],r=this.directives[e];if(void 0!==r)for(const e of r)t.push(`enable ${e};`);return t.join("\n")}enableSubGroups(){this.enableDirective("subgroups")}enableSubgroupsF16(){this.enableDirective("subgroups-f16")}enableClipDistances(){this.enableDirective("clip_distances")}enableShaderF16(){this.enableDirective("f16")}enableDualSourceBlending(){this.enableDirective("dual_source_blending")}enableHardwareClipping(e){this.enableClipDistances(),this.getBuiltin("clip_distances","hw_clip_distances",`array`,"vertex")}getBuiltins(e){const t=[],r=this.builtins[e];if(void 0!==r)for(const{name:e,property:s,type:i}of r.values())t.push(`@builtin( ${e} ) ${s} : ${i}`);return t.join(",\n\t")}getScopedArray(e,t,r,s){return!1===this.scopedArrays.has(e)&&this.scopedArrays.set(e,{name:e,scope:t,bufferType:r,bufferCount:s}),e}getScopedArrays(e){if("compute"!==e)return;const t=[];for(const{name:e,scope:r,bufferType:s,bufferCount:i}of this.scopedArrays.values()){const n=this.getType(s);t.push(`var<${r}> ${e}: array< ${n}, ${i} >;`)}return t.join("\n")}getAttributes(e){const t=[];if("compute"===e&&(this.getBuiltin("global_invocation_id","globalId","vec3","attribute"),this.getBuiltin("workgroup_id","workgroupId","vec3","attribute"),this.getBuiltin("local_invocation_id","localId","vec3","attribute"),this.getBuiltin("num_workgroups","numWorkgroups","vec3","attribute"),this.renderer.hasFeature("subgroups")&&(this.enableDirective("subgroups",e),this.getBuiltin("subgroup_size","subgroupSize","u32","attribute"))),"vertex"===e||"compute"===e){const e=this.getBuiltins("attribute");e&&t.push(e);const r=this.getAttributesArray();for(let e=0,s=r.length;e"),t.push(`\t${s+r.name} : ${i}`)}return e.output&&t.push(`\t${this.getBuiltins("output")}`),t.join(",\n")}getStructs(e){let t="";const r=this.structs[e];if(r.length>0){const e=[];for(const t of r){let r=`struct ${t.name} {\n`;r+=this.getStructMembers(t),r+="\n};",e.push(r)}t="\n"+e.join("\n\n")+"\n"}return t}getVar(e,t,r=null){let s=`var ${t} : `;return s+=null!==r?this.generateArrayDeclaration(e,r):this.getType(e),s}getVars(e){const t=[],r=this.vars[e];if(void 0!==r)for(const e of r)t.push(`\t${this.getVar(e.type,e.name,e.count)};`);return`\n${t.join("\n")}\n`}getVaryings(e){const t=[];if("vertex"===e&&this.getBuiltin("position","Vertex","vec4","vertex"),"vertex"===e||"fragment"===e){const r=this.varyings,s=this.vars[e];for(let i=0;ir.value.itemSize;return s&&!i}getUniforms(e){const t=this.uniforms[e],r=[],s=[],i=[],n={};for(const i of t){const t=i.groupNode.name,a=this.bindingsIndexes[t];if("texture"===i.type||"cubeTexture"===i.type||"storageTexture"===i.type||"texture3D"===i.type){const t=i.node.value;let s;!1===this.isUnfilterable(t)&&!0!==i.node.isStorageTextureNode&&(this.isSampleCompare(t)?r.push(`@binding( ${a.binding++} ) @group( ${a.group} ) var ${i.name}_sampler : sampler_comparison;`):r.push(`@binding( ${a.binding++} ) @group( ${a.group} ) var ${i.name}_sampler : sampler;`));let n="";const{primarySamples:o}=this.renderer.backend.utils.getTextureSampleData(t);if(o>1&&(n="_multisampled"),!0===t.isCubeTexture)s="texture_cube";else if(!0===t.isDepthTexture)s=this.renderer.backend.compatibilityMode&&null===t.compareFunction?`texture${n}_2d`:`texture_depth${n}_2d${!0===t.isArrayTexture?"_array":""}`;else if(!0===i.node.isStorageTextureNode){const r=lA(t),n=this.getStorageAccess(i.node,e),a=i.node.value.is3DTexture,o=i.node.value.isArrayTexture;s=`texture_storage_${a?"3d":"2d"+(o?"_array":"")}<${r}, ${n}>`}else if(!0===t.isArrayTexture||!0===t.isDataArrayTexture||!0===t.isCompressedArrayTexture)s="texture_2d_array";else if(!0===t.is3DTexture||!0===t.isData3DTexture)s="texture_3d";else{s=`texture${n}_2d<${this.getComponentTypeFromTexture(t).charAt(0)}32>`}r.push(`@binding( ${a.binding++} ) @group( ${a.group} ) var ${i.name} : ${s};`)}else if("buffer"===i.type||"storageBuffer"===i.type||"indirectStorageBuffer"===i.type){const t=i.node,r=this.getType(t.getNodeType(this)),n=t.bufferCount,o=n>0&&"buffer"===i.type?", "+n:"",u=t.isStorageBufferNode?`storage, ${this.getStorageAccess(t,e)}`:"uniform";if(this.isCustomStruct(i))s.push(`@binding( ${a.binding++} ) @group( ${a.group} ) var<${u}> ${i.name} : ${r};`);else{const e=`\tvalue : array< ${t.isAtomic?`atomic<${r}>`:`${r}`}${o} >`;s.push(this._getWGSLStructBinding(i.name,e,u,a.binding++,a.group))}}else{const e=this.getType(this.getVectorType(i.type)),t=i.groupNode.name;(n[t]||(n[t]={index:a.binding++,id:a.group,snippets:[]})).snippets.push(`\t${i.name} : ${e}`)}}for(const e in n){const t=n[e];i.push(this._getWGSLStructBinding(e,t.snippets.join(",\n"),"uniform",t.index,t.id))}let a=r.join("\n");return a+=s.join("\n"),a+=i.join("\n"),a}buildCode(){const e=null!==this.material?{fragment:{},vertex:{}}:{compute:{}};this.sortBindingGroups();for(const t in e){this.shaderStage=t;const r=e[t];r.uniforms=this.getUniforms(t),r.attributes=this.getAttributes(t),r.varyings=this.getVaryings(t),r.structs=this.getStructs(t),r.vars=this.getVars(t),r.codes=this.getCodes(t),r.directives=this.getDirectives(t),r.scopedArrays=this.getScopedArrays(t);let s="// code\n\n";s+=this.flowCode[t];const i=this.flowNodes[t],n=i[i.length-1],a=n.outputNode,o=void 0!==a&&!0===a.isOutputStructNode;for(const e of i){const i=this.getFlowData(e),u=e.name;if(u&&(s.length>0&&(s+="\n"),s+=`\t// flow -> ${u}\n`),s+=`${i.code}\n\t`,e===n&&"compute"!==t)if(s+="// result\n\n\t","vertex"===t)s+=`varyings.Vertex = ${i.result};`;else if("fragment"===t)if(o)r.returnType=a.getNodeType(this),r.structs+="var output : "+r.returnType+";",s+=`return ${i.result};`;else{let e="\t@location(0) color: vec4";const t=this.getBuiltins("output");t&&(e+=",\n\t"+t),r.returnType="OutputStruct",r.structs+=this._getWGSLStruct("OutputStruct",e),r.structs+="\nvar output : OutputStruct;",s+=`output.color = ${i.result};\n\n\treturn output;`}}r.flow=s}if(this.shaderStage=null,null!==this.material)this.vertexShader=this._getWGSLVertexCode(e.vertex),this.fragmentShader=this._getWGSLFragmentCode(e.fragment);else{const t=this.object.workgroupSize;this.computeShader=this._getWGSLComputeCode(e.compute,t)}}getMethod(e,t=null){let r;return null!==t&&(r=this._getWGSLMethod(e+"_"+t)),void 0===r&&(r=this._getWGSLMethod(e)),r||e}getTernary(e,t,r){return`select( ${r}, ${t}, ${e} )`}getType(e){return _A[e]||e}isAvailable(e){let t=xA[e];return void 0===t&&("float32Filterable"===e?t=this.renderer.hasFeature("float32-filterable"):"clipDistance"===e&&(t=this.renderer.hasFeature("clip-distances")),xA[e]=t),t}_getWGSLMethod(e){return void 0!==NA[e]&&this._include(e),SA[e]}_include(e){const t=NA[e];return t.build(this),null!==this.currentFunctionNode&&this.currentFunctionNode.includes.push(t),t}_getWGSLVertexCode(e){return`${this.getSignature()}\n// directives\n${e.directives}\n\n// structs\n${e.structs}\n\n// uniforms\n${e.uniforms}\n\n// varyings\n${e.varyings}\nvar varyings : VaryingsStruct;\n\n// codes\n${e.codes}\n\n@vertex\nfn main( ${e.attributes} ) -> VaryingsStruct {\n\n\t// vars\n\t${e.vars}\n\n\t// flow\n\t${e.flow}\n\n\treturn varyings;\n\n}\n`}_getWGSLFragmentCode(e){return`${this.getSignature()}\n// global\n${EA}\n\n// structs\n${e.structs}\n\n// uniforms\n${e.uniforms}\n\n// codes\n${e.codes}\n\n@fragment\nfn main( ${e.varyings} ) -> ${e.returnType} {\n\n\t// vars\n\t${e.vars}\n\n\t// flow\n\t${e.flow}\n\n}\n`}_getWGSLComputeCode(e,t){const[r,s,i]=t;return`${this.getSignature()}\n// directives\n${e.directives}\n\n// system\nvar instanceIndex : u32;\n\n// locals\n${e.scopedArrays}\n\n// structs\n${e.structs}\n\n// uniforms\n${e.uniforms}\n\n// codes\n${e.codes}\n\n@compute @workgroup_size( ${r}, ${s}, ${i} )\nfn main( ${e.attributes} ) {\n\n\t// system\n\tinstanceIndex = globalId.x\n\t\t+ globalId.y * ( ${r} * numWorkgroups.x )\n\t\t+ globalId.z * ( ${r} * numWorkgroups.x ) * ( ${s} * numWorkgroups.y );\n\n\t// vars\n\t${e.vars}\n\n\t// flow\n\t${e.flow}\n\n}\n`}_getWGSLStruct(e,t){return`\nstruct ${e} {\n${t}\n};`}_getWGSLStructBinding(e,t,r,s=0,i=0){const n=e+"Struct";return`${this._getWGSLStruct(n,t)}\n@binding( ${s} ) @group( ${i} )\nvar<${r}> ${e} : ${n};`}}class AA{constructor(e){this.backend=e}getCurrentDepthStencilFormat(e){let t;return null!==e.depthTexture?t=this.getTextureFormatGPU(e.depthTexture):e.depth&&e.stencil?t=JS:e.depth&&(t=ZS),t}getTextureFormatGPU(e){return this.backend.get(e).format}getTextureSampleData(e){let t;if(e.isFramebufferTexture)t=1;else if(e.isDepthTexture&&!e.renderTarget){const e=this.backend.renderer,r=e.getRenderTarget();t=r?r.samples:e.samples}else e.renderTarget&&(t=e.renderTarget.samples);t=t||1;const r=t>1&&null!==e.renderTarget&&!0!==e.isDepthTexture&&!0!==e.isFramebufferTexture;return{samples:t,primarySamples:r?1:t,isMSAA:r}}getCurrentColorFormat(e){let t;return t=null!==e.textures?this.getTextureFormatGPU(e.textures[0]):this.getPreferredCanvasFormat(),t}getCurrentColorSpace(e){return null!==e.textures?e.textures[0].colorSpace:this.backend.renderer.outputColorSpace}getPrimitiveTopology(e,t){return e.isPoints?qN:e.isLineSegments||e.isMesh&&!0===t.wireframe?XN:e.isLine?KN:e.isMesh?YN:void 0}getSampleCount(e){return e>=4?4:1}getSampleCountRenderContext(e){return null!==e.textures?this.getSampleCount(e.sampleCount):this.getSampleCount(this.backend.renderer.samples)}getPreferredCanvasFormat(){const e=this.backend.parameters.outputType;if(void 0===e)return navigator.gpu.getPreferredCanvasFormat();if(e===Ce)return VS;if(e===ce)return qS;throw new Error("Unsupported outputType")}}const RA=new Map([[Int8Array,["sint8","snorm8"]],[Uint8Array,["uint8","unorm8"]],[Int16Array,["sint16","snorm16"]],[Uint16Array,["uint16","unorm16"]],[Int32Array,["sint32","snorm32"]],[Uint32Array,["uint32","unorm32"]],[Float32Array,["float32"]]]);"undefined"!=typeof Float16Array&&RA.set(Float16Array,["float16"]);const CA=new Map([[ze,["float16"]]]),MA=new Map([[Int32Array,"sint32"],[Int16Array,"sint32"],[Uint32Array,"uint32"],[Uint16Array,"uint32"],[Float32Array,"float32"]]);class PA{constructor(e){this.backend=e}createAttribute(e,t){const r=this._getBufferAttribute(e),s=this.backend,i=s.get(r);let n=i.buffer;if(void 0===n){const a=s.device;let o=r.array;if(!1===e.normalized)if(o.constructor===Int16Array||o.constructor===Int8Array)o=new Int32Array(o);else if((o.constructor===Uint16Array||o.constructor===Uint8Array)&&(o=new Uint32Array(o),t&GPUBufferUsage.INDEX))for(let e=0;e1&&(s.multisampled=!0,r.texture.isDepthTexture||(s.sampleType=Gw)),r.texture.isDepthTexture)t.compatibilityMode&&null===r.texture.compareFunction?s.sampleType=Gw:s.sampleType=zw;else if(r.texture.isDataTexture||r.texture.isDataArrayTexture||r.texture.isData3DTexture){const e=r.texture.type;e===_?s.sampleType=Hw:e===T?s.sampleType=$w:e===I&&(this.backend.hasFeature("float32-filterable")?s.sampleType=kw:s.sampleType=Gw)}r.isSampledCubeTexture?s.viewDimension=Kw:r.texture.isArrayTexture||r.texture.isDataArrayTexture||r.texture.isCompressedArrayTexture?s.viewDimension=Xw:r.isSampledTexture3D&&(s.viewDimension=Yw),e.texture=s}else if(r.isSampler){const s={};r.texture.isDepthTexture&&(null!==r.texture.compareFunction?s.type=Ow:t.compatibilityMode&&(s.type=Uw)),e.sampler=s}else console.error(`WebGPUBindingUtils: Unsupported binding "${r}".`);s.push(e)}return r.createBindGroupLayout({entries:s})}createBindings(e,t,r,s=0){const{backend:i,bindGroupLayoutCache:n}=this,a=i.get(e);let o,u=n.get(e.bindingsReference);void 0===u&&(u=this.createBindingsLayout(e),n.set(e.bindingsReference,u)),r>0&&(void 0===a.groups&&(a.groups=[],a.versions=[]),a.versions[r]===s&&(o=a.groups[r])),void 0===o&&(o=this.createBindGroup(e,u),r>0&&(a.groups[r]=o,a.versions[r]=s)),a.group=o,a.layout=u}updateBinding(e){const t=this.backend,r=t.device,s=e.buffer,i=t.get(e).buffer;r.queue.writeBuffer(i,0,s,0)}createBindGroupIndex(e,t){const r=this.backend.device,s=GPUBufferUsage.UNIFORM|GPUBufferUsage.COPY_DST,i=e[0],n=r.createBuffer({label:"bindingCameraIndex_"+i,size:16,usage:s});r.queue.writeBuffer(n,0,e,0);const a=[{binding:0,resource:{buffer:n}}];return r.createBindGroup({label:"bindGroupCameraIndex_"+i,layout:t,entries:a})}createBindGroup(e,t){const r=this.backend,s=r.device;let i=0;const n=[];for(const t of e.bindings){if(t.isUniformBuffer){const e=r.get(t);if(void 0===e.buffer){const r=t.byteLength,i=GPUBufferUsage.UNIFORM|GPUBufferUsage.COPY_DST,n=s.createBuffer({label:"bindingBuffer_"+t.name,size:r,usage:i});e.buffer=n}n.push({binding:i,resource:{buffer:e.buffer}})}else if(t.isStorageBuffer){const e=r.get(t);if(void 0===e.buffer){const s=t.attribute;e.buffer=r.get(s).buffer}n.push({binding:i,resource:{buffer:e.buffer}})}else if(t.isSampledTexture){const e=r.get(t.texture);let a;if(void 0!==e.externalTexture)a=s.importExternalTexture({source:e.externalTexture});else{const r=t.store?1:e.texture.mipLevelCount;let s=`view-${e.texture.width}-${e.texture.height}`;if(e.texture.depthOrArrayLayers>1&&(s+=`-${e.texture.depthOrArrayLayers}`),s+=`-${r}`,a=e[s],void 0===a){const i=Qw;let n;n=t.isSampledCubeTexture?Kw:t.isSampledTexture3D?Yw:t.texture.isArrayTexture||t.texture.isDataArrayTexture||t.texture.isCompressedArrayTexture?Xw:qw,a=e[s]=e.texture.createView({aspect:i,dimension:n,mipLevelCount:r})}}n.push({binding:i,resource:a})}else if(t.isSampler){const e=r.get(t.texture);n.push({binding:i,resource:e.sampler})}i++}return s.createBindGroup({label:"bindGroup_"+e.name,layout:t,entries:n})}}class FA{constructor(e){this.backend=e,this._activePipelines=new WeakMap}setPipeline(e,t){this._activePipelines.get(e)!==t&&(e.setPipeline(t),this._activePipelines.set(e,t))}_getSampleCount(e){return this.backend.utils.getSampleCountRenderContext(e)}createRenderPipeline(e,t){const{object:r,material:s,geometry:i,pipeline:n}=e,{vertexProgram:a,fragmentProgram:o}=n,u=this.backend,l=u.device,d=u.utils,c=u.get(n),h=[];for(const t of e.getBindings()){const e=u.get(t);h.push(e.layout)}const p=u.attributeUtils.createShaderVertexBuffers(e);let g;s.blending===H||s.blending===k&&!1===s.transparent||(g=this._getBlending(s));let m={};!0===s.stencilWrite&&(m={compare:this._getStencilCompare(s),failOp:this._getStencilOperation(s.stencilFail),depthFailOp:this._getStencilOperation(s.stencilZFail),passOp:this._getStencilOperation(s.stencilZPass)});const f=this._getColorWriteMask(s),y=[];if(null!==e.context.textures){const t=e.context.textures;for(let e=0;e1},layout:l.createPipelineLayout({bindGroupLayouts:h})},E={},w=e.context.depth,A=e.context.stencil;if(!0!==w&&!0!==A||(!0===w&&(E.format=v,E.depthWriteEnabled=s.depthWrite,E.depthCompare=_),!0===A&&(E.stencilFront=m,E.stencilBack={},E.stencilReadMask=s.stencilFuncMask,E.stencilWriteMask=s.stencilWriteMask),!0===s.polygonOffset&&(E.depthBias=s.polygonOffsetUnits,E.depthBiasSlopeScale=s.polygonOffsetFactor,E.depthBiasClamp=0),S.depthStencil=E),null===t)c.pipeline=l.createRenderPipeline(S);else{const e=new Promise(e=>{l.createRenderPipelineAsync(S).then(t=>{c.pipeline=t,e()})});t.push(e)}}createBundleEncoder(e,t="renderBundleEncoder"){const r=this.backend,{utils:s,device:i}=r,n=s.getCurrentDepthStencilFormat(e),a={label:t,colorFormats:[s.getCurrentColorFormat(e)],depthStencilFormat:n,sampleCount:this._getSampleCount(e)};return i.createRenderBundleEncoder(a)}createComputePipeline(e,t){const r=this.backend,s=r.device,i=r.get(e.computeProgram).module,n=r.get(e),a=[];for(const e of t){const t=r.get(e);a.push(t.layout)}n.pipeline=s.createComputePipeline({compute:i,layout:s.createPipelineLayout({bindGroupLayouts:a})})}_getBlending(e){let t,r;const s=e.blending,i=e.blendSrc,n=e.blendDst,a=e.blendEquation;if(s===qe){const s=null!==e.blendSrcAlpha?e.blendSrcAlpha:i,o=null!==e.blendDstAlpha?e.blendDstAlpha:n,u=null!==e.blendEquationAlpha?e.blendEquationAlpha:a;t={srcFactor:this._getBlendFactor(i),dstFactor:this._getBlendFactor(n),operation:this._getBlendOperation(a)},r={srcFactor:this._getBlendFactor(s),dstFactor:this._getBlendFactor(o),operation:this._getBlendOperation(u)}}else{const i=(e,s,i,n)=>{t={srcFactor:e,dstFactor:s,operation:bw},r={srcFactor:i,dstFactor:n,operation:bw}};if(e.premultipliedAlpha)switch(s){case k:i(aw,dw,aw,dw);break;case Bt:i(aw,aw,aw,aw);break;case Pt:i(nw,uw,nw,aw);break;case Mt:i(cw,dw,nw,aw)}else switch(s){case k:i(lw,dw,aw,dw);break;case Bt:i(lw,aw,aw,aw);break;case Pt:console.error("THREE.WebGPURenderer: SubtractiveBlending requires material.premultipliedAlpha = true");break;case Mt:console.error("THREE.WebGPURenderer: MultiplyBlending requires material.premultipliedAlpha = true")}}if(void 0!==t&&void 0!==r)return{color:t,alpha:r};console.error("THREE.WebGPURenderer: Invalid blending: ",s)}_getBlendFactor(e){let t;switch(e){case Ke:t=nw;break;case wt:t=aw;break;case Et:t=ow;break;case Tt:t=uw;break;case St:t=lw;break;case xt:t=dw;break;case vt:t=cw;break;case bt:t=hw;break;case _t:t=pw;break;case yt:t=gw;break;case Nt:t=mw;break;case 211:t=fw;break;case 212:t=yw;break;default:console.error("THREE.WebGPURenderer: Blend factor not supported.",e)}return t}_getStencilCompare(e){let t;const r=e.stencilFunc;switch(r){case zr:t=ZN;break;case Gr:t=nS;break;case kr:t=JN;break;case Or:t=tS;break;case Ur:t=eS;break;case Vr:t=iS;break;case Dr:t=rS;break;case Ir:t=sS;break;default:console.error("THREE.WebGPURenderer: Invalid stencil function.",r)}return t}_getStencilOperation(e){let t;switch(e){case Yr:t=Ew;break;case Kr:t=ww;break;case Xr:t=Aw;break;case qr:t=Rw;break;case jr:t=Cw;break;case Wr:t=Mw;break;case $r:t=Pw;break;case Hr:t=Bw;break;default:console.error("THREE.WebGPURenderer: Invalid stencil operation.",t)}return t}_getBlendOperation(e){let t;switch(e){case Xe:t=bw;break;case ft:t=xw;break;case mt:t=Tw;break;case Zr:t=_w;break;case Qr:t=vw;break;default:console.error("THREE.WebGPUPipelineUtils: Blend equation not supported.",e)}return t}_getPrimitiveState(e,t,r){const s={},i=this.backend.utils;switch(s.topology=i.getPrimitiveTopology(e,r),null!==t.index&&!0===e.isLine&&!0!==e.isLineSegments&&(s.stripIndexFormat=t.index.array instanceof Uint16Array?pS:gS),r.side){case je:s.frontFace=lS,s.cullMode=hS;break;case S:s.frontFace=lS,s.cullMode=cS;break;case E:s.frontFace=lS,s.cullMode=dS;break;default:console.error("THREE.WebGPUPipelineUtils: Unknown material.side value.",r.side)}return s}_getColorWriteMask(e){return!0===e.colorWrite?Sw:Nw}_getDepthCompare(e){let t;if(!1===e.depthTest)t=nS;else{const r=e.depthFunc;switch(r){case kt:t=ZN;break;case Ot:t=nS;break;case Ut:t=JN;break;case Vt:t=tS;break;case Dt:t=eS;break;case It:t=iS;break;case Lt:t=rS;break;case Ft:t=sS;break;default:console.error("THREE.WebGPUPipelineUtils: Invalid depth function.",r)}}return t}}class LA extends $N{constructor(e,t,r=2048){super(r),this.device=e,this.type=t,this.querySet=this.device.createQuerySet({type:"timestamp",count:this.maxQueries,label:`queryset_global_timestamp_${t}`});const s=8*this.maxQueries;this.resolveBuffer=this.device.createBuffer({label:`buffer_timestamp_resolve_${t}`,size:s,usage:GPUBufferUsage.QUERY_RESOLVE|GPUBufferUsage.COPY_SRC}),this.resultBuffer=this.device.createBuffer({label:`buffer_timestamp_result_${t}`,size:s,usage:GPUBufferUsage.COPY_DST|GPUBufferUsage.MAP_READ})}allocateQueriesForContext(e){if(!this.trackTimestamp||this.isDisposed)return null;if(this.currentQueryIndex+2>this.maxQueries)return pt(`WebGPUTimestampQueryPool [${this.type}]: Maximum number of queries exceeded, when using trackTimestamp it is necessary to resolves the queries via renderer.resolveTimestampsAsync( THREE.TimestampQuery.${this.type.toUpperCase()} ).`),null;const t=this.currentQueryIndex;return this.currentQueryIndex+=2,this.queryOffsets.set(e.id,t),t}async resolveQueriesAsync(){if(!this.trackTimestamp||0===this.currentQueryIndex||this.isDisposed)return this.lastValue;if(this.pendingResolve)return this.pendingResolve;this.pendingResolve=this._resolveQueries();try{return await this.pendingResolve}finally{this.pendingResolve=null}}async _resolveQueries(){if(this.isDisposed)return this.lastValue;try{if("unmapped"!==this.resultBuffer.mapState)return this.lastValue;const e=new Map(this.queryOffsets),t=this.currentQueryIndex,r=8*t;this.currentQueryIndex=0,this.queryOffsets.clear();const s=this.device.createCommandEncoder();s.resolveQuerySet(this.querySet,0,t,this.resolveBuffer,0),s.copyBufferToBuffer(this.resolveBuffer,0,this.resultBuffer,0,r);const i=s.finish();if(this.device.queue.submit([i]),"unmapped"!==this.resultBuffer.mapState)return this.lastValue;if(await this.resultBuffer.mapAsync(GPUMapMode.READ,0,r),this.isDisposed)return"mapped"===this.resultBuffer.mapState&&this.resultBuffer.unmap(),this.lastValue;const n=new BigUint64Array(this.resultBuffer.getMappedRange(0,r));let a=0;for(const[,t]of e){const e=n[t],r=n[t+1];a+=Number(r-e)/1e6}return this.resultBuffer.unmap(),this.lastValue=a,a}catch(e){return console.error("Error resolving queries:",e),"mapped"===this.resultBuffer.mapState&&this.resultBuffer.unmap(),this.lastValue}}async dispose(){if(!this.isDisposed){if(this.isDisposed=!0,this.pendingResolve)try{await this.pendingResolve}catch(e){console.error("Error waiting for pending resolve:",e)}if(this.resultBuffer&&"mapped"===this.resultBuffer.mapState)try{this.resultBuffer.unmap()}catch(e){console.error("Error unmapping buffer:",e)}this.querySet&&(this.querySet.destroy(),this.querySet=null),this.resolveBuffer&&(this.resolveBuffer.destroy(),this.resolveBuffer=null),this.resultBuffer&&(this.resultBuffer.destroy(),this.resultBuffer=null),this.queryOffsets.clear(),this.pendingResolve=null}}}class IA extends wN{constructor(e={}){super(e),this.isWebGPUBackend=!0,this.parameters.alpha=void 0===e.alpha||e.alpha,this.parameters.compatibilityMode=void 0!==e.compatibilityMode&&e.compatibilityMode,this.parameters.requiredLimits=void 0===e.requiredLimits?{}:e.requiredLimits,this.compatibilityMode=this.parameters.compatibilityMode,this.device=null,this.context=null,this.colorBuffer=null,this.defaultRenderPassdescriptor=null,this.utils=new AA(this),this.attributeUtils=new PA(this),this.bindingUtils=new BA(this),this.pipelineUtils=new FA(this),this.textureUtils=new uA(this),this.occludedResolveCache=new Map}async init(e){await super.init(e);const t=this.parameters;let r;if(void 0===t.device){const e={powerPreference:t.powerPreference,featureLevel:t.compatibilityMode?"compatibility":void 0},s="undefined"!=typeof navigator?await navigator.gpu.requestAdapter(e):null;if(null===s)throw new Error("WebGPUBackend: Unable to create WebGPU adapter.");const i=Object.values(eA),n=[];for(const e of i)s.features.has(e)&&n.push(e);const a={requiredFeatures:n,requiredLimits:t.requiredLimits};r=await s.requestDevice(a)}else r=t.device;r.lost.then(t=>{const r={api:"WebGPU",message:t.message||"Unknown reason",reason:t.reason||null,originalEvent:t};e.onDeviceLost(r)});const s=void 0!==t.context?t.context:e.domElement.getContext("webgpu");this.device=r,this.context=s;const i=t.alpha?"premultiplied":"opaque",n=c.getToneMappingMode(this.renderer.outputColorSpace);this.context.configure({device:this.device,format:this.utils.getPreferredCanvasFormat(),usage:GPUTextureUsage.RENDER_ATTACHMENT|GPUTextureUsage.COPY_SRC,alphaMode:i,toneMapping:{mode:n}}),this.trackTimestamp=this.trackTimestamp&&this.hasFeature(eA.TimestampQuery),this.updateSize()}get coordinateSystem(){return d}async getArrayBufferAsync(e){return await this.attributeUtils.getArrayBufferAsync(e)}getContext(){return this.context}_getDefaultRenderPassDescriptor(){let e=this.defaultRenderPassdescriptor;if(null===e){const t=this.renderer;e={colorAttachments:[{view:null}]},!0!==this.renderer.depth&&!0!==this.renderer.stencil||(e.depthStencilAttachment={view:this.textureUtils.getDepthBuffer(t.depth,t.stencil).createView()});const r=e.colorAttachments[0];this.renderer.samples>0?r.view=this.colorBuffer.createView():r.resolveTarget=void 0,this.defaultRenderPassdescriptor=e}const t=e.colorAttachments[0];return this.renderer.samples>0?t.resolveTarget=this.context.getCurrentTexture().createView():t.view=this.context.getCurrentTexture().createView(),e}_isRenderCameraDepthArray(e){return e.depthTexture&&e.depthTexture.image.depth>1&&e.camera.isArrayCamera}_getRenderPassDescriptor(e,t={}){const r=e.renderTarget,s=this.get(r);let i=s.descriptors;void 0!==i&&s.width===r.width&&s.height===r.height&&s.activeMipmapLevel===e.activeMipmapLevel&&s.activeCubeFace===e.activeCubeFace&&s.samples===r.samples||(i={},s.descriptors=i);const n=e.getCacheKey();let a=i[n];if(void 0===a){const t=e.textures,o=[];let u;const l=this._isRenderCameraDepthArray(e);for(let s=0;s1)if(!0===l){const t=e.camera.cameras;for(let e=0;e0&&(t.currentOcclusionQuerySet&&t.currentOcclusionQuerySet.destroy(),t.currentOcclusionQueryBuffer&&t.currentOcclusionQueryBuffer.destroy(),t.currentOcclusionQuerySet=t.occlusionQuerySet,t.currentOcclusionQueryBuffer=t.occlusionQueryBuffer,t.currentOcclusionQueryObjects=t.occlusionQueryObjects,i=r.createQuerySet({type:"occlusion",count:s,label:`occlusionQuerySet_${e.id}`}),t.occlusionQuerySet=i,t.occlusionQueryIndex=0,t.occlusionQueryObjects=new Array(s),t.lastOcclusionObject=null),n=null===e.textures?this._getDefaultRenderPassDescriptor():this._getRenderPassDescriptor(e,{loadOp:oS}),this.initTimestampQuery(e,n),n.occlusionQuerySet=i;const a=n.depthStencilAttachment;if(null!==e.textures){const t=n.colorAttachments;for(let r=0;r0&&t.currentPass.executeBundles(t.renderBundles),r>t.occlusionQueryIndex&&t.currentPass.endOcclusionQuery();const s=t.encoder;if(!0===this._isRenderCameraDepthArray(e)){const r=[];for(let e=0;e0){const s=8*r;let i=this.occludedResolveCache.get(s);void 0===i&&(i=this.device.createBuffer({size:s,usage:GPUBufferUsage.QUERY_RESOLVE|GPUBufferUsage.COPY_SRC}),this.occludedResolveCache.set(s,i));const n=this.device.createBuffer({size:s,usage:GPUBufferUsage.COPY_DST|GPUBufferUsage.MAP_READ});t.encoder.resolveQuerySet(t.occlusionQuerySet,0,r,i,0),t.encoder.copyBufferToBuffer(i,0,n,0,s),t.occlusionQueryBuffer=n,this.resolveOccludedAsync(e)}if(this.device.queue.submit([t.encoder.finish()]),null!==e.textures){const t=e.textures;for(let e=0;ea&&(u[0]=Math.min(i,a),u[1]=Math.ceil(i/a)),n.dispatchSize=u}u=n.dispatchSize}else u=i;a.dispatchWorkgroups(u[0],u[1]||1,u[2]||1)}finishCompute(e){const t=this.get(e);t.passEncoderGPU.end(),this.device.queue.submit([t.cmdEncoderGPU.finish()])}async waitForGPU(){await this.device.queue.onSubmittedWorkDone()}draw(e,t){const{object:r,material:s,context:i,pipeline:n}=e,a=e.getBindings(),o=this.get(i),u=this.get(n).pipeline,l=e.getIndex(),d=null!==l,c=e.getDrawParameters();if(null===c)return;const h=(t,r)=>{this.pipelineUtils.setPipeline(t,u),r.pipeline=u;const n=r.bindingGroups;for(let e=0,r=a.length;e{if(h(s,i),!0===r.isBatchedMesh){const e=r._multiDrawStarts,i=r._multiDrawCounts,n=r._multiDrawCount,a=r._multiDrawInstances;null!==a&&pt("THREE.WebGPUBackend: renderMultiDrawInstances has been deprecated and will be removed in r184. Append to renderMultiDraw arguments and use indirection.");for(let o=0;o1?0:o;!0===d?s.drawIndexed(i[o],n,e[o]/l.array.BYTES_PER_ELEMENT,0,u):s.draw(i[o],n,e[o],u),t.update(r,i[o],n)}}else if(!0===d){const{vertexCount:i,instanceCount:n,firstVertex:a}=c,o=e.getIndirect();if(null!==o){const e=this.get(o).buffer;s.drawIndexedIndirect(e,0)}else s.drawIndexed(i,n,a,0,0);t.update(r,i,n)}else{const{vertexCount:i,instanceCount:n,firstVertex:a}=c,o=e.getIndirect();if(null!==o){const e=this.get(o).buffer;s.drawIndirect(e,0)}else s.draw(i,n,a,0);t.update(r,i,n)}};if(e.camera.isArrayCamera&&e.camera.cameras.length>0){const t=this.get(e.camera),s=e.camera.cameras,n=e.getBindingGroup("cameraIndex");if(void 0===t.indexesGPU||t.indexesGPU.length!==s.length){const e=this.get(n),r=[],i=new Uint32Array([0,0,0,0]);for(let t=0,n=s.length;t(console.warn("THREE.WebGPURenderer: WebGPU is not available, running under WebGL2 backend."),new jN(e)));super(new t(e),e),this.library=new UA,this.isWebGPURenderer=!0}}class kA extends hs{constructor(){super(),this.isBundleGroup=!0,this.type="BundleGroup",this.static=!0,this.version=0}set needsUpdate(e){!0===e&&this.version++}}class GA{constructor(e,t=cn(0,0,1,1)){this.renderer=e,this.outputNode=t,this.outputColorTransform=!0,this.needsUpdate=!0;const r=new _p;r.name="PostProcessing",this._quadMesh=new Yy(r),this._context=null}render(){const e=this.renderer;this._update(),null!==this._context.onBeforePostProcessing&&this._context.onBeforePostProcessing();const t=e.toneMapping,r=e.outputColorSpace;e.toneMapping=p,e.outputColorSpace=c.workingColorSpace;const s=e.xr.enabled;e.xr.enabled=!1,this._quadMesh.render(e),e.xr.enabled=s,e.toneMapping=t,e.outputColorSpace=r,null!==this._context.onAfterPostProcessing&&this._context.onAfterPostProcessing()}get context(){return this._context}dispose(){this._quadMesh.material.dispose()}_update(){if(!0===this.needsUpdate){const e=this.renderer,t=e.toneMapping,r=e.outputColorSpace,s={postProcessing:this,onBeforePostProcessing:null,onAfterPostProcessing:null};let i=this.outputNode;!0===this.outputColorTransform?(i=i.context(s),i=Yu(i,t,r)):(s.toneMapping=t,s.outputColorSpace=r,i=i.context(s)),this._context=s,this._quadMesh.material.fragmentNode=i,this._quadMesh.material.needsUpdate=!0,this.needsUpdate=!1}}async renderAsync(){this._update(),null!==this._context.onBeforePostProcessing&&this._context.onBeforePostProcessing();const e=this.renderer,t=e.toneMapping,r=e.outputColorSpace;e.toneMapping=p,e.outputColorSpace=c.workingColorSpace;const s=e.xr.enabled;e.xr.enabled=!1,await this._quadMesh.renderAsync(e),e.xr.enabled=s,e.toneMapping=t,e.outputColorSpace=r,null!==this._context.onAfterPostProcessing&&this._context.onAfterPostProcessing()}}class zA extends x{constructor(e=1,t=1){super(),this.image={width:e,height:t},this.magFilter=Y,this.minFilter=Y,this.isStorageTexture=!0}setSize(e,t){this.image.width===e&&this.image.height===t||(this.image.width=e,this.image.height=t,this.dispose())}}class HA extends ob{constructor(e,t){super(e,t,Uint32Array),this.isIndirectStorageBufferAttribute=!0}}class $A extends ps{constructor(e){super(e),this.textures={},this.nodes={}}load(e,t,r,s){const i=new gs(this.manager);i.setPath(this.path),i.setRequestHeader(this.requestHeader),i.setWithCredentials(this.withCredentials),i.load(e,r=>{try{t(this.parse(JSON.parse(r)))}catch(t){s?s(t):console.error(t),this.manager.itemError(e)}},r,s)}parseNodes(e){const t={};if(void 0!==e){for(const r of e){const{uuid:e,type:s}=r;t[e]=this.createNodeFromType(s),t[e].uuid=e}const r={nodes:t,textures:this.textures};for(const s of e){s.meta=r;t[s.uuid].deserialize(s),delete s.meta}}return t}parse(e){const t=this.createNodeFromType(e.type);t.uuid=e.uuid;const r={nodes:this.parseNodes(e.nodes),textures:this.textures};return e.meta=r,t.deserialize(e),delete e.meta,t}setTextures(e){return this.textures=e,this}setNodes(e){return this.nodes=e,this}createNodeFromType(e){return void 0===this.nodes[e]?(console.error("THREE.NodeLoader: Node type not found:",e),Zi()):Vi(new this.nodes[e])}}class WA extends ms{constructor(e){super(e),this.nodes={},this.nodeMaterials={}}parse(e){const t=super.parse(e),r=this.nodes,s=e.inputNodes;for(const e in s){const i=s[e];t[e]=r[i]}return t}setNodes(e){return this.nodes=e,this}setNodeMaterials(e){return this.nodeMaterials=e,this}createMaterialFromType(e){const t=this.nodeMaterials[e];return void 0!==t?new t:super.createMaterialFromType(e)}}class jA extends fs{constructor(e){super(e),this.nodes={},this.nodeMaterials={},this._nodesJSON=null}setNodes(e){return this.nodes=e,this}setNodeMaterials(e){return this.nodeMaterials=e,this}parse(e,t){this._nodesJSON=e.nodes;const r=super.parse(e,t);return this._nodesJSON=null,r}parseNodes(e,t){if(void 0!==e){const r=new $A;return r.setNodes(this.nodes),r.setTextures(t),r.parseNodes(e)}return{}}parseMaterials(e,t){const r={};if(void 0!==e){const s=this.parseNodes(this._nodesJSON,t),i=new WA;i.setTextures(t),i.setNodes(s),i.setNodeMaterials(this.nodeMaterials);for(let t=0,s=e.length;t