typegpu 0.5.9 → 0.6.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (44) hide show
  1. package/chunk-APTRHY5Y.js +41 -0
  2. package/chunk-APTRHY5Y.js.map +1 -0
  3. package/chunk-RC26P3MP.cjs +2 -0
  4. package/chunk-RC26P3MP.cjs.map +1 -0
  5. package/{chunk-CGVYLGBG.js → chunk-RK6TMFVW.js} +2 -2
  6. package/chunk-S62QJDM6.js +2 -0
  7. package/chunk-S62QJDM6.js.map +1 -0
  8. package/chunk-TG4A6AM3.cjs +2 -0
  9. package/chunk-TG4A6AM3.cjs.map +1 -0
  10. package/chunk-UMHCZDPA.cjs +41 -0
  11. package/chunk-UMHCZDPA.cjs.map +1 -0
  12. package/data/index.cjs +1 -1
  13. package/data/index.cjs.map +1 -1
  14. package/data/index.d.cts +30 -4
  15. package/data/index.d.ts +30 -4
  16. package/data/index.js +1 -1
  17. package/index.cjs +20 -20
  18. package/index.cjs.map +1 -1
  19. package/index.d.cts +62 -11
  20. package/index.d.ts +62 -11
  21. package/index.js +20 -20
  22. package/index.js.map +1 -1
  23. package/{matrix-BnXitNJ7.d.cts → matrix-BN6ObiMv.d.cts} +1 -1
  24. package/{matrix-BULDDGYa.d.ts → matrix-S8W4dk8I.d.ts} +1 -1
  25. package/package.json +1 -1
  26. package/std/index.cjs +1 -1
  27. package/std/index.cjs.map +1 -1
  28. package/std/index.d.cts +2 -2
  29. package/std/index.d.ts +2 -2
  30. package/std/index.js +1 -1
  31. package/{tgpuComputeFn-BxPDI5hQ.d.ts → tgpuComputeFn-DOUjhQua.d.cts} +370 -157
  32. package/{tgpuComputeFn-BxPDI5hQ.d.cts → tgpuComputeFn-DOUjhQua.d.ts} +370 -157
  33. package/chunk-734H4JWF.js +0 -2
  34. package/chunk-734H4JWF.js.map +0 -1
  35. package/chunk-BJSN5UVV.cjs +0 -41
  36. package/chunk-BJSN5UVV.cjs.map +0 -1
  37. package/chunk-BZVU4Q6A.cjs +0 -2
  38. package/chunk-BZVU4Q6A.cjs.map +0 -1
  39. package/chunk-CDUKTYES.cjs +0 -2
  40. package/chunk-CDUKTYES.cjs.map +0 -1
  41. package/chunk-SWJVYRFM.js +0 -41
  42. package/chunk-SWJVYRFM.js.map +0 -1
  43. /package/{LICENSE.md → LICENSE} +0 -0
  44. /package/{chunk-CGVYLGBG.js.map → chunk-RK6TMFVW.js.map} +0 -0
@@ -1,2 +1,2 @@
1
- import{Aa as q,B as i,Ba as C,Ca as g,F as V,J as xe,Ma as se,Na as te,Oa as ce,a as ye,da as a,ga as v,ma as H,oa as b,pa as I,qa as L,ra as _,sa as m,ta as h,ua as z,va as U,wa as W,xa as f,ya as M,za as B}from"./chunk-SWJVYRFM.js";var S=e=>Math.sqrt(e.x**2+e.y**2),D=e=>Math.sqrt(e.x**2+e.y**2+e.z**2),E=e=>Math.sqrt(e.x**2+e.y**2+e.z**2+e.w**2),ae=(e,n)=>e.x*n.x+e.y*n.y,re=(e,n)=>e.x*n.x+e.y*n.y+e.z*n.z,ve=(e,n)=>e.x*n.x+e.y*n.y+e.z*n.z+e.w*n.w,r=(e,n,s)=>Math.min(Math.max(n,e),s),u=e=>n=>b(e(n.x),e(n.y)),w=e=>n=>I(e(n.x),e(n.y)),R=e=>n=>L(e(n.x),e(n.y)),K=e=>n=>_(e(n.x),e(n.y)),y=e=>n=>h(e(n.x),e(n.y),e(n.z)),l=e=>n=>z(e(n.x),e(n.y),e(n.z)),$=e=>n=>U(e(n.x),e(n.y),e(n.z)),k=e=>n=>W(e(n.x),e(n.y),e(n.z)),x=e=>n=>M(e(n.x),e(n.y),e(n.z),e(n.w)),o=e=>n=>B(e(n.x),e(n.y),e(n.z),e(n.w)),N=e=>n=>q(e(n.x),e(n.y),e(n.z),e(n.w)),O=e=>n=>C(e(n.x),e(n.y),e(n.z),e(n.w)),ue=e=>n=>{let s=n.columns;return se(u(e)(s[0]),u(e)(s[1]))},we=e=>n=>{let s=n.columns;return te(y(e)(s[0]),y(e)(s[1]),y(e)(s[2]))},le=e=>n=>{let s=n.columns;return ce(x(e)(s[0]),x(e)(s[1]),x(e)(s[2]),x(e)(s[3]))},F=e=>(n,s)=>b(e(n.x,s.x),e(n.y,s.y)),j=e=>(n,s)=>I(e(n.x,s.x),e(n.y,s.y)),J=e=>(n,s)=>L(e(n.x,s.x),e(n.y,s.y)),Q=e=>(n,s)=>_(e(n.x,s.x),e(n.y,s.y)),A=e=>(n,s)=>h(e(n.x,s.x),e(n.y,s.y),e(n.z,s.z)),P=e=>(n,s)=>z(e(n.x,s.x),e(n.y,s.y),e(n.z,s.z)),X=e=>(n,s)=>U(e(n.x,s.x),e(n.y,s.y),e(n.z,s.z)),Y=e=>(n,s)=>W(e(n.x,s.x),e(n.y,s.y),e(n.z,s.z)),p=e=>(n,s)=>M(e(n.x,s.x),e(n.y,s.y),e(n.z,s.z),e(n.w,s.w)),Z=e=>(n,s)=>B(e(n.x,s.x),e(n.y,s.y),e(n.z,s.z),e(n.w,s.w)),ee=e=>(n,s)=>q(e(n.x,s.x),e(n.y,s.y),e(n.z,s.z),e(n.w,s.w)),ne=e=>(n,s)=>C(e(n.x,s.x),e(n.y,s.y),e(n.z,s.z),e(n.w,s.w)),fe=e=>(n,s)=>{let t=n.columns,T=s.columns;return se(F(e)(t[0],T[0]),F(e)(t[1],T[1]))},ge=e=>(n,s)=>{let t=n.columns,T=s.columns;return te(A(e)(t[0],T[0]),A(e)(t[1],T[1]),A(e)(t[2],T[2]))},he=e=>(n,s)=>{let t=n.columns,T=s.columns;return ce(p(e)(t[0],T[0]),p(e)(t[1],T[1]),p(e)(t[2],T[2]),p(e)(t[3],T[3]))},d={divInteger:(e,n)=>n===0?e:Math.trunc(e/n)},c={eq:{vec2f:(e,n)=>m(e.x===n.x,e.y===n.y),vec2h:(e,n)=>m(e.x===n.x,e.y===n.y),vec2i:(e,n)=>m(e.x===n.x,e.y===n.y),vec2u:(e,n)=>m(e.x===n.x,e.y===n.y),"vec2<bool>":(e,n)=>m(e.x===n.x,e.y===n.y),vec3f:(e,n)=>f(e.x===n.x,e.y===n.y,e.z===n.z),vec3h:(e,n)=>f(e.x===n.x,e.y===n.y,e.z===n.z),vec3i:(e,n)=>f(e.x===n.x,e.y===n.y,e.z===n.z),vec3u:(e,n)=>f(e.x===n.x,e.y===n.y,e.z===n.z),"vec3<bool>":(e,n)=>f(e.x===n.x,e.y===n.y,e.z===n.z),vec4f:(e,n)=>g(e.x===n.x,e.y===n.y,e.z===n.z,e.w===n.w),vec4h:(e,n)=>g(e.x===n.x,e.y===n.y,e.z===n.z,e.w===n.w),vec4i:(e,n)=>g(e.x===n.x,e.y===n.y,e.z===n.z,e.w===n.w),vec4u:(e,n)=>g(e.x===n.x,e.y===n.y,e.z===n.z,e.w===n.w),"vec4<bool>":(e,n)=>g(e.x===n.x,e.y===n.y,e.z===n.z,e.w===n.w)},lt:{vec2f:(e,n)=>m(e.x<n.x,e.y<n.y),vec2h:(e,n)=>m(e.x<n.x,e.y<n.y),vec2i:(e,n)=>m(e.x<n.x,e.y<n.y),vec2u:(e,n)=>m(e.x<n.x,e.y<n.y),vec3f:(e,n)=>f(e.x<n.x,e.y<n.y,e.z<n.z),vec3h:(e,n)=>f(e.x<n.x,e.y<n.y,e.z<n.z),vec3i:(e,n)=>f(e.x<n.x,e.y<n.y,e.z<n.z),vec3u:(e,n)=>f(e.x<n.x,e.y<n.y,e.z<n.z),vec4f:(e,n)=>g(e.x<n.x,e.y<n.y,e.z<n.z,e.w<n.w),vec4h:(e,n)=>g(e.x<n.x,e.y<n.y,e.z<n.z,e.w<n.w),vec4i:(e,n)=>g(e.x<n.x,e.y<n.y,e.z<n.z,e.w<n.w),vec4u:(e,n)=>g(e.x<n.x,e.y<n.y,e.z<n.z,e.w<n.w)},or:{"vec2<bool>":(e,n)=>m(e.x||n.x,e.y||n.y),"vec3<bool>":(e,n)=>f(e.x||n.x,e.y||n.y,e.z||n.z),"vec4<bool>":(e,n)=>g(e.x||n.x,e.y||n.y,e.z||n.z,e.w||n.w)},all:{"vec2<bool>":e=>e.x&&e.y,"vec3<bool>":e=>e.x&&e.y&&e.z,"vec4<bool>":e=>e.x&&e.y&&e.z&&e.w},abs:{vec2f:u(Math.abs),vec2h:w(Math.abs),vec2i:R(Math.abs),vec2u:K(Math.abs),vec3f:y(Math.abs),vec3h:l(Math.abs),vec3i:$(Math.abs),vec3u:k(Math.abs),vec4f:x(Math.abs),vec4h:o(Math.abs),vec4i:N(Math.abs),vec4u:O(Math.abs)},atan2:{vec2f:F(Math.atan2),vec2h:j(Math.atan2),vec3f:A(Math.atan2),vec3h:P(Math.atan2),vec4f:p(Math.atan2),vec4h:Z(Math.atan2)},acos:{vec2f:u(Math.acos),vec2h:w(Math.acos),vec2i:R(Math.acos),vec2u:K(Math.acos),vec3f:y(Math.acos),vec3h:l(Math.acos),vec3i:$(Math.acos),vec3u:k(Math.acos),vec4f:x(Math.acos),vec4h:o(Math.acos),vec4i:N(Math.acos),vec4u:O(Math.acos)},acosh:{vec2f:u(Math.acosh),vec2h:w(Math.acosh),vec3f:y(Math.acosh),vec3h:l(Math.acosh),vec4f:x(Math.acosh),vec4h:o(Math.acosh)},asin:{vec2f:u(Math.asin),vec2h:w(Math.asin),vec2i:R(Math.asin),vec2u:K(Math.asin),vec3f:y(Math.asin),vec3h:l(Math.asin),vec3i:$(Math.asin),vec3u:k(Math.asin),vec4f:x(Math.asin),vec4h:o(Math.asin),vec4i:N(Math.asin),vec4u:O(Math.asin)},ceil:{vec2f:u(Math.ceil),vec2h:w(Math.ceil),vec3f:y(Math.ceil),vec3h:l(Math.ceil),vec4f:x(Math.ceil),vec4h:o(Math.ceil)},clamp:{vec2f:(e,n,s)=>b(r(e.x,n.x,s.x),r(e.y,n.y,s.y)),vec2h:(e,n,s)=>I(r(e.x,n.x,s.x),r(e.y,n.y,s.y)),vec2i:(e,n,s)=>L(r(e.x,n.x,s.x),r(e.y,n.y,s.y)),vec2u:(e,n,s)=>_(r(e.x,n.x,s.x),r(e.y,n.y,s.y)),vec3f:(e,n,s)=>h(r(e.x,n.x,s.x),r(e.y,n.y,s.y),r(e.z,n.z,s.z)),vec3h:(e,n,s)=>z(r(e.x,n.x,s.x),r(e.y,n.y,s.y),r(e.z,n.z,s.z)),vec3i:(e,n,s)=>U(r(e.x,n.x,s.x),r(e.y,n.y,s.y),r(e.z,n.z,s.z)),vec3u:(e,n,s)=>W(r(e.x,n.x,s.x),r(e.y,n.y,s.y),r(e.z,n.z,s.z)),vec4f:(e,n,s)=>M(r(e.x,n.x,s.x),r(e.y,n.y,s.y),r(e.z,n.z,s.z),r(e.w,n.w,s.w)),vec4h:(e,n,s)=>B(r(e.x,n.x,s.x),r(e.y,n.y,s.y),r(e.z,n.z,s.z),r(e.w,n.w,s.w)),vec4i:(e,n,s)=>q(r(e.x,n.x,s.x),r(e.y,n.y,s.y),r(e.z,n.z,s.z),r(e.w,n.w,s.w)),vec4u:(e,n,s)=>C(r(e.x,n.x,s.x),r(e.y,n.y,s.y),r(e.z,n.z,s.z),r(e.w,n.w,s.w))},length:{vec2f:S,vec2h:S,vec3f:D,vec3h:D,vec4f:E,vec4h:E},add:{vec2f:F((e,n)=>e+n),vec2h:j((e,n)=>e+n),vec2i:J((e,n)=>e+n),vec2u:Q((e,n)=>e+n),vec3f:A((e,n)=>e+n),vec3h:P((e,n)=>e+n),vec3i:X((e,n)=>e+n),vec3u:Y((e,n)=>e+n),vec4f:p((e,n)=>e+n),vec4h:Z((e,n)=>e+n),vec4i:ee((e,n)=>e+n),vec4u:ne((e,n)=>e+n),mat2x2f:fe((e,n)=>e+n),mat3x3f:ge((e,n)=>e+n),mat4x4f:he((e,n)=>e+n)},addMixed:{vec2f:(e,n)=>u(s=>s+n)(e),vec2h:(e,n)=>w(s=>s+n)(e),vec2i:(e,n)=>R(s=>s+n)(e),vec2u:(e,n)=>K(s=>s+n)(e),vec3f:(e,n)=>y(s=>s+n)(e),vec3h:(e,n)=>l(s=>s+n)(e),vec3i:(e,n)=>$(s=>s+n)(e),vec3u:(e,n)=>k(s=>s+n)(e),vec4f:(e,n)=>x(s=>s+n)(e),vec4h:(e,n)=>o(s=>s+n)(e),vec4i:(e,n)=>N(s=>s+n)(e),vec4u:(e,n)=>O(s=>s+n)(e),mat2x2f:(e,n)=>ue(s=>s+n)(e),mat3x3f:(e,n)=>we(s=>s+n)(e),mat4x4f:(e,n)=>le(s=>s+n)(e)},mulSxV:{vec2f:(e,n)=>u(s=>e*s)(n),vec2h:(e,n)=>w(s=>e*s)(n),vec2i:(e,n)=>R(s=>e*s)(n),vec2u:(e,n)=>K(s=>e*s)(n),vec3f:(e,n)=>y(s=>e*s)(n),vec3h:(e,n)=>l(s=>e*s)(n),vec3i:(e,n)=>$(s=>e*s)(n),vec3u:(e,n)=>k(s=>e*s)(n),vec4f:(e,n)=>x(s=>e*s)(n),vec4h:(e,n)=>o(s=>e*s)(n),vec4i:(e,n)=>N(s=>e*s)(n),vec4u:(e,n)=>O(s=>e*s)(n),mat2x2f:(e,n)=>ue(s=>e*s)(n),mat3x3f:(e,n)=>we(s=>e*s)(n),mat4x4f:(e,n)=>le(s=>e*s)(n)},mulVxV:{vec2f:F((e,n)=>e*n),vec2h:j((e,n)=>e*n),vec2i:J((e,n)=>e*n),vec2u:Q((e,n)=>e*n),vec3f:A((e,n)=>e*n),vec3h:P((e,n)=>e*n),vec3i:X((e,n)=>e*n),vec3u:Y((e,n)=>e*n),vec4f:p((e,n)=>e*n),vec4h:Z((e,n)=>e*n),vec4i:ee((e,n)=>e*n),vec4u:ne((e,n)=>e*n),mat2x2f:(e,n)=>{let s=e.columns,t=n.columns;return se(s[0].x*t[0].x+s[1].x*t[0].y,s[0].y*t[0].x+s[1].y*t[0].y,s[0].x*t[1].x+s[1].x*t[1].y,s[0].y*t[1].x+s[1].y*t[1].y)},mat3x3f:(e,n)=>{let s=e.columns,t=n.columns;return te(s[0].x*t[0].x+s[1].x*t[0].y+s[2].x*t[0].z,s[0].y*t[0].x+s[1].y*t[0].y+s[2].y*t[0].z,s[0].z*t[0].x+s[1].z*t[0].y+s[2].z*t[0].z,s[0].x*t[1].x+s[1].x*t[1].y+s[2].x*t[1].z,s[0].y*t[1].x+s[1].y*t[1].y+s[2].y*t[1].z,s[0].z*t[1].x+s[1].z*t[1].y+s[2].z*t[1].z,s[0].x*t[2].x+s[1].x*t[2].y+s[2].x*t[2].z,s[0].y*t[2].x+s[1].y*t[2].y+s[2].y*t[2].z,s[0].z*t[2].x+s[1].z*t[2].y+s[2].z*t[2].z)},mat4x4f:(e,n)=>{let s=e.columns,t=n.columns;return ce(s[0].x*t[0].x+s[1].x*t[0].y+s[2].x*t[0].z+s[3].x*t[0].w,s[0].y*t[0].x+s[1].y*t[0].y+s[2].y*t[0].z+s[3].y*t[0].w,s[0].z*t[0].x+s[1].z*t[0].y+s[2].z*t[0].z+s[3].z*t[0].w,s[0].w*t[0].x+s[1].w*t[0].y+s[2].w*t[0].z+s[3].w*t[0].w,s[0].x*t[1].x+s[1].x*t[1].y+s[2].x*t[1].z+s[3].x*t[1].w,s[0].y*t[1].x+s[1].y*t[1].y+s[2].y*t[1].z+s[3].y*t[1].w,s[0].z*t[1].x+s[1].z*t[1].y+s[2].z*t[1].z+s[3].z*t[1].w,s[0].w*t[1].x+s[1].w*t[1].y+s[2].w*t[1].z+s[3].w*t[1].w,s[0].x*t[2].x+s[1].x*t[2].y+s[2].x*t[2].z+s[3].x*t[2].w,s[0].y*t[2].x+s[1].y*t[2].y+s[2].y*t[2].z+s[3].y*t[2].w,s[0].z*t[2].x+s[1].z*t[2].y+s[2].z*t[2].z+s[3].z*t[2].w,s[0].w*t[2].x+s[1].w*t[2].y+s[2].w*t[2].z+s[3].w*t[2].w,s[0].x*t[3].x+s[1].x*t[3].y+s[2].x*t[3].z+s[3].x*t[3].w,s[0].y*t[3].x+s[1].y*t[3].y+s[2].y*t[3].z+s[3].y*t[3].w,s[0].z*t[3].x+s[1].z*t[3].y+s[2].z*t[3].z+s[3].z*t[3].w,s[0].w*t[3].x+s[1].w*t[3].y+s[2].w*t[3].z+s[3].w*t[3].w)}},mulMxV:{mat2x2f:(e,n)=>{let s=e.columns;return b(s[0].x*n.x+s[1].x*n.y,s[0].y*n.x+s[1].y*n.y)},mat3x3f:(e,n)=>{let s=e.columns;return h(s[0].x*n.x+s[1].x*n.y+s[2].x*n.z,s[0].y*n.x+s[1].y*n.y+s[2].y*n.z,s[0].z*n.x+s[1].z*n.y+s[2].z*n.z)},mat4x4f:(e,n)=>{let s=e.columns;return M(s[0].x*n.x+s[1].x*n.y+s[2].x*n.z+s[3].x*n.w,s[0].y*n.x+s[1].y*n.y+s[2].y*n.z+s[3].y*n.w,s[0].z*n.x+s[1].z*n.y+s[2].z*n.z+s[3].z*n.w,s[0].w*n.x+s[1].w*n.y+s[2].w*n.z+s[3].w*n.w)}},mulVxM:{mat2x2f:(e,n)=>{let s=n.columns;return b(e.x*s[0].x+e.y*s[0].y,e.x*s[1].x+e.y*s[1].y)},mat3x3f:(e,n)=>{let s=n.columns;return h(e.x*s[0].x+e.y*s[0].y+e.z*s[0].z,e.x*s[1].x+e.y*s[1].y+e.z*s[1].z,e.x*s[2].x+e.y*s[2].y+e.z*s[2].z)},mat4x4f:(e,n)=>{let s=n.columns;return M(e.x*s[0].x+e.y*s[0].y+e.z*s[0].z+e.w*s[0].w,e.x*s[1].x+e.y*s[1].y+e.z*s[1].z+e.w*s[1].w,e.x*s[2].x+e.y*s[2].y+e.z*s[2].z+e.w*s[2].w,e.x*s[3].x+e.y*s[3].y+e.z*s[3].z+e.w*s[3].w)}},div:{vec2f:F((e,n)=>e/n),vec2h:j((e,n)=>e/n),vec2i:J(d.divInteger),vec2u:Q(d.divInteger),vec3f:A((e,n)=>e/n),vec3h:P((e,n)=>e/n),vec3i:X(d.divInteger),vec3u:Y(d.divInteger),vec4f:p((e,n)=>e/n),vec4h:Z((e,n)=>e/n),vec4i:ee(d.divInteger),vec4u:ne(d.divInteger)},divMixed:{vec2f:(e,n)=>u(s=>s/n)(e),vec2h:(e,n)=>w(s=>s/n)(e),vec2i:(e,n)=>R(s=>d.divInteger(s,n))(e),vec2u:(e,n)=>K(s=>d.divInteger(s,n))(e),vec3f:(e,n)=>y(s=>s/n)(e),vec3h:(e,n)=>l(s=>s/n)(e),vec3i:(e,n)=>$(s=>d.divInteger(s,n))(e),vec3u:(e,n)=>k(s=>d.divInteger(s,n))(e),vec4f:(e,n)=>x(s=>s/n)(e),vec4h:(e,n)=>o(s=>s/n)(e),vec4i:(e,n)=>N(s=>d.divInteger(s,n))(e),vec4u:(e,n)=>O(s=>d.divInteger(s,n))(e)},dot:{vec2f:ae,vec2h:ae,vec2i:ae,vec2u:ae,vec3f:re,vec3h:re,vec3i:re,vec3u:re,vec4f:ve,vec4h:ve,vec4i:ve,vec4u:ve},normalize:{vec2f:e=>{let n=S(e);return b(e.x/n,e.y/n)},vec2h:e=>{let n=S(e);return I(e.x/n,e.y/n)},vec2i:e=>{let n=S(e);return L(e.x/n,e.y/n)},vec2u:e=>{let n=S(e);return _(e.x/n,e.y/n)},vec3f:e=>{let n=D(e);return h(e.x/n,e.y/n,e.z/n)},vec3h:e=>{let n=D(e);return z(e.x/n,e.y/n,e.z/n)},vec3i:e=>{let n=D(e);return U(e.x/n,e.y/n,e.z/n)},vec3u:e=>{let n=D(e);return W(e.x/n,e.y/n,e.z/n)},vec4f:e=>{let n=E(e);return M(e.x/n,e.y/n,e.z/n,e.w/n)},vec4h:e=>{let n=E(e);return B(e.x/n,e.y/n,e.z/n,e.w/n)},vec4i:e=>{let n=E(e);return q(e.x/n,e.y/n,e.z/n,e.w/n)},vec4u:e=>{let n=E(e);return C(e.x/n,e.y/n,e.z/n,e.w/n)}},cross:{vec3f:(e,n)=>h(e.y*n.z-e.z*n.y,e.z*n.x-e.x*n.z,e.x*n.y-e.y*n.x),vec3h:(e,n)=>z(e.y*n.z-e.z*n.y,e.z*n.x-e.x*n.z,e.x*n.y-e.y*n.x)},floor:{vec2f:u(Math.floor),vec2h:w(Math.floor),vec3f:y(Math.floor),vec3h:l(Math.floor),vec4f:x(Math.floor),vec4h:o(Math.floor)},max:{vec2f:F(Math.max),vec2h:j(Math.max),vec2i:J(Math.max),vec2u:Q(Math.max),vec3f:A(Math.max),vec3h:P(Math.max),vec3i:X(Math.max),vec3u:Y(Math.max),vec4f:p(Math.max),vec4h:Z(Math.max),vec4i:ee(Math.max),vec4u:ne(Math.max)},min:{vec2f:F(Math.min),vec2h:j(Math.min),vec2i:J(Math.min),vec2u:Q(Math.min),vec3f:A(Math.min),vec3h:P(Math.min),vec3i:X(Math.min),vec3u:Y(Math.min),vec4f:p(Math.min),vec4h:Z(Math.min),vec4i:ee(Math.min),vec4u:ne(Math.min)},pow:{vec2f:(e,n)=>b(e.x**n.x,e.y**n.y),vec2h:(e,n)=>I(e.x**n.x,e.y**n.y),vec3f:(e,n)=>h(e.x**n.x,e.y**n.y,e.z**n.z),vec3h:(e,n)=>z(e.x**n.x,e.y**n.y,e.z**n.z),vec4f:(e,n)=>M(e.x**n.x,e.y**n.y,e.z**n.z,e.w**n.w),vec4h:(e,n)=>B(e.x**n.x,e.y**n.y,e.z**n.z,e.w**n.w)},sign:{vec2f:u(Math.sign),vec2h:w(Math.sign),vec2i:R(Math.sign),vec3f:y(Math.sign),vec3h:l(Math.sign),vec3i:$(Math.sign),vec4f:x(Math.sign),vec4h:o(Math.sign),vec4i:N(Math.sign)},sqrt:{vec2f:u(Math.sqrt),vec2h:w(Math.sqrt),vec3f:y(Math.sqrt),vec3h:l(Math.sqrt),vec4f:x(Math.sqrt),vec4h:o(Math.sqrt)},mix:{vec2f:(e,n,s)=>typeof s=="number"?b(e.x*(1-s)+n.x*s,e.y*(1-s)+n.y*s):b(e.x*(1-s.x)+n.x*s.x,e.y*(1-s.y)+n.y*s.y),vec2h:(e,n,s)=>typeof s=="number"?I(e.x*(1-s)+n.x*s,e.y*(1-s)+n.y*s):I(e.x*(1-s.x)+n.x*s.x,e.y*(1-s.y)+n.y*s.y),vec3f:(e,n,s)=>typeof s=="number"?h(e.x*(1-s)+n.x*s,e.y*(1-s)+n.y*s,e.z*(1-s)+n.z*s):h(e.x*(1-s.x)+n.x*s.x,e.y*(1-s.y)+n.y*s.y,e.z*(1-s.z)+n.z*s.z),vec3h:(e,n,s)=>typeof s=="number"?z(e.x*(1-s)+n.x*s,e.y*(1-s)+n.y*s,e.z*(1-s)+n.z*s):z(e.x*(1-s.x)+n.x*s.x,e.y*(1-s.y)+n.y*s.y,e.z*(1-s.z)+n.z*s.z),vec4f:(e,n,s)=>typeof s=="number"?M(e.x*(1-s)+n.x*s,e.y*(1-s)+n.y*s,e.z*(1-s)+n.z*s,e.w*(1-s)+n.w*s):M(e.x*(1-s.x)+n.x*s.x,e.y*(1-s.y)+n.y*s.y,e.z*(1-s.z)+n.z*s.z,e.w*(1-s.w)+n.w*s.w),vec4h:(e,n,s)=>typeof s=="number"?B(e.x*(1-s)+n.x*s,e.y*(1-s)+n.y*s,e.z*(1-s)+n.z*s,e.w*(1-s)+n.w*s):B(e.x*(1-s.x)+n.x*s.x,e.y*(1-s.y)+n.y*s.y,e.z*(1-s.z)+n.z*s.z,e.w*(1-s.w)+n.w*s.w)},sin:{vec2f:u(Math.sin),vec2h:w(Math.sin),vec3f:y(Math.sin),vec3h:l(Math.sin),vec4f:x(Math.sin),vec4h:o(Math.sin)},cos:{vec2f:u(Math.cos),vec2h:w(Math.cos),vec3f:y(Math.cos),vec3h:l(Math.cos),vec4f:x(Math.cos),vec4h:o(Math.cos)},cosh:{vec2f:u(Math.cosh),vec2h:w(Math.cosh),vec3f:y(Math.cosh),vec3h:l(Math.cosh),vec4f:x(Math.cosh),vec4h:o(Math.cosh)},exp:{vec2f:u(Math.exp),vec2h:w(Math.exp),vec3f:y(Math.exp),vec3h:l(Math.exp),vec4f:x(Math.exp),vec4h:o(Math.exp)},exp2:{vec2f:u(e=>2**e),vec2h:w(e=>2**e),vec3f:y(e=>2**e),vec3h:l(e=>2**e),vec4f:x(e=>2**e),vec4h:o(e=>2**e)},log:{vec2f:u(Math.log),vec2h:w(Math.log),vec3f:y(Math.log),vec3h:l(Math.log),vec4f:x(Math.log),vec4h:o(Math.log)},log2:{vec2f:u(Math.log2),vec2h:w(Math.log2),vec3f:y(Math.log2),vec3h:l(Math.log2),vec4f:x(Math.log2),vec4h:o(Math.log2)},fract:{vec2f:u(e=>e-Math.floor(e)),vec2h:w(e=>e-Math.floor(e)),vec3f:y(e=>e-Math.floor(e)),vec3h:l(e=>e-Math.floor(e)),vec4f:x(e=>e-Math.floor(e)),vec4h:o(e=>e-Math.floor(e))},isCloseToZero:{vec2f:(e,n)=>Math.abs(e.x)<=n&&Math.abs(e.y)<=n,vec2h:(e,n)=>Math.abs(e.x)<=n&&Math.abs(e.y)<=n,vec3f:(e,n)=>Math.abs(e.x)<=n&&Math.abs(e.y)<=n&&Math.abs(e.z)<=n,vec3h:(e,n)=>Math.abs(e.x)<=n&&Math.abs(e.y)<=n&&Math.abs(e.z)<=n,vec4f:(e,n)=>Math.abs(e.x)<=n&&Math.abs(e.y)<=n&&Math.abs(e.z)<=n&&Math.abs(e.w)<=n,vec4h:(e,n)=>Math.abs(e.x)<=n&&Math.abs(e.y)<=n&&Math.abs(e.z)<=n&&Math.abs(e.w)<=n},neg:{vec2f:u(e=>-e),vec2h:w(e=>-e),vec2i:R(e=>-e),vec2u:K(e=>-e),"vec2<bool>":e=>m(!e.x,!e.y),vec3f:y(e=>-e),vec3h:l(e=>-e),vec3i:$(e=>-e),vec3u:k(e=>-e),"vec3<bool>":e=>f(!e.x,!e.y,!e.z),vec4f:x(e=>-e),vec4h:o(e=>-e),vec4i:N(e=>-e),vec4u:O(e=>-e),"vec4<bool>":e=>g(!e.x,!e.y,!e.z,!e.w)},select:{vec2f:(e,n,s)=>b(s.x?n.x:e.x,s.y?n.y:e.y),vec2h:(e,n,s)=>I(s.x?n.x:e.x,s.y?n.y:e.y),vec2i:(e,n,s)=>L(s.x?n.x:e.x,s.y?n.y:e.y),vec2u:(e,n,s)=>_(s.x?n.x:e.x,s.y?n.y:e.y),"vec2<bool>":(e,n,s)=>m(s.x?n.x:e.x,s.y?n.y:e.y),vec3f:(e,n,s)=>h(s.x?n.x:e.x,s.y?n.y:e.y,s.z?n.z:e.z),vec3h:(e,n,s)=>z(s.x?n.x:e.x,s.y?n.y:e.y,s.z?n.z:e.z),vec3i:(e,n,s)=>U(s.x?n.x:e.x,s.y?n.y:e.y,s.z?n.z:e.z),vec3u:(e,n,s)=>W(s.x?n.x:e.x,s.y?n.y:e.y,s.z?n.z:e.z),"vec3<bool>":(e,n,s)=>f(s.x?n.x:e.x,s.y?n.y:e.y,s.z?n.z:e.z),vec4f:(e,n,s)=>M(s.x?n.x:e.x,s.y?n.y:e.y,s.z?n.z:e.z,s.w?n.w:e.w),vec4h:(e,n,s)=>B(s.x?n.x:e.x,s.y?n.y:e.y,s.z?n.z:e.z,s.w?n.w:e.w),vec4i:(e,n,s)=>q(s.x?n.x:e.x,s.y?n.y:e.y,s.z?n.z:e.z,s.w?n.w:e.w),vec4u:(e,n,s)=>C(s.x?n.x:e.x,s.y?n.y:e.y,s.z?n.z:e.z,s.w?n.w:e.w),"vec4<bool>":(e,n,s)=>g(s.x?n.x:e.x,s.y?n.y:e.y,s.z?n.z:e.z,s.w?n.w:e.w)},tanh:{vec2f:u(Math.tanh),vec2h:w(Math.tanh),vec3f:y(Math.tanh),vec3h:l(Math.tanh),vec4f:x(Math.tanh),vec4h:o(Math.tanh)}};function G(e){return de(e.dataType)}function de(e){let n=e?.type;return!!e?.[ye]&&(n==="abstractInt"||n==="abstractFloat"||n==="f32"||n==="f16"||n==="i32"||n==="u32")}function oe(e,n){if(typeof e=="number"&&typeof n=="number")return e+n;if(typeof e=="number"&&i(n))return c.addMixed[n.kind](n,e);if(i(e)&&typeof n=="number")return c.addMixed[e.kind](e,n);if(i(e)&&i(n)||V(e)&&V(n))return c.add[e.kind](e,n);throw new Error("Add/Sub called with invalid arguments.")}var ke=v(oe,(e,n)=>a(`(${e.value} + ${n.value})`,G(e)?n.dataType:e.dataType),"coerce");function Te(e,n){return oe(e,me(-1,n))}var ie=v(Te,(e,n)=>a(`(${e.value} - ${n.value})`,G(e)?n.dataType:e.dataType),"sub","coerce");function be(e,n){if(typeof e=="number"&&typeof n=="number")return e*n;if(typeof e=="number"&&(i(n)||V(n)))return c.mulSxV[n.kind](e,n);if((i(e)||V(e))&&typeof n=="number")return c.mulSxV[e.kind](n,e);if(i(e)&&i(n))return c.mulVxV[e.kind](e,n);if(xe(e)&&V(n))return c.mulVxM[n.kind](e,n);if(V(e)&&xe(n))return c.mulMxV[e.kind](e,n);if(V(e)&&V(n))return c.mulVxV[e.kind](e,n);throw new Error("Mul called with invalid arguments.")}var me=v(be,(e,n)=>{let s=G(e)?n.dataType:G(n)||e.dataType.type.startsWith("vec")?e.dataType:n.dataType.type.startsWith("vec")?n.dataType:e.dataType;return a(`(${e.value} * ${n.value})`,s)},"mul");function Me(e,n){if(typeof e=="number"&&typeof n=="number")return e/n;if(typeof e=="number"&&i(n))return c.divMixed[n.kind](n,e);if(i(e)&&typeof n=="number")return c.divMixed[e.kind](e,n);if(i(e)&&i(n))return c.div[e.kind](e,n);throw new Error("Div called with invalid arguments.")}var Oe=v(Me,(e,n)=>G(e)&&G(n)?a(`(f32(${e.value}) / ${n.value})`,H):a(`(${e.value} / ${n.value})`,e.dataType),"div"),Le=v(e=>typeof e=="number"?Math.abs(e):c.abs[e.kind](e),e=>a(`abs(${e.value})`,e.dataType),"abs"),_e=v((e,n)=>typeof e=="number"&&typeof n=="number"?Math.atan2(e,n):c.atan2[e.kind](e,n),(e,n)=>a(`atan2(${e.value}, ${n.value})`,e.dataType),"atan2"),Ue=v(e=>typeof e=="number"?Math.acos(e):c.acos[e.kind](e),e=>a(`acos(${e.value})`,e.dataType),"acos"),We=v(e=>typeof e=="number"?Math.acosh(e):c.acosh[e.kind](e),e=>a(`acosh(${e.value})`,e.dataType),"acosh"),qe=v(e=>typeof e=="number"?Math.asin(e):c.asin[e.kind](e),e=>a(`asin(${e.value})`,e.dataType),"asin"),Ce=v(e=>typeof e=="number"?Math.ceil(e):c.ceil[e.kind](e),e=>a(`ceil(${e.value})`,e.dataType),"ceil"),Se=v((e,n,s)=>typeof e=="number"?Math.min(Math.max(n,e),s):c.clamp[e.kind](e,n,s),(e,n,s)=>a(`clamp(${e.value}, ${n.value}, ${s.value})`,e.dataType),"clamp"),De=v(e=>typeof e=="number"?Math.cos(e):c.cos[e.kind](e),e=>a(`cos(${e.value})`,e.dataType),"cos"),Ee=v(e=>typeof e=="number"?Math.cosh(e):c.cosh[e.kind](e),e=>a(`cosh(${e.value})`,e.dataType),"cosh"),je=v((e,n)=>c.cross[e.kind](e,n),(e,n)=>a(`cross(${e.value}, ${n.value})`,e.dataType),"cross"),ze=v((e,n)=>c.dot[e.kind](e,n),(e,n)=>a(`dot(${e.value}, ${n.value})`,H),"dot"),Pe=v(e=>c.normalize[e.kind](e),e=>a(`normalize(${e.value})`,e.dataType),"normalize"),Ze=v(e=>typeof e=="number"?Math.floor(e):c.floor[e.kind](e),e=>a(`floor(${e.value})`,e.dataType),"floor"),Ge=v(e=>typeof e=="number"?e-Math.floor(e):c.fract[e.kind](e),e=>a(`fract(${e.value})`,e.dataType),"fract"),pe=v(e=>typeof e=="number"?Math.abs(e):c.length[e.kind](e),e=>a(`length(${e.value})`,H),"length"),He=v(e=>typeof e=="number"?Math.log(e):c.log[e.kind](e),e=>a(`log(${e.value})`,e.dataType),"log"),Je=v(e=>typeof e=="number"?Math.log2(e):c.log2[e.kind](e),e=>a(`log2(${e.value})`,e.dataType),"log2"),Qe=v((e,n)=>typeof e=="number"?Math.max(e,n):c.max[e.kind](e,n),(e,n)=>a(`max(${e.value}, ${n.value})`,e.dataType),"max","coerce"),Xe=v((e,n)=>typeof e=="number"?Math.min(e,n):c.min[e.kind](e,n),(e,n)=>a(`min(${e.value}, ${n.value})`,e.dataType),"min","coerce"),Ye=v(e=>typeof e=="number"?Math.sign(e):c.sign[e.kind](e),e=>a(`sign(${e.value})`,e.dataType),"sign"),en=v(e=>typeof e=="number"?Math.sin(e):c.sin[e.kind](e),e=>a(`sin(${e.value})`,e.dataType),"sin"),nn=v(e=>typeof e=="number"?Math.exp(e):c.exp[e.kind](e),e=>a(`exp(${e.value})`,e.dataType),"exp"),sn=v(e=>typeof e=="number"?2**e:c.exp2[e.kind](e),e=>a(`exp2(${e.value})`,e.dataType),"exp2"),tn=v((e,n)=>{if(typeof e=="number"&&typeof n=="number")return e**n;if(typeof e=="object"&&typeof n=="object"&&"kind"in e&&"kind"in n)return c.pow[e.kind](e,n);throw new Error("Invalid arguments to pow()")},(e,n)=>a(`pow(${e.value}, ${n.value})`,e.dataType),"pow"),cn=v((e,n,s)=>{if(typeof e=="number"){if(typeof s!="number"||typeof n!="number")throw new Error("When e1 and e2 are numbers, the blend factor must be a number.");return e*(1-s)+n*s}if(typeof e=="number"||typeof n=="number")throw new Error("e1 and e2 need to both be vectors of the same kind.");return c.mix[e.kind](e,n,s)},(e,n,s)=>a(`mix(${e.value}, ${n.value}, ${s.value})`,e.dataType),"mix"),an=v((e,n)=>ie(e,me(2*ze(n,e),n)),(e,n)=>a(`reflect(${e.value}, ${n.value})`,e.dataType),"reflect"),rn=v((e,n)=>typeof e=="number"&&typeof n=="number"?Math.abs(e-n):pe(ie(e,n)),(e,n)=>a(`distance(${e.value}, ${n.value})`,H),"distance"),vn=v(e=>typeof e=="number"?-e:c.neg[e.kind](e),e=>a(`-(${e.value})`,e.dataType),"neg"),xn=v(e=>typeof e=="number"?Math.sqrt(e):c.sqrt[e.kind](e),e=>a(`sqrt(${e.value})`,e.dataType),"sqrt"),yn=v(e=>typeof e=="number"?Math.tanh(e):c.tanh[e.kind](e),e=>a(`tanh(${e.value})`,e.dataType),"tanh");export{c as a,G as b,de as c,ke as d,ie as e,me as f,Oe as g,Le as h,_e as i,Ue as j,We as k,qe as l,Ce as m,Se as n,De as o,Ee as p,je as q,ze as r,Pe as s,Ze as t,Ge as u,pe as v,He as w,Je as x,Qe as y,Xe as z,Ye as A,en as B,nn as C,sn as D,tn as E,cn as F,an as G,rn as H,vn as I,xn as J,yn as K};
2
- //# sourceMappingURL=chunk-CGVYLGBG.js.map
1
+ import{Aa as f,Ba as M,Ca as B,D as i,Da as q,Ea as C,Fa as g,H as V,L as xe,Pa as se,Qa as te,Ra as ce,a as ye,fa as a,ia as v,pa as H,ra as b,sa as I,ta as L,ua as _,va as m,wa as h,xa as z,ya as U,za as W}from"./chunk-APTRHY5Y.js";var S=e=>Math.sqrt(e.x**2+e.y**2),D=e=>Math.sqrt(e.x**2+e.y**2+e.z**2),E=e=>Math.sqrt(e.x**2+e.y**2+e.z**2+e.w**2),ae=(e,n)=>e.x*n.x+e.y*n.y,re=(e,n)=>e.x*n.x+e.y*n.y+e.z*n.z,ve=(e,n)=>e.x*n.x+e.y*n.y+e.z*n.z+e.w*n.w,r=(e,n,s)=>Math.min(Math.max(n,e),s),u=e=>n=>b(e(n.x),e(n.y)),w=e=>n=>I(e(n.x),e(n.y)),R=e=>n=>L(e(n.x),e(n.y)),K=e=>n=>_(e(n.x),e(n.y)),y=e=>n=>h(e(n.x),e(n.y),e(n.z)),l=e=>n=>z(e(n.x),e(n.y),e(n.z)),$=e=>n=>U(e(n.x),e(n.y),e(n.z)),k=e=>n=>W(e(n.x),e(n.y),e(n.z)),x=e=>n=>M(e(n.x),e(n.y),e(n.z),e(n.w)),o=e=>n=>B(e(n.x),e(n.y),e(n.z),e(n.w)),N=e=>n=>q(e(n.x),e(n.y),e(n.z),e(n.w)),O=e=>n=>C(e(n.x),e(n.y),e(n.z),e(n.w)),ue=e=>n=>{let s=n.columns;return se(u(e)(s[0]),u(e)(s[1]))},we=e=>n=>{let s=n.columns;return te(y(e)(s[0]),y(e)(s[1]),y(e)(s[2]))},le=e=>n=>{let s=n.columns;return ce(x(e)(s[0]),x(e)(s[1]),x(e)(s[2]),x(e)(s[3]))},F=e=>(n,s)=>b(e(n.x,s.x),e(n.y,s.y)),j=e=>(n,s)=>I(e(n.x,s.x),e(n.y,s.y)),J=e=>(n,s)=>L(e(n.x,s.x),e(n.y,s.y)),Q=e=>(n,s)=>_(e(n.x,s.x),e(n.y,s.y)),A=e=>(n,s)=>h(e(n.x,s.x),e(n.y,s.y),e(n.z,s.z)),P=e=>(n,s)=>z(e(n.x,s.x),e(n.y,s.y),e(n.z,s.z)),X=e=>(n,s)=>U(e(n.x,s.x),e(n.y,s.y),e(n.z,s.z)),Y=e=>(n,s)=>W(e(n.x,s.x),e(n.y,s.y),e(n.z,s.z)),p=e=>(n,s)=>M(e(n.x,s.x),e(n.y,s.y),e(n.z,s.z),e(n.w,s.w)),Z=e=>(n,s)=>B(e(n.x,s.x),e(n.y,s.y),e(n.z,s.z),e(n.w,s.w)),ee=e=>(n,s)=>q(e(n.x,s.x),e(n.y,s.y),e(n.z,s.z),e(n.w,s.w)),ne=e=>(n,s)=>C(e(n.x,s.x),e(n.y,s.y),e(n.z,s.z),e(n.w,s.w)),fe=e=>(n,s)=>{let t=n.columns,T=s.columns;return se(F(e)(t[0],T[0]),F(e)(t[1],T[1]))},ge=e=>(n,s)=>{let t=n.columns,T=s.columns;return te(A(e)(t[0],T[0]),A(e)(t[1],T[1]),A(e)(t[2],T[2]))},he=e=>(n,s)=>{let t=n.columns,T=s.columns;return ce(p(e)(t[0],T[0]),p(e)(t[1],T[1]),p(e)(t[2],T[2]),p(e)(t[3],T[3]))},d={divInteger:(e,n)=>n===0?e:Math.trunc(e/n)},c={eq:{vec2f:(e,n)=>m(e.x===n.x,e.y===n.y),vec2h:(e,n)=>m(e.x===n.x,e.y===n.y),vec2i:(e,n)=>m(e.x===n.x,e.y===n.y),vec2u:(e,n)=>m(e.x===n.x,e.y===n.y),"vec2<bool>":(e,n)=>m(e.x===n.x,e.y===n.y),vec3f:(e,n)=>f(e.x===n.x,e.y===n.y,e.z===n.z),vec3h:(e,n)=>f(e.x===n.x,e.y===n.y,e.z===n.z),vec3i:(e,n)=>f(e.x===n.x,e.y===n.y,e.z===n.z),vec3u:(e,n)=>f(e.x===n.x,e.y===n.y,e.z===n.z),"vec3<bool>":(e,n)=>f(e.x===n.x,e.y===n.y,e.z===n.z),vec4f:(e,n)=>g(e.x===n.x,e.y===n.y,e.z===n.z,e.w===n.w),vec4h:(e,n)=>g(e.x===n.x,e.y===n.y,e.z===n.z,e.w===n.w),vec4i:(e,n)=>g(e.x===n.x,e.y===n.y,e.z===n.z,e.w===n.w),vec4u:(e,n)=>g(e.x===n.x,e.y===n.y,e.z===n.z,e.w===n.w),"vec4<bool>":(e,n)=>g(e.x===n.x,e.y===n.y,e.z===n.z,e.w===n.w)},lt:{vec2f:(e,n)=>m(e.x<n.x,e.y<n.y),vec2h:(e,n)=>m(e.x<n.x,e.y<n.y),vec2i:(e,n)=>m(e.x<n.x,e.y<n.y),vec2u:(e,n)=>m(e.x<n.x,e.y<n.y),vec3f:(e,n)=>f(e.x<n.x,e.y<n.y,e.z<n.z),vec3h:(e,n)=>f(e.x<n.x,e.y<n.y,e.z<n.z),vec3i:(e,n)=>f(e.x<n.x,e.y<n.y,e.z<n.z),vec3u:(e,n)=>f(e.x<n.x,e.y<n.y,e.z<n.z),vec4f:(e,n)=>g(e.x<n.x,e.y<n.y,e.z<n.z,e.w<n.w),vec4h:(e,n)=>g(e.x<n.x,e.y<n.y,e.z<n.z,e.w<n.w),vec4i:(e,n)=>g(e.x<n.x,e.y<n.y,e.z<n.z,e.w<n.w),vec4u:(e,n)=>g(e.x<n.x,e.y<n.y,e.z<n.z,e.w<n.w)},or:{"vec2<bool>":(e,n)=>m(e.x||n.x,e.y||n.y),"vec3<bool>":(e,n)=>f(e.x||n.x,e.y||n.y,e.z||n.z),"vec4<bool>":(e,n)=>g(e.x||n.x,e.y||n.y,e.z||n.z,e.w||n.w)},all:{"vec2<bool>":e=>e.x&&e.y,"vec3<bool>":e=>e.x&&e.y&&e.z,"vec4<bool>":e=>e.x&&e.y&&e.z&&e.w},abs:{vec2f:u(Math.abs),vec2h:w(Math.abs),vec2i:R(Math.abs),vec2u:K(Math.abs),vec3f:y(Math.abs),vec3h:l(Math.abs),vec3i:$(Math.abs),vec3u:k(Math.abs),vec4f:x(Math.abs),vec4h:o(Math.abs),vec4i:N(Math.abs),vec4u:O(Math.abs)},atan2:{vec2f:F(Math.atan2),vec2h:j(Math.atan2),vec3f:A(Math.atan2),vec3h:P(Math.atan2),vec4f:p(Math.atan2),vec4h:Z(Math.atan2)},acos:{vec2f:u(Math.acos),vec2h:w(Math.acos),vec2i:R(Math.acos),vec2u:K(Math.acos),vec3f:y(Math.acos),vec3h:l(Math.acos),vec3i:$(Math.acos),vec3u:k(Math.acos),vec4f:x(Math.acos),vec4h:o(Math.acos),vec4i:N(Math.acos),vec4u:O(Math.acos)},acosh:{vec2f:u(Math.acosh),vec2h:w(Math.acosh),vec3f:y(Math.acosh),vec3h:l(Math.acosh),vec4f:x(Math.acosh),vec4h:o(Math.acosh)},asin:{vec2f:u(Math.asin),vec2h:w(Math.asin),vec2i:R(Math.asin),vec2u:K(Math.asin),vec3f:y(Math.asin),vec3h:l(Math.asin),vec3i:$(Math.asin),vec3u:k(Math.asin),vec4f:x(Math.asin),vec4h:o(Math.asin),vec4i:N(Math.asin),vec4u:O(Math.asin)},ceil:{vec2f:u(Math.ceil),vec2h:w(Math.ceil),vec3f:y(Math.ceil),vec3h:l(Math.ceil),vec4f:x(Math.ceil),vec4h:o(Math.ceil)},clamp:{vec2f:(e,n,s)=>b(r(e.x,n.x,s.x),r(e.y,n.y,s.y)),vec2h:(e,n,s)=>I(r(e.x,n.x,s.x),r(e.y,n.y,s.y)),vec2i:(e,n,s)=>L(r(e.x,n.x,s.x),r(e.y,n.y,s.y)),vec2u:(e,n,s)=>_(r(e.x,n.x,s.x),r(e.y,n.y,s.y)),vec3f:(e,n,s)=>h(r(e.x,n.x,s.x),r(e.y,n.y,s.y),r(e.z,n.z,s.z)),vec3h:(e,n,s)=>z(r(e.x,n.x,s.x),r(e.y,n.y,s.y),r(e.z,n.z,s.z)),vec3i:(e,n,s)=>U(r(e.x,n.x,s.x),r(e.y,n.y,s.y),r(e.z,n.z,s.z)),vec3u:(e,n,s)=>W(r(e.x,n.x,s.x),r(e.y,n.y,s.y),r(e.z,n.z,s.z)),vec4f:(e,n,s)=>M(r(e.x,n.x,s.x),r(e.y,n.y,s.y),r(e.z,n.z,s.z),r(e.w,n.w,s.w)),vec4h:(e,n,s)=>B(r(e.x,n.x,s.x),r(e.y,n.y,s.y),r(e.z,n.z,s.z),r(e.w,n.w,s.w)),vec4i:(e,n,s)=>q(r(e.x,n.x,s.x),r(e.y,n.y,s.y),r(e.z,n.z,s.z),r(e.w,n.w,s.w)),vec4u:(e,n,s)=>C(r(e.x,n.x,s.x),r(e.y,n.y,s.y),r(e.z,n.z,s.z),r(e.w,n.w,s.w))},length:{vec2f:S,vec2h:S,vec3f:D,vec3h:D,vec4f:E,vec4h:E},add:{vec2f:F((e,n)=>e+n),vec2h:j((e,n)=>e+n),vec2i:J((e,n)=>e+n),vec2u:Q((e,n)=>e+n),vec3f:A((e,n)=>e+n),vec3h:P((e,n)=>e+n),vec3i:X((e,n)=>e+n),vec3u:Y((e,n)=>e+n),vec4f:p((e,n)=>e+n),vec4h:Z((e,n)=>e+n),vec4i:ee((e,n)=>e+n),vec4u:ne((e,n)=>e+n),mat2x2f:fe((e,n)=>e+n),mat3x3f:ge((e,n)=>e+n),mat4x4f:he((e,n)=>e+n)},addMixed:{vec2f:(e,n)=>u(s=>s+n)(e),vec2h:(e,n)=>w(s=>s+n)(e),vec2i:(e,n)=>R(s=>s+n)(e),vec2u:(e,n)=>K(s=>s+n)(e),vec3f:(e,n)=>y(s=>s+n)(e),vec3h:(e,n)=>l(s=>s+n)(e),vec3i:(e,n)=>$(s=>s+n)(e),vec3u:(e,n)=>k(s=>s+n)(e),vec4f:(e,n)=>x(s=>s+n)(e),vec4h:(e,n)=>o(s=>s+n)(e),vec4i:(e,n)=>N(s=>s+n)(e),vec4u:(e,n)=>O(s=>s+n)(e),mat2x2f:(e,n)=>ue(s=>s+n)(e),mat3x3f:(e,n)=>we(s=>s+n)(e),mat4x4f:(e,n)=>le(s=>s+n)(e)},mulSxV:{vec2f:(e,n)=>u(s=>e*s)(n),vec2h:(e,n)=>w(s=>e*s)(n),vec2i:(e,n)=>R(s=>e*s)(n),vec2u:(e,n)=>K(s=>e*s)(n),vec3f:(e,n)=>y(s=>e*s)(n),vec3h:(e,n)=>l(s=>e*s)(n),vec3i:(e,n)=>$(s=>e*s)(n),vec3u:(e,n)=>k(s=>e*s)(n),vec4f:(e,n)=>x(s=>e*s)(n),vec4h:(e,n)=>o(s=>e*s)(n),vec4i:(e,n)=>N(s=>e*s)(n),vec4u:(e,n)=>O(s=>e*s)(n),mat2x2f:(e,n)=>ue(s=>e*s)(n),mat3x3f:(e,n)=>we(s=>e*s)(n),mat4x4f:(e,n)=>le(s=>e*s)(n)},mulVxV:{vec2f:F((e,n)=>e*n),vec2h:j((e,n)=>e*n),vec2i:J((e,n)=>e*n),vec2u:Q((e,n)=>e*n),vec3f:A((e,n)=>e*n),vec3h:P((e,n)=>e*n),vec3i:X((e,n)=>e*n),vec3u:Y((e,n)=>e*n),vec4f:p((e,n)=>e*n),vec4h:Z((e,n)=>e*n),vec4i:ee((e,n)=>e*n),vec4u:ne((e,n)=>e*n),mat2x2f:(e,n)=>{let s=e.columns,t=n.columns;return se(s[0].x*t[0].x+s[1].x*t[0].y,s[0].y*t[0].x+s[1].y*t[0].y,s[0].x*t[1].x+s[1].x*t[1].y,s[0].y*t[1].x+s[1].y*t[1].y)},mat3x3f:(e,n)=>{let s=e.columns,t=n.columns;return te(s[0].x*t[0].x+s[1].x*t[0].y+s[2].x*t[0].z,s[0].y*t[0].x+s[1].y*t[0].y+s[2].y*t[0].z,s[0].z*t[0].x+s[1].z*t[0].y+s[2].z*t[0].z,s[0].x*t[1].x+s[1].x*t[1].y+s[2].x*t[1].z,s[0].y*t[1].x+s[1].y*t[1].y+s[2].y*t[1].z,s[0].z*t[1].x+s[1].z*t[1].y+s[2].z*t[1].z,s[0].x*t[2].x+s[1].x*t[2].y+s[2].x*t[2].z,s[0].y*t[2].x+s[1].y*t[2].y+s[2].y*t[2].z,s[0].z*t[2].x+s[1].z*t[2].y+s[2].z*t[2].z)},mat4x4f:(e,n)=>{let s=e.columns,t=n.columns;return ce(s[0].x*t[0].x+s[1].x*t[0].y+s[2].x*t[0].z+s[3].x*t[0].w,s[0].y*t[0].x+s[1].y*t[0].y+s[2].y*t[0].z+s[3].y*t[0].w,s[0].z*t[0].x+s[1].z*t[0].y+s[2].z*t[0].z+s[3].z*t[0].w,s[0].w*t[0].x+s[1].w*t[0].y+s[2].w*t[0].z+s[3].w*t[0].w,s[0].x*t[1].x+s[1].x*t[1].y+s[2].x*t[1].z+s[3].x*t[1].w,s[0].y*t[1].x+s[1].y*t[1].y+s[2].y*t[1].z+s[3].y*t[1].w,s[0].z*t[1].x+s[1].z*t[1].y+s[2].z*t[1].z+s[3].z*t[1].w,s[0].w*t[1].x+s[1].w*t[1].y+s[2].w*t[1].z+s[3].w*t[1].w,s[0].x*t[2].x+s[1].x*t[2].y+s[2].x*t[2].z+s[3].x*t[2].w,s[0].y*t[2].x+s[1].y*t[2].y+s[2].y*t[2].z+s[3].y*t[2].w,s[0].z*t[2].x+s[1].z*t[2].y+s[2].z*t[2].z+s[3].z*t[2].w,s[0].w*t[2].x+s[1].w*t[2].y+s[2].w*t[2].z+s[3].w*t[2].w,s[0].x*t[3].x+s[1].x*t[3].y+s[2].x*t[3].z+s[3].x*t[3].w,s[0].y*t[3].x+s[1].y*t[3].y+s[2].y*t[3].z+s[3].y*t[3].w,s[0].z*t[3].x+s[1].z*t[3].y+s[2].z*t[3].z+s[3].z*t[3].w,s[0].w*t[3].x+s[1].w*t[3].y+s[2].w*t[3].z+s[3].w*t[3].w)}},mulMxV:{mat2x2f:(e,n)=>{let s=e.columns;return b(s[0].x*n.x+s[1].x*n.y,s[0].y*n.x+s[1].y*n.y)},mat3x3f:(e,n)=>{let s=e.columns;return h(s[0].x*n.x+s[1].x*n.y+s[2].x*n.z,s[0].y*n.x+s[1].y*n.y+s[2].y*n.z,s[0].z*n.x+s[1].z*n.y+s[2].z*n.z)},mat4x4f:(e,n)=>{let s=e.columns;return M(s[0].x*n.x+s[1].x*n.y+s[2].x*n.z+s[3].x*n.w,s[0].y*n.x+s[1].y*n.y+s[2].y*n.z+s[3].y*n.w,s[0].z*n.x+s[1].z*n.y+s[2].z*n.z+s[3].z*n.w,s[0].w*n.x+s[1].w*n.y+s[2].w*n.z+s[3].w*n.w)}},mulVxM:{mat2x2f:(e,n)=>{let s=n.columns;return b(e.x*s[0].x+e.y*s[0].y,e.x*s[1].x+e.y*s[1].y)},mat3x3f:(e,n)=>{let s=n.columns;return h(e.x*s[0].x+e.y*s[0].y+e.z*s[0].z,e.x*s[1].x+e.y*s[1].y+e.z*s[1].z,e.x*s[2].x+e.y*s[2].y+e.z*s[2].z)},mat4x4f:(e,n)=>{let s=n.columns;return M(e.x*s[0].x+e.y*s[0].y+e.z*s[0].z+e.w*s[0].w,e.x*s[1].x+e.y*s[1].y+e.z*s[1].z+e.w*s[1].w,e.x*s[2].x+e.y*s[2].y+e.z*s[2].z+e.w*s[2].w,e.x*s[3].x+e.y*s[3].y+e.z*s[3].z+e.w*s[3].w)}},div:{vec2f:F((e,n)=>e/n),vec2h:j((e,n)=>e/n),vec2i:J(d.divInteger),vec2u:Q(d.divInteger),vec3f:A((e,n)=>e/n),vec3h:P((e,n)=>e/n),vec3i:X(d.divInteger),vec3u:Y(d.divInteger),vec4f:p((e,n)=>e/n),vec4h:Z((e,n)=>e/n),vec4i:ee(d.divInteger),vec4u:ne(d.divInteger)},divMixed:{vec2f:(e,n)=>u(s=>s/n)(e),vec2h:(e,n)=>w(s=>s/n)(e),vec2i:(e,n)=>R(s=>d.divInteger(s,n))(e),vec2u:(e,n)=>K(s=>d.divInteger(s,n))(e),vec3f:(e,n)=>y(s=>s/n)(e),vec3h:(e,n)=>l(s=>s/n)(e),vec3i:(e,n)=>$(s=>d.divInteger(s,n))(e),vec3u:(e,n)=>k(s=>d.divInteger(s,n))(e),vec4f:(e,n)=>x(s=>s/n)(e),vec4h:(e,n)=>o(s=>s/n)(e),vec4i:(e,n)=>N(s=>d.divInteger(s,n))(e),vec4u:(e,n)=>O(s=>d.divInteger(s,n))(e)},dot:{vec2f:ae,vec2h:ae,vec2i:ae,vec2u:ae,vec3f:re,vec3h:re,vec3i:re,vec3u:re,vec4f:ve,vec4h:ve,vec4i:ve,vec4u:ve},normalize:{vec2f:e=>{let n=S(e);return b(e.x/n,e.y/n)},vec2h:e=>{let n=S(e);return I(e.x/n,e.y/n)},vec2i:e=>{let n=S(e);return L(e.x/n,e.y/n)},vec2u:e=>{let n=S(e);return _(e.x/n,e.y/n)},vec3f:e=>{let n=D(e);return h(e.x/n,e.y/n,e.z/n)},vec3h:e=>{let n=D(e);return z(e.x/n,e.y/n,e.z/n)},vec3i:e=>{let n=D(e);return U(e.x/n,e.y/n,e.z/n)},vec3u:e=>{let n=D(e);return W(e.x/n,e.y/n,e.z/n)},vec4f:e=>{let n=E(e);return M(e.x/n,e.y/n,e.z/n,e.w/n)},vec4h:e=>{let n=E(e);return B(e.x/n,e.y/n,e.z/n,e.w/n)},vec4i:e=>{let n=E(e);return q(e.x/n,e.y/n,e.z/n,e.w/n)},vec4u:e=>{let n=E(e);return C(e.x/n,e.y/n,e.z/n,e.w/n)}},cross:{vec3f:(e,n)=>h(e.y*n.z-e.z*n.y,e.z*n.x-e.x*n.z,e.x*n.y-e.y*n.x),vec3h:(e,n)=>z(e.y*n.z-e.z*n.y,e.z*n.x-e.x*n.z,e.x*n.y-e.y*n.x)},floor:{vec2f:u(Math.floor),vec2h:w(Math.floor),vec3f:y(Math.floor),vec3h:l(Math.floor),vec4f:x(Math.floor),vec4h:o(Math.floor)},max:{vec2f:F(Math.max),vec2h:j(Math.max),vec2i:J(Math.max),vec2u:Q(Math.max),vec3f:A(Math.max),vec3h:P(Math.max),vec3i:X(Math.max),vec3u:Y(Math.max),vec4f:p(Math.max),vec4h:Z(Math.max),vec4i:ee(Math.max),vec4u:ne(Math.max)},min:{vec2f:F(Math.min),vec2h:j(Math.min),vec2i:J(Math.min),vec2u:Q(Math.min),vec3f:A(Math.min),vec3h:P(Math.min),vec3i:X(Math.min),vec3u:Y(Math.min),vec4f:p(Math.min),vec4h:Z(Math.min),vec4i:ee(Math.min),vec4u:ne(Math.min)},pow:{vec2f:(e,n)=>b(e.x**n.x,e.y**n.y),vec2h:(e,n)=>I(e.x**n.x,e.y**n.y),vec3f:(e,n)=>h(e.x**n.x,e.y**n.y,e.z**n.z),vec3h:(e,n)=>z(e.x**n.x,e.y**n.y,e.z**n.z),vec4f:(e,n)=>M(e.x**n.x,e.y**n.y,e.z**n.z,e.w**n.w),vec4h:(e,n)=>B(e.x**n.x,e.y**n.y,e.z**n.z,e.w**n.w)},sign:{vec2f:u(Math.sign),vec2h:w(Math.sign),vec2i:R(Math.sign),vec3f:y(Math.sign),vec3h:l(Math.sign),vec3i:$(Math.sign),vec4f:x(Math.sign),vec4h:o(Math.sign),vec4i:N(Math.sign)},sqrt:{vec2f:u(Math.sqrt),vec2h:w(Math.sqrt),vec3f:y(Math.sqrt),vec3h:l(Math.sqrt),vec4f:x(Math.sqrt),vec4h:o(Math.sqrt)},mix:{vec2f:(e,n,s)=>typeof s=="number"?b(e.x*(1-s)+n.x*s,e.y*(1-s)+n.y*s):b(e.x*(1-s.x)+n.x*s.x,e.y*(1-s.y)+n.y*s.y),vec2h:(e,n,s)=>typeof s=="number"?I(e.x*(1-s)+n.x*s,e.y*(1-s)+n.y*s):I(e.x*(1-s.x)+n.x*s.x,e.y*(1-s.y)+n.y*s.y),vec3f:(e,n,s)=>typeof s=="number"?h(e.x*(1-s)+n.x*s,e.y*(1-s)+n.y*s,e.z*(1-s)+n.z*s):h(e.x*(1-s.x)+n.x*s.x,e.y*(1-s.y)+n.y*s.y,e.z*(1-s.z)+n.z*s.z),vec3h:(e,n,s)=>typeof s=="number"?z(e.x*(1-s)+n.x*s,e.y*(1-s)+n.y*s,e.z*(1-s)+n.z*s):z(e.x*(1-s.x)+n.x*s.x,e.y*(1-s.y)+n.y*s.y,e.z*(1-s.z)+n.z*s.z),vec4f:(e,n,s)=>typeof s=="number"?M(e.x*(1-s)+n.x*s,e.y*(1-s)+n.y*s,e.z*(1-s)+n.z*s,e.w*(1-s)+n.w*s):M(e.x*(1-s.x)+n.x*s.x,e.y*(1-s.y)+n.y*s.y,e.z*(1-s.z)+n.z*s.z,e.w*(1-s.w)+n.w*s.w),vec4h:(e,n,s)=>typeof s=="number"?B(e.x*(1-s)+n.x*s,e.y*(1-s)+n.y*s,e.z*(1-s)+n.z*s,e.w*(1-s)+n.w*s):B(e.x*(1-s.x)+n.x*s.x,e.y*(1-s.y)+n.y*s.y,e.z*(1-s.z)+n.z*s.z,e.w*(1-s.w)+n.w*s.w)},sin:{vec2f:u(Math.sin),vec2h:w(Math.sin),vec3f:y(Math.sin),vec3h:l(Math.sin),vec4f:x(Math.sin),vec4h:o(Math.sin)},cos:{vec2f:u(Math.cos),vec2h:w(Math.cos),vec3f:y(Math.cos),vec3h:l(Math.cos),vec4f:x(Math.cos),vec4h:o(Math.cos)},cosh:{vec2f:u(Math.cosh),vec2h:w(Math.cosh),vec3f:y(Math.cosh),vec3h:l(Math.cosh),vec4f:x(Math.cosh),vec4h:o(Math.cosh)},exp:{vec2f:u(Math.exp),vec2h:w(Math.exp),vec3f:y(Math.exp),vec3h:l(Math.exp),vec4f:x(Math.exp),vec4h:o(Math.exp)},exp2:{vec2f:u(e=>2**e),vec2h:w(e=>2**e),vec3f:y(e=>2**e),vec3h:l(e=>2**e),vec4f:x(e=>2**e),vec4h:o(e=>2**e)},log:{vec2f:u(Math.log),vec2h:w(Math.log),vec3f:y(Math.log),vec3h:l(Math.log),vec4f:x(Math.log),vec4h:o(Math.log)},log2:{vec2f:u(Math.log2),vec2h:w(Math.log2),vec3f:y(Math.log2),vec3h:l(Math.log2),vec4f:x(Math.log2),vec4h:o(Math.log2)},fract:{vec2f:u(e=>e-Math.floor(e)),vec2h:w(e=>e-Math.floor(e)),vec3f:y(e=>e-Math.floor(e)),vec3h:l(e=>e-Math.floor(e)),vec4f:x(e=>e-Math.floor(e)),vec4h:o(e=>e-Math.floor(e))},isCloseToZero:{vec2f:(e,n)=>Math.abs(e.x)<=n&&Math.abs(e.y)<=n,vec2h:(e,n)=>Math.abs(e.x)<=n&&Math.abs(e.y)<=n,vec3f:(e,n)=>Math.abs(e.x)<=n&&Math.abs(e.y)<=n&&Math.abs(e.z)<=n,vec3h:(e,n)=>Math.abs(e.x)<=n&&Math.abs(e.y)<=n&&Math.abs(e.z)<=n,vec4f:(e,n)=>Math.abs(e.x)<=n&&Math.abs(e.y)<=n&&Math.abs(e.z)<=n&&Math.abs(e.w)<=n,vec4h:(e,n)=>Math.abs(e.x)<=n&&Math.abs(e.y)<=n&&Math.abs(e.z)<=n&&Math.abs(e.w)<=n},neg:{vec2f:u(e=>-e),vec2h:w(e=>-e),vec2i:R(e=>-e),vec2u:K(e=>-e),"vec2<bool>":e=>m(!e.x,!e.y),vec3f:y(e=>-e),vec3h:l(e=>-e),vec3i:$(e=>-e),vec3u:k(e=>-e),"vec3<bool>":e=>f(!e.x,!e.y,!e.z),vec4f:x(e=>-e),vec4h:o(e=>-e),vec4i:N(e=>-e),vec4u:O(e=>-e),"vec4<bool>":e=>g(!e.x,!e.y,!e.z,!e.w)},select:{vec2f:(e,n,s)=>b(s.x?n.x:e.x,s.y?n.y:e.y),vec2h:(e,n,s)=>I(s.x?n.x:e.x,s.y?n.y:e.y),vec2i:(e,n,s)=>L(s.x?n.x:e.x,s.y?n.y:e.y),vec2u:(e,n,s)=>_(s.x?n.x:e.x,s.y?n.y:e.y),"vec2<bool>":(e,n,s)=>m(s.x?n.x:e.x,s.y?n.y:e.y),vec3f:(e,n,s)=>h(s.x?n.x:e.x,s.y?n.y:e.y,s.z?n.z:e.z),vec3h:(e,n,s)=>z(s.x?n.x:e.x,s.y?n.y:e.y,s.z?n.z:e.z),vec3i:(e,n,s)=>U(s.x?n.x:e.x,s.y?n.y:e.y,s.z?n.z:e.z),vec3u:(e,n,s)=>W(s.x?n.x:e.x,s.y?n.y:e.y,s.z?n.z:e.z),"vec3<bool>":(e,n,s)=>f(s.x?n.x:e.x,s.y?n.y:e.y,s.z?n.z:e.z),vec4f:(e,n,s)=>M(s.x?n.x:e.x,s.y?n.y:e.y,s.z?n.z:e.z,s.w?n.w:e.w),vec4h:(e,n,s)=>B(s.x?n.x:e.x,s.y?n.y:e.y,s.z?n.z:e.z,s.w?n.w:e.w),vec4i:(e,n,s)=>q(s.x?n.x:e.x,s.y?n.y:e.y,s.z?n.z:e.z,s.w?n.w:e.w),vec4u:(e,n,s)=>C(s.x?n.x:e.x,s.y?n.y:e.y,s.z?n.z:e.z,s.w?n.w:e.w),"vec4<bool>":(e,n,s)=>g(s.x?n.x:e.x,s.y?n.y:e.y,s.z?n.z:e.z,s.w?n.w:e.w)},tanh:{vec2f:u(Math.tanh),vec2h:w(Math.tanh),vec3f:y(Math.tanh),vec3h:l(Math.tanh),vec4f:x(Math.tanh),vec4h:o(Math.tanh)}};function G(e){return de(e.dataType)}function de(e){let n=e?.type;return!!e?.[ye]&&(n==="abstractInt"||n==="abstractFloat"||n==="f32"||n==="f16"||n==="i32"||n==="u32")}function oe(e,n){if(typeof e=="number"&&typeof n=="number")return e+n;if(typeof e=="number"&&i(n))return c.addMixed[n.kind](n,e);if(i(e)&&typeof n=="number")return c.addMixed[e.kind](e,n);if(i(e)&&i(n)||V(e)&&V(n))return c.add[e.kind](e,n);throw new Error("Add/Sub called with invalid arguments.")}var ke=v(oe,(e,n)=>a(`(${e.value} + ${n.value})`,G(e)?n.dataType:e.dataType),"coerce");function Te(e,n){return oe(e,me(-1,n))}var ie=v(Te,(e,n)=>a(`(${e.value} - ${n.value})`,G(e)?n.dataType:e.dataType),"sub","coerce");function be(e,n){if(typeof e=="number"&&typeof n=="number")return e*n;if(typeof e=="number"&&(i(n)||V(n)))return c.mulSxV[n.kind](e,n);if((i(e)||V(e))&&typeof n=="number")return c.mulSxV[e.kind](n,e);if(i(e)&&i(n))return c.mulVxV[e.kind](e,n);if(xe(e)&&V(n))return c.mulVxM[n.kind](e,n);if(V(e)&&xe(n))return c.mulMxV[e.kind](e,n);if(V(e)&&V(n))return c.mulVxV[e.kind](e,n);throw new Error("Mul called with invalid arguments.")}var me=v(be,(e,n)=>{let s=G(e)?n.dataType:G(n)||e.dataType.type.startsWith("vec")?e.dataType:n.dataType.type.startsWith("vec")?n.dataType:e.dataType;return a(`(${e.value} * ${n.value})`,s)},"mul");function Me(e,n){if(typeof e=="number"&&typeof n=="number")return e/n;if(typeof e=="number"&&i(n))return c.divMixed[n.kind](n,e);if(i(e)&&typeof n=="number")return c.divMixed[e.kind](e,n);if(i(e)&&i(n))return c.div[e.kind](e,n);throw new Error("Div called with invalid arguments.")}var Oe=v(Me,(e,n)=>G(e)&&G(n)?a(`(f32(${e.value}) / ${n.value})`,H):a(`(${e.value} / ${n.value})`,e.dataType),"div"),Le=v(e=>typeof e=="number"?Math.abs(e):c.abs[e.kind](e),e=>a(`abs(${e.value})`,e.dataType),"abs"),_e=v((e,n)=>typeof e=="number"&&typeof n=="number"?Math.atan2(e,n):c.atan2[e.kind](e,n),(e,n)=>a(`atan2(${e.value}, ${n.value})`,e.dataType),"atan2"),Ue=v(e=>typeof e=="number"?Math.acos(e):c.acos[e.kind](e),e=>a(`acos(${e.value})`,e.dataType),"acos"),We=v(e=>typeof e=="number"?Math.acosh(e):c.acosh[e.kind](e),e=>a(`acosh(${e.value})`,e.dataType),"acosh"),qe=v(e=>typeof e=="number"?Math.asin(e):c.asin[e.kind](e),e=>a(`asin(${e.value})`,e.dataType),"asin"),Ce=v(e=>typeof e=="number"?Math.ceil(e):c.ceil[e.kind](e),e=>a(`ceil(${e.value})`,e.dataType),"ceil"),Se=v((e,n,s)=>typeof e=="number"?Math.min(Math.max(n,e),s):c.clamp[e.kind](e,n,s),(e,n,s)=>a(`clamp(${e.value}, ${n.value}, ${s.value})`,e.dataType),"clamp"),De=v(e=>typeof e=="number"?Math.cos(e):c.cos[e.kind](e),e=>a(`cos(${e.value})`,e.dataType),"cos"),Ee=v(e=>typeof e=="number"?Math.cosh(e):c.cosh[e.kind](e),e=>a(`cosh(${e.value})`,e.dataType),"cosh"),je=v((e,n)=>c.cross[e.kind](e,n),(e,n)=>a(`cross(${e.value}, ${n.value})`,e.dataType),"cross"),ze=v((e,n)=>c.dot[e.kind](e,n),(e,n)=>a(`dot(${e.value}, ${n.value})`,H),"dot"),Pe=v(e=>c.normalize[e.kind](e),e=>a(`normalize(${e.value})`,e.dataType),"normalize"),Ze=v(e=>typeof e=="number"?Math.floor(e):c.floor[e.kind](e),e=>a(`floor(${e.value})`,e.dataType),"floor"),Ge=v(e=>typeof e=="number"?e-Math.floor(e):c.fract[e.kind](e),e=>a(`fract(${e.value})`,e.dataType),"fract"),pe=v(e=>typeof e=="number"?Math.abs(e):c.length[e.kind](e),e=>a(`length(${e.value})`,H),"length"),He=v(e=>typeof e=="number"?Math.log(e):c.log[e.kind](e),e=>a(`log(${e.value})`,e.dataType),"log"),Je=v(e=>typeof e=="number"?Math.log2(e):c.log2[e.kind](e),e=>a(`log2(${e.value})`,e.dataType),"log2"),Qe=v((e,n)=>typeof e=="number"?Math.max(e,n):c.max[e.kind](e,n),(e,n)=>a(`max(${e.value}, ${n.value})`,e.dataType),"max","coerce"),Xe=v((e,n)=>typeof e=="number"?Math.min(e,n):c.min[e.kind](e,n),(e,n)=>a(`min(${e.value}, ${n.value})`,e.dataType),"min","coerce"),Ye=v(e=>typeof e=="number"?Math.sign(e):c.sign[e.kind](e),e=>a(`sign(${e.value})`,e.dataType),"sign"),en=v(e=>typeof e=="number"?Math.sin(e):c.sin[e.kind](e),e=>a(`sin(${e.value})`,e.dataType),"sin"),nn=v(e=>typeof e=="number"?Math.exp(e):c.exp[e.kind](e),e=>a(`exp(${e.value})`,e.dataType),"exp"),sn=v(e=>typeof e=="number"?2**e:c.exp2[e.kind](e),e=>a(`exp2(${e.value})`,e.dataType),"exp2"),tn=v((e,n)=>{if(typeof e=="number"&&typeof n=="number")return e**n;if(typeof e=="object"&&typeof n=="object"&&"kind"in e&&"kind"in n)return c.pow[e.kind](e,n);throw new Error("Invalid arguments to pow()")},(e,n)=>a(`pow(${e.value}, ${n.value})`,e.dataType),"pow"),cn=v((e,n,s)=>{if(typeof e=="number"){if(typeof s!="number"||typeof n!="number")throw new Error("When e1 and e2 are numbers, the blend factor must be a number.");return e*(1-s)+n*s}if(typeof e=="number"||typeof n=="number")throw new Error("e1 and e2 need to both be vectors of the same kind.");return c.mix[e.kind](e,n,s)},(e,n,s)=>a(`mix(${e.value}, ${n.value}, ${s.value})`,e.dataType),"mix"),an=v((e,n)=>ie(e,me(2*ze(n,e),n)),(e,n)=>a(`reflect(${e.value}, ${n.value})`,e.dataType),"reflect"),rn=v((e,n)=>typeof e=="number"&&typeof n=="number"?Math.abs(e-n):pe(ie(e,n)),(e,n)=>a(`distance(${e.value}, ${n.value})`,H),"distance"),vn=v(e=>typeof e=="number"?-e:c.neg[e.kind](e),e=>a(`-(${e.value})`,e.dataType),"neg"),xn=v(e=>typeof e=="number"?Math.sqrt(e):c.sqrt[e.kind](e),e=>a(`sqrt(${e.value})`,e.dataType),"sqrt"),yn=v(e=>typeof e=="number"?Math.tanh(e):c.tanh[e.kind](e),e=>a(`tanh(${e.value})`,e.dataType),"tanh");export{c as a,G as b,de as c,ke as d,ie as e,me as f,Oe as g,Le as h,_e as i,Ue as j,We as k,qe as l,Ce as m,Se as n,De as o,Ee as p,je as q,ze as r,Pe as s,Ze as t,Ge as u,pe as v,He as w,Je as x,Qe as y,Xe as z,Ye as A,en as B,nn as C,sn as D,tn as E,cn as F,an as G,rn as H,vn as I,xn as J,yn as K};
2
+ //# sourceMappingURL=chunk-RK6TMFVW.js.map
@@ -0,0 +1,2 @@
1
+ import{$ as m,Ba as p,Da as S,Ea as F,M as P,N as v,O as A,R as U,S as O,V as z,W as y,Y as E,Z as T,_ as g,a as i,aa as D,ba as H,i as _,j as L,la as N,ma as s,oa as w,pa as c,ra as f,ta as h,ua as V,wa as C,ya as M,za as d}from"./chunk-APTRHY5Y.js";function J(t,e){let r=e;try{r=t(e)}catch{let o=t?.type;console.warn(`Schema of type ${o??"<unknown>"} is not callable.`)}return r}function Z(t){let e=r=>Object.fromEntries(Object.entries(t).map(([o,x])=>[o,J(x,r[o])]));return Object.setPrototypeOf(e,tt),e.propTypes=t,e}var tt={[i]:!0,type:"struct",$name(t){return L(this,t),this},toString(){return`struct:${_(this)??"<unnamed>"}`}};var b=(t,e)=>{let r=e-1,o=~r;return(t&r)===0?t:(t&o)+e};var n=class{constructor(e){this.type=e}[i]=!0},et={uint8:s,uint8x2:V,uint8x4:F,sint8:w,sint8x2:h,sint8x4:S,unorm8:c,unorm8x2:f,unorm8x4:p,snorm8:c,snorm8x2:f,snorm8x4:p,uint16:s,uint16x2:V,uint16x4:F,sint16:w,sint16x2:h,sint16x4:S,unorm16:c,unorm16x2:f,unorm16x4:p,snorm16:c,snorm16x2:f,snorm16x4:p,float16:c,float16x2:f,float16x4:p,float32:c,float32x2:f,float32x3:C,float32x4:p,uint32:s,uint32x2:V,uint32x3:d,uint32x4:F,sint32:w,sint32x2:h,sint32x3:M,sint32x4:S,"unorm10-10-10-2":p,"unorm8x4-bgra":p},q=Object.keys(et),_t=new n("uint8"),Lt=new n("uint8x2"),$t=new n("uint8x4"),Wt=new n("sint8"),kt=new n("sint8x2"),Pt=new n("sint8x4"),Ut=new n("unorm8"),Ot=new n("unorm8x2"),zt=new n("unorm8x4"),Et=new n("snorm8"),Nt=new n("snorm8x2"),Ct=new n("snorm8x4"),Mt=new n("uint16"),Gt=new n("uint16x2"),jt=new n("uint16x4"),Rt=new n("sint16"),Kt=new n("sint16x2"),Ht=new n("sint16x4"),Jt=new n("unorm16"),qt=new n("unorm16x2"),Qt=new n("unorm16x4"),Xt=new n("snorm16"),Yt=new n("snorm16x2"),Zt=new n("snorm16x4"),te=new n("float16"),ee=new n("float16x2"),ne=new n("float16x4"),re=new n("float32"),oe=new n("float32x2"),ie=new n("float32x3"),ae=new n("float32x4"),se=new n("uint32"),pe=new n("uint32x2"),ue=new n("uint32x3"),le=new n("uint32x4"),xe=new n("sint32"),me=new n("sint32x2"),ce=new n("sint32x3"),ye=new n("sint32x4"),fe=new n("unorm10-10-10-2"),de=new n("unorm8x4-bgra");var nt={f32:4,f16:2,i32:4,u32:4,u16:2,vec2f:8,vec2h:4,vec2i:8,vec2u:8,vec3f:16,vec3h:8,vec3i:16,vec3u:16,vec4f:16,vec4h:8,vec4i:16,vec4u:16,mat2x2f:8,mat3x3f:16,mat4x4f:16,atomic:4};function rt(t){let e=t?.type,r=nt[e];if(r!==void 0)return r;if(A(t))return Object.values(t.propTypes).map(u).reduce((o,x)=>o>x?o:x);if(v(t))return u(t.elementType);if(g(t)){let o=Object.values(t.propTypes)[0];return o?D(o)??1:1}if(T(t))return D(t.elementType)??1;if(y(t)||m(t))return D(t)??u(t.inner);if(q.includes(e))return 1;throw new Error(`Cannot determine alignment of data: ${JSON.stringify(t)}`)}function ot(t){if(g(t)){let e=Object.values(t.propTypes)[0];return e?I(e):1}return T(t)?I(t.elementType):m(t)?D(t)??I(t.inner):D(t)??1}var Q=new WeakMap,X=new WeakMap;function u(t){let e=Q.get(t);return e===void 0&&(e=rt(t),Q.set(t,e)),e}function I(t){let e=X.get(t);return e===void 0&&(e=ot(t),X.set(t,e)),e}function it(t){return u(t)}var at={f32:4,f16:2,i32:4,u32:4,u16:2,vec2f:8,vec2h:4,vec2i:8,vec2u:8,vec3f:12,vec3h:6,vec3i:12,vec3u:12,vec4f:16,vec4h:8,vec4i:16,vec4u:16,mat2x2f:16,mat3x3f:48,mat4x4f:64,uint8:1,uint8x2:2,uint8x4:4,sint8:1,sint8x2:2,sint8x4:4,unorm8:1,unorm8x2:2,unorm8x4:4,snorm8:1,snorm8x2:2,snorm8x4:4,uint16:2,uint16x2:4,uint16x4:8,sint16:2,sint16x2:4,sint16x4:8,unorm16:2,unorm16x2:4,unorm16x4:8,snorm16:2,snorm16x2:4,snorm16x4:8,float16:2,float16x2:4,float16x4:8,float32:4,float32x2:8,float32x3:12,float32x4:16,uint32:4,uint32x2:8,uint32x3:12,uint32x4:16,sint32:4,sint32x2:8,sint32x3:12,sint32x4:16,"unorm10-10-10-2":4,"unorm8x4-bgra":4,atomic:4};function st(t){let e=0;for(let r of Object.values(t.propTypes)){if(Number.isNaN(e))throw new Error("Only the last property of a struct can be unbounded");if(e=b(e,u(r)),e+=l(r),Number.isNaN(e)&&r.type!=="array")throw new Error("Cannot nest unbounded struct within another struct")}return b(e,u(t))}function pt(t){let e=0;for(let r of Object.values(t.propTypes)){let o=I(r);e=b(e,o),e+=l(r)}return e}function ut(t){let e=at[t?.type];if(e!==void 0)return e;if(A(t))return st(t);if(g(t))return pt(t);if(v(t)){if(t.elementCount===0)return Number.NaN;let r=u(t.elementType);return b(l(t.elementType),r)*t.elementCount}if(T(t)){let r=I(t.elementType);return b(l(t.elementType),r)*t.elementCount}if(y(t)||m(t))return H(t)??l(t.inner);throw new Error(`Cannot determine size of data: ${t}`)}var Y=new WeakMap;function l(t){let e=Y.get(t);return e===void 0&&(e=ut(t),Y.set(t,e)),e}function lt(t){return l(t)}function j(t,e){return new G(t,e)}var G=class{constructor(e,r){this.elementType=e;this.elementCount=r;if(Number.isNaN(l(e)))throw new Error("Cannot nest runtime sized arrays.");if(!Number.isInteger(r)||r<0)throw new Error(`Cannot create array schema with invalid element count: ${r}.`)}[i]=!0;type="array";toString(){return`arrayOf(${this.elementType})`}};function xt(t,e){return new R(t,e)}var R=class{constructor(e,r){this.elementType=e;this.elementCount=r;if(!Number.isInteger(r)||r<0)throw new Error(`Cannot create disarray schema with invalid element count: ${r}.`)}[i]=!0;type="disarray"};function mt(t){let e=r=>r;return Object.setPrototypeOf(e,ct),e.propTypes=t,e}var ct={[i]:!0,type:"unstruct",$name(t){return L(this,t),this},toString(){return`unstruct:${_(this)??"<unnamed>"}`}};function yt(t){return new K(t)}var K=class{constructor(e){this.inner=e}[i]=!0;type="atomic"};function B(t,e){return y(t)?new W(t.inner,[e,...t.attribs]):m(t)?new k(t.inner,[e,...t.attribs]):E(t)?new k(t,[e]):new W(t,[e])}function ft(t,e){return B(e,{[i]:!0,type:"@align",value:t})}function dt(t,e){return B(e,{[i]:!0,type:"@size",value:t})}function Tt(t,e){return B(e,{[i]:!0,type:"@location",value:t})}function gt(t,e){return B(e,{[i]:!0,type:"@interpolate",value:t})}function Dt(t){return(y(t)||m(t))&&t.attribs.find(z)!==void 0}function Me(t){return!y(t)&&!m(t)?"":t.attribs.map(e=>`${e.type}(${e.value}) `).join("")}var $=class{constructor(e,r){this.inner=e;this.attribs=r;let o=r.find(U)?.value,x=r.find(O)?.value;if(o!==void 0){if(o<=0)throw new Error(`Custom data alignment must be a positive number, got: ${o}.`);if(Math.log2(o)%1!==0)throw new Error(`Alignment has to be a power of 2, got: ${o}.`);if(P(this.inner)&&o%u(this.inner)!==0)throw new Error(`Custom alignment has to be a multiple of the standard data alignment. Got: ${o}, expected multiple of: ${u(this.inner)}.`)}if(x!==void 0){if(x<l(this.inner))throw new Error(`Custom data size cannot be smaller then the standard data size. Got: ${x}, expected at least: ${l(this.inner)}.`);if(x<=0)throw new Error(`Custom data size must be a positive number. Got: ${x}.`)}}[i]=!0},W=class extends ${[i]=!0;type="decorated"},k=class extends ${[i]=!0;type="loose-decorated"};function a(t,e){return B(t,{[i]:!0,type:"@builtin",value:e})}var bt={vertexIndex:a(s,"vertex_index"),instanceIndex:a(s,"instance_index"),position:a(p,"position"),clipDistances:a(j(s,8),"clip_distances"),frontFacing:a(N,"front_facing"),fragDepth:a(c,"frag_depth"),sampleIndex:a(s,"sample_index"),sampleMask:a(s,"sample_mask"),localInvocationId:a(d,"local_invocation_id"),localInvocationIndex:a(s,"local_invocation_index"),globalInvocationId:a(d,"global_invocation_id"),workgroupId:a(d,"workgroup_id"),numWorkgroups:a(d,"num_workgroups"),subgroupInvocationId:a(s,"subgroup_invocation_id"),subgroupSize:a(s,"subgroup_size")};export{b as a,et as b,q as c,_t as d,Lt as e,$t as f,Wt as g,kt as h,Pt as i,Ut as j,Ot as k,zt as l,Et as m,Nt as n,Ct as o,Mt as p,Gt as q,jt as r,Rt as s,Kt as t,Ht as u,Jt as v,qt as w,Qt as x,Xt as y,Yt as z,Zt as A,te as B,ee as C,ne as D,re as E,oe as F,ie as G,ae as H,se as I,pe as J,ue as K,le as L,xe as M,me as N,ce as O,ye as P,fe as Q,de as R,u as S,I as T,it as U,l as V,lt as W,j as X,ft as Y,dt as Z,Tt as _,gt as $,Dt as aa,Me as ba,J as ca,Z as da,xt as ea,mt as fa,yt as ga,bt as ha};
2
+ //# sourceMappingURL=chunk-S62QJDM6.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/data/utils.ts","../src/data/struct.ts","../src/mathUtils.ts","../src/data/vertexFormatData.ts","../src/data/alignmentOf.ts","../src/data/sizeOf.ts","../src/data/array.ts","../src/data/disarray.ts","../src/data/unstruct.ts","../src/data/atomic.ts","../src/data/attributes.ts","../src/builtin.ts"],"sourcesContent":["/**\n * A wrapper for `schema(item)` call.\n * Logs a warning if the schema is not callable.\n */\nexport function schemaCallWrapper<T>(schema: unknown, item: T): T {\n let result = item;\n try {\n result = (\n schema as unknown as ((item: typeof result) => typeof result)\n )(item);\n } catch {\n const maybeType = (schema as { type: string })?.type;\n console.warn(`Schema of type ${maybeType ?? '<unknown>'} is not callable.`);\n }\n return result;\n}\n","import { getName, setName } from '../shared/meta.ts';\nimport { $internal } from '../shared/symbols.ts';\nimport { schemaCallWrapper } from './utils.ts';\nimport type { AnyWgslData, WgslStruct } from './wgslTypes.ts';\n\n// ----------\n// Public API\n// ----------\n\n/**\n * Creates a struct schema that can be used to construct GPU buffers.\n * Ensures proper alignment and padding of properties (as opposed to a `d.unstruct` schema).\n * The order of members matches the passed in properties object.\n *\n * @example\n * const CircleStruct = d.struct({ radius: d.f32, pos: d.vec3f });\n *\n * @param props Record with `string` keys and `TgpuData` values,\n * each entry describing one struct member.\n */\nexport function struct<TProps extends Record<string, AnyWgslData>>(\n props: TProps,\n): WgslStruct<TProps> {\n // in the schema call, create and return a deep copy\n // by wrapping all the values in corresponding schema calls\n const structSchema = <T extends TProps>(instanceProps: T) =>\n Object.fromEntries(\n Object.entries(props).map((\n [key, schema],\n ) => [key, schemaCallWrapper(schema, instanceProps[key])]),\n );\n Object.setPrototypeOf(structSchema, WgslStructImpl);\n structSchema.propTypes = props;\n\n return structSchema as WgslStruct<TProps>;\n}\n\n// --------------\n// Implementation\n// --------------\n\nconst WgslStructImpl = {\n [$internal]: true,\n type: 'struct',\n\n $name(label: string) {\n setName(this, label);\n return this;\n },\n\n toString(): string {\n return `struct:${getName(this) ?? '<unnamed>'}`;\n },\n};\n","/**\n * @param value\n * @param modulo has to be power of 2\n */\nexport const roundUp = (value: number, modulo: number) => {\n const bitMask = modulo - 1;\n const invBitMask = ~bitMask;\n return (value & bitMask) === 0 ? value : (value & invBitMask) + modulo;\n};\n","import type { Infer } from '../shared/repr.ts';\nimport { $internal } from '../shared/symbols.ts';\nimport type { $repr } from '../shared/symbols.ts';\nimport type { VertexFormat } from '../shared/vertexFormat.ts';\nimport { f32, i32, u32 } from './numeric.ts';\nimport {\n vec2f,\n vec2i,\n vec2u,\n vec3f,\n vec3i,\n vec3u,\n vec4f,\n vec4i,\n vec4u,\n} from './vector.ts';\n\nexport type FormatToWGSLType<T extends VertexFormat> =\n (typeof formatToWGSLType)[T];\n\nexport interface TgpuVertexFormatData<T extends VertexFormat> {\n readonly [$internal]: true;\n readonly type: T;\n readonly [$repr]: Infer<FormatToWGSLType<T>>;\n}\n\nclass TgpuVertexFormatDataImpl<T extends VertexFormat>\n implements TgpuVertexFormatData<T> {\n public readonly [$internal] = true;\n\n // Type-tokens, not available at runtime\n declare readonly [$repr]: Infer<FormatToWGSLType<T>>;\n // ---\n\n constructor(public readonly type: T) {}\n}\n\nexport const formatToWGSLType = {\n uint8: u32,\n uint8x2: vec2u,\n uint8x4: vec4u,\n sint8: i32,\n sint8x2: vec2i,\n sint8x4: vec4i,\n unorm8: f32,\n unorm8x2: vec2f,\n unorm8x4: vec4f,\n snorm8: f32,\n snorm8x2: vec2f,\n snorm8x4: vec4f,\n uint16: u32,\n uint16x2: vec2u,\n uint16x4: vec4u,\n sint16: i32,\n sint16x2: vec2i,\n sint16x4: vec4i,\n unorm16: f32,\n unorm16x2: vec2f,\n unorm16x4: vec4f,\n snorm16: f32,\n snorm16x2: vec2f,\n snorm16x4: vec4f,\n float16: f32,\n float16x2: vec2f,\n float16x4: vec4f,\n float32: f32,\n float32x2: vec2f,\n float32x3: vec3f,\n float32x4: vec4f,\n uint32: u32,\n uint32x2: vec2u,\n uint32x3: vec3u,\n uint32x4: vec4u,\n sint32: i32,\n sint32x2: vec2i,\n sint32x3: vec3i,\n sint32x4: vec4i,\n 'unorm10-10-10-2': vec4f,\n 'unorm8x4-bgra': vec4f,\n} as const;\n\nexport const packedFormats = Object.keys(formatToWGSLType);\n\nexport type uint8 = TgpuVertexFormatData<'uint8'>;\nexport const uint8 = new TgpuVertexFormatDataImpl('uint8') as uint8;\n\nexport type uint8x2 = TgpuVertexFormatData<'uint8x2'>;\nexport const uint8x2 = new TgpuVertexFormatDataImpl('uint8x2') as uint8x2;\n\nexport type uint8x4 = TgpuVertexFormatData<'uint8x4'>;\nexport const uint8x4 = new TgpuVertexFormatDataImpl('uint8x4') as uint8x4;\n\nexport type sint8 = TgpuVertexFormatData<'sint8'>;\nexport const sint8 = new TgpuVertexFormatDataImpl('sint8') as sint8;\n\nexport type sint8x2 = TgpuVertexFormatData<'sint8x2'>;\nexport const sint8x2 = new TgpuVertexFormatDataImpl('sint8x2') as sint8x2;\n\nexport type sint8x4 = TgpuVertexFormatData<'sint8x4'>;\nexport const sint8x4 = new TgpuVertexFormatDataImpl('sint8x4') as sint8x4;\n\nexport type unorm8 = TgpuVertexFormatData<'unorm8'>;\nexport const unorm8 = new TgpuVertexFormatDataImpl('unorm8') as unorm8;\n\nexport type unorm8x2 = TgpuVertexFormatData<'unorm8x2'>;\nexport const unorm8x2 = new TgpuVertexFormatDataImpl('unorm8x2') as unorm8x2;\n\nexport type unorm8x4 = TgpuVertexFormatData<'unorm8x4'>;\nexport const unorm8x4 = new TgpuVertexFormatDataImpl('unorm8x4') as unorm8x4;\n\nexport type snorm8 = TgpuVertexFormatData<'snorm8'>;\nexport const snorm8 = new TgpuVertexFormatDataImpl('snorm8') as snorm8;\n\nexport type snorm8x2 = TgpuVertexFormatData<'snorm8x2'>;\nexport const snorm8x2 = new TgpuVertexFormatDataImpl('snorm8x2') as snorm8x2;\n\nexport type snorm8x4 = TgpuVertexFormatData<'snorm8x4'>;\nexport const snorm8x4 = new TgpuVertexFormatDataImpl('snorm8x4') as snorm8x4;\n\nexport type uint16 = TgpuVertexFormatData<'uint16'>;\nexport const uint16 = new TgpuVertexFormatDataImpl('uint16') as uint16;\n\nexport type uint16x2 = TgpuVertexFormatData<'uint16x2'>;\nexport const uint16x2 = new TgpuVertexFormatDataImpl('uint16x2') as uint16x2;\n\nexport type uint16x4 = TgpuVertexFormatData<'uint16x4'>;\nexport const uint16x4 = new TgpuVertexFormatDataImpl('uint16x4') as uint16x4;\n\nexport type sint16 = TgpuVertexFormatData<'sint16'>;\nexport const sint16 = new TgpuVertexFormatDataImpl('sint16') as sint16;\n\nexport type sint16x2 = TgpuVertexFormatData<'sint16x2'>;\nexport const sint16x2 = new TgpuVertexFormatDataImpl('sint16x2') as sint16x2;\n\nexport type sint16x4 = TgpuVertexFormatData<'sint16x4'>;\nexport const sint16x4 = new TgpuVertexFormatDataImpl('sint16x4') as sint16x4;\n\nexport type unorm16 = TgpuVertexFormatData<'unorm16'>;\nexport const unorm16 = new TgpuVertexFormatDataImpl('unorm16') as unorm16;\n\nexport type unorm16x2 = TgpuVertexFormatData<'unorm16x2'>;\nexport const unorm16x2 = new TgpuVertexFormatDataImpl('unorm16x2') as unorm16x2;\n\nexport type unorm16x4 = TgpuVertexFormatData<'unorm16x4'>;\nexport const unorm16x4 = new TgpuVertexFormatDataImpl('unorm16x4') as unorm16x4;\n\nexport type snorm16 = TgpuVertexFormatData<'snorm16'>;\nexport const snorm16 = new TgpuVertexFormatDataImpl('snorm16') as snorm16;\n\nexport type snorm16x2 = TgpuVertexFormatData<'snorm16x2'>;\nexport const snorm16x2 = new TgpuVertexFormatDataImpl('snorm16x2') as snorm16x2;\n\nexport type snorm16x4 = TgpuVertexFormatData<'snorm16x4'>;\nexport const snorm16x4 = new TgpuVertexFormatDataImpl('snorm16x4') as snorm16x4;\n\nexport type float16 = TgpuVertexFormatData<'float16'>;\nexport const float16 = new TgpuVertexFormatDataImpl('float16') as float16;\n\nexport type float16x2 = TgpuVertexFormatData<'float16x2'>;\nexport const float16x2 = new TgpuVertexFormatDataImpl('float16x2') as float16x2;\n\nexport type float16x4 = TgpuVertexFormatData<'float16x4'>;\nexport const float16x4 = new TgpuVertexFormatDataImpl('float16x4') as float16x4;\n\nexport type float32 = TgpuVertexFormatData<'float32'>;\nexport const float32 = new TgpuVertexFormatDataImpl('float32') as float32;\n\nexport type float32x2 = TgpuVertexFormatData<'float32x2'>;\nexport const float32x2 = new TgpuVertexFormatDataImpl('float32x2') as float32x2;\n\nexport type float32x3 = TgpuVertexFormatData<'float32x3'>;\nexport const float32x3 = new TgpuVertexFormatDataImpl('float32x3') as float32x3;\n\nexport type float32x4 = TgpuVertexFormatData<'float32x4'>;\nexport const float32x4 = new TgpuVertexFormatDataImpl('float32x4') as float32x4;\n\nexport type uint32 = TgpuVertexFormatData<'uint32'>;\nexport const uint32 = new TgpuVertexFormatDataImpl('uint32') as uint32;\n\nexport type uint32x2 = TgpuVertexFormatData<'uint32x2'>;\nexport const uint32x2 = new TgpuVertexFormatDataImpl('uint32x2') as uint32x2;\n\nexport type uint32x3 = TgpuVertexFormatData<'uint32x3'>;\nexport const uint32x3 = new TgpuVertexFormatDataImpl('uint32x3') as uint32x3;\n\nexport type uint32x4 = TgpuVertexFormatData<'uint32x4'>;\nexport const uint32x4 = new TgpuVertexFormatDataImpl('uint32x4') as uint32x4;\n\nexport type sint32 = TgpuVertexFormatData<'sint32'>;\nexport const sint32 = new TgpuVertexFormatDataImpl('sint32') as sint32;\n\nexport type sint32x2 = TgpuVertexFormatData<'sint32x2'>;\nexport const sint32x2 = new TgpuVertexFormatDataImpl('sint32x2') as sint32x2;\n\nexport type sint32x3 = TgpuVertexFormatData<'sint32x3'>;\nexport const sint32x3 = new TgpuVertexFormatDataImpl('sint32x3') as sint32x3;\n\nexport type sint32x4 = TgpuVertexFormatData<'sint32x4'>;\nexport const sint32x4 = new TgpuVertexFormatDataImpl('sint32x4') as sint32x4;\n\nexport type unorm10_10_10_2 = TgpuVertexFormatData<'unorm10-10-10-2'>;\nexport const unorm10_10_10_2 = new TgpuVertexFormatDataImpl(\n 'unorm10-10-10-2',\n) as unorm10_10_10_2;\n\nexport type unorm8x4_bgra = TgpuVertexFormatData<'unorm8x4-bgra'>;\nexport const unorm8x4_bgra = new TgpuVertexFormatDataImpl(\n 'unorm8x4-bgra',\n) as unorm8x4_bgra;\n\nexport type PackedData =\n | uint8\n | uint8x2\n | uint8x4\n | sint8\n | sint8x2\n | sint8x4\n | unorm8\n | unorm8x2\n | unorm8x4\n | snorm8\n | snorm8x2\n | snorm8x4\n | uint16\n | uint16x2\n | uint16x4\n | sint16\n | sint16x2\n | sint16x4\n | unorm16\n | unorm16x2\n | unorm16x4\n | snorm16\n | snorm16x2\n | snorm16x4\n | float16\n | float16x2\n | float16x4\n | float32\n | float32x2\n | float32x3\n | float32x4\n | uint32\n | uint32x2\n | uint32x3\n | uint32x4\n | sint32\n | sint32x2\n | sint32x3\n | sint32x4\n | unorm10_10_10_2\n | unorm8x4_bgra;\n","import {\n type AnyData,\n getCustomAlignment,\n isDisarray,\n isLooseDecorated,\n isUnstruct,\n} from './dataTypes.ts';\nimport { packedFormats } from './vertexFormatData.ts';\nimport {\n type BaseData,\n isDecorated,\n isWgslArray,\n isWgslStruct,\n} from './wgslTypes.ts';\n\nconst knownAlignmentMap: Record<string, number> = {\n f32: 4,\n f16: 2,\n i32: 4,\n u32: 4,\n u16: 2,\n vec2f: 8,\n vec2h: 4,\n vec2i: 8,\n vec2u: 8,\n vec3f: 16,\n vec3h: 8,\n vec3i: 16,\n vec3u: 16,\n vec4f: 16,\n vec4h: 8,\n vec4i: 16,\n vec4u: 16,\n mat2x2f: 8,\n mat3x3f: 16,\n mat4x4f: 16,\n atomic: 4,\n};\n\nfunction computeAlignment(data: object): number {\n const dataType = (data as BaseData)?.type;\n const knownAlignment = knownAlignmentMap[dataType];\n if (knownAlignment !== undefined) {\n return knownAlignment;\n }\n\n if (isWgslStruct(data)) {\n return Object.values(data.propTypes)\n .map(alignmentOf)\n .reduce((a, b) => (a > b ? a : b));\n }\n\n if (isWgslArray(data)) {\n return alignmentOf(data.elementType);\n }\n\n if (isUnstruct(data)) {\n // A loose struct is aligned to its first property.\n const firstProp = Object.values(data.propTypes)[0];\n return firstProp ? (getCustomAlignment(firstProp) ?? 1) : 1;\n }\n\n if (isDisarray(data)) {\n return getCustomAlignment(data.elementType) ?? 1;\n }\n\n if (isDecorated(data) || isLooseDecorated(data)) {\n return getCustomAlignment(data) ?? alignmentOf(data.inner);\n }\n\n if (packedFormats.includes(dataType)) {\n return 1;\n }\n\n throw new Error(\n `Cannot determine alignment of data: ${JSON.stringify(data)}`,\n );\n}\n\nfunction computeCustomAlignment(data: BaseData): number {\n if (isUnstruct(data)) {\n // A loose struct is aligned to its first property.\n const firstProp = Object.values(data.propTypes)[0];\n return firstProp ? customAlignmentOf(firstProp) : 1;\n }\n\n if (isDisarray(data)) {\n return customAlignmentOf(data.elementType);\n }\n\n if (isLooseDecorated(data)) {\n return getCustomAlignment(data) ?? customAlignmentOf(data.inner);\n }\n\n return getCustomAlignment(data) ?? 1;\n}\n\n/**\n * Since alignments can be inferred from data types, they are not stored on them.\n * Instead, this weak map acts as an extended property of those data types.\n */\nconst cachedAlignments = new WeakMap<object, number>();\n\nconst cachedCustomAlignments = new WeakMap<object, number>();\n\nexport function alignmentOf(data: BaseData): number {\n let alignment = cachedAlignments.get(data);\n if (alignment === undefined) {\n alignment = computeAlignment(data);\n cachedAlignments.set(data, alignment);\n }\n\n return alignment;\n}\n\nexport function customAlignmentOf(data: BaseData): number {\n let alignment = cachedCustomAlignments.get(data);\n if (alignment === undefined) {\n alignment = computeCustomAlignment(data);\n cachedCustomAlignments.set(data, alignment);\n }\n\n return alignment;\n}\n\n/**\n * Returns the alignment (in bytes) of data represented by the `schema`.\n */\nexport function PUBLIC_alignmentOf(schema: AnyData): number {\n return alignmentOf(schema);\n}\n","import { roundUp } from '../mathUtils.ts';\nimport { alignmentOf, customAlignmentOf } from './alignmentOf.ts';\nimport type { AnyData, LooseTypeLiteral, Unstruct } from './dataTypes.ts';\nimport {\n getCustomSize,\n isDisarray,\n isLooseDecorated,\n isUnstruct,\n} from './dataTypes.ts';\nimport type { BaseData, WgslStruct, WgslTypeLiteral } from './wgslTypes.ts';\nimport { isDecorated, isWgslArray, isWgslStruct } from './wgslTypes.ts';\n\nconst knownSizesMap: Record<string, number> = {\n f32: 4,\n f16: 2,\n i32: 4,\n u32: 4,\n u16: 2,\n vec2f: 8,\n vec2h: 4,\n vec2i: 8,\n vec2u: 8,\n vec3f: 12,\n vec3h: 6,\n vec3i: 12,\n vec3u: 12,\n vec4f: 16,\n vec4h: 8,\n vec4i: 16,\n vec4u: 16,\n mat2x2f: 16,\n mat3x3f: 48,\n mat4x4f: 64,\n uint8: 1,\n uint8x2: 2,\n uint8x4: 4,\n sint8: 1,\n sint8x2: 2,\n sint8x4: 4,\n unorm8: 1,\n unorm8x2: 2,\n unorm8x4: 4,\n snorm8: 1,\n snorm8x2: 2,\n snorm8x4: 4,\n uint16: 2,\n uint16x2: 4,\n uint16x4: 8,\n sint16: 2,\n sint16x2: 4,\n sint16x4: 8,\n unorm16: 2,\n unorm16x2: 4,\n unorm16x4: 8,\n snorm16: 2,\n snorm16x2: 4,\n snorm16x4: 8,\n float16: 2,\n float16x2: 4,\n float16x4: 8,\n float32: 4,\n float32x2: 8,\n float32x3: 12,\n float32x4: 16,\n uint32: 4,\n uint32x2: 8,\n uint32x3: 12,\n uint32x4: 16,\n sint32: 4,\n sint32x2: 8,\n sint32x3: 12,\n sint32x4: 16,\n 'unorm10-10-10-2': 4,\n 'unorm8x4-bgra': 4,\n atomic: 4,\n} satisfies Partial<Record<WgslTypeLiteral | LooseTypeLiteral, number>>;\n\nfunction sizeOfStruct(struct: WgslStruct) {\n let size = 0;\n for (const property of Object.values(struct.propTypes)) {\n if (Number.isNaN(size)) {\n throw new Error('Only the last property of a struct can be unbounded');\n }\n\n size = roundUp(size, alignmentOf(property));\n size += sizeOf(property);\n\n if (Number.isNaN(size) && property.type !== 'array') {\n throw new Error('Cannot nest unbounded struct within another struct');\n }\n }\n\n return roundUp(size, alignmentOf(struct));\n}\n\nfunction sizeOfUnstruct(data: Unstruct) {\n let size = 0;\n\n for (const property of Object.values(data.propTypes)) {\n const alignment = customAlignmentOf(property);\n size = roundUp(size, alignment);\n size += sizeOf(property);\n }\n\n return size;\n}\n\nfunction computeSize(data: object): number {\n const knownSize = knownSizesMap[(data as BaseData)?.type];\n\n if (knownSize !== undefined) {\n return knownSize;\n }\n\n if (isWgslStruct(data)) {\n return sizeOfStruct(data);\n }\n\n if (isUnstruct(data)) {\n return sizeOfUnstruct(data);\n }\n\n if (isWgslArray(data)) {\n if (data.elementCount === 0) {\n return Number.NaN;\n }\n\n const alignment = alignmentOf(data.elementType);\n const stride = roundUp(sizeOf(data.elementType), alignment);\n return stride * data.elementCount;\n }\n\n if (isDisarray(data)) {\n const alignment = customAlignmentOf(data.elementType);\n const stride = roundUp(sizeOf(data.elementType), alignment);\n return stride * data.elementCount;\n }\n\n if (isDecorated(data) || isLooseDecorated(data)) {\n return getCustomSize(data) ?? sizeOf(data.inner);\n }\n\n throw new Error(`Cannot determine size of data: ${data}`);\n}\n\n/**\n * Since sizes can be inferred from data types, they are not stored on them.\n * Instead, this weak map acts as an extended property of those data types.\n */\nconst cachedSizes = new WeakMap<BaseData, number>();\n\nexport function sizeOf(schema: BaseData): number {\n let size = cachedSizes.get(schema);\n\n if (size === undefined) {\n size = computeSize(schema);\n cachedSizes.set(schema, size);\n }\n\n return size;\n}\n\n/**\n * Returns the size (in bytes) of data represented by the `schema`.\n */\nexport function PUBLIC_sizeOf(schema: AnyData): number {\n return sizeOf(schema);\n}\n","import type {\n Infer,\n InferGPU,\n InferPartial,\n MemIdentity,\n} from '../shared/repr.ts';\nimport type {\n $gpuRepr,\n $memIdent,\n $repr,\n $reprPartial,\n} from '../shared/symbols.ts';\nimport { $internal } from '../shared/symbols.ts';\nimport { sizeOf } from './sizeOf.ts';\nimport type { AnyWgslData, BaseData, WgslArray } from './wgslTypes.ts';\n\n// ----------\n// Public API\n// ----------\n\n/**\n * Creates an array schema that can be used to construct gpu buffers.\n * Describes arrays with fixed-size length, storing elements of the same type.\n *\n * @example\n * const LENGTH = 3;\n * const array = d.arrayOf(d.u32, LENGTH);\n *\n * @param elementType The type of elements in the array.\n * @param elementCount The number of elements in the array.\n */\nexport function arrayOf<TElement extends AnyWgslData>(\n elementType: TElement,\n elementCount: number,\n): WgslArray<TElement> {\n return new WgslArrayImpl(elementType, elementCount);\n}\n\n// --------------\n// Implementation\n// --------------\n\nclass WgslArrayImpl<TElement extends BaseData> implements WgslArray<TElement> {\n public readonly [$internal] = true;\n public readonly type = 'array';\n\n // Type-tokens, not available at runtime\n declare readonly [$repr]: Infer<TElement>[];\n declare readonly [$gpuRepr]: InferGPU<TElement>[];\n declare readonly [$reprPartial]: {\n idx: number;\n value: InferPartial<TElement>;\n }[];\n declare readonly [$memIdent]: WgslArray<MemIdentity<TElement>>;\n // ---\n\n constructor(\n public readonly elementType: TElement,\n public readonly elementCount: number,\n ) {\n if (Number.isNaN(sizeOf(elementType))) {\n throw new Error('Cannot nest runtime sized arrays.');\n }\n\n if (!Number.isInteger(elementCount) || elementCount < 0) {\n throw new Error(\n `Cannot create array schema with invalid element count: ${elementCount}.`,\n );\n }\n }\n\n toString() {\n return `arrayOf(${this.elementType})`;\n }\n}\n","import type { Infer, InferPartial } from '../shared/repr.ts';\nimport { $internal } from '../shared/symbols.ts';\nimport type { $repr, $reprPartial } from '../shared/symbols.ts';\nimport type { AnyData, Disarray } from './dataTypes.ts';\n\n// ----------\n// Public API\n// ----------\n\n/**\n * Creates an array schema that can be used to construct vertex buffers.\n * Describes arrays with fixed-size length, storing elements of the same type.\n *\n * Elements in the schema are not aligned in respect to their `byteAlignment`,\n * unless they are explicitly decorated with the custom align attribute\n * via `d.align` function.\n *\n * @example\n * const disarray = d.disarrayOf(d.vec3f, 3); // packed array of vec3f\n *\n * @example\n * const disarray = d.disarrayOf(d.align(16, d.vec3f), 3);\n *\n * @param elementType The type of elements in the array.\n * @param count The number of elements in the array.\n */\nexport function disarrayOf<TElement extends AnyData>(\n elementType: TElement,\n count: number,\n): Disarray<TElement> {\n return new DisarrayImpl(elementType, count);\n}\n\n// --------------\n// Implementation\n// --------------\n\nclass DisarrayImpl<TElement extends AnyData> implements Disarray<TElement> {\n public readonly [$internal] = true;\n public readonly type = 'disarray';\n\n // Type-tokens, not available at runtime\n declare readonly [$repr]: Infer<TElement>[];\n declare readonly [$reprPartial]: {\n idx: number;\n value: InferPartial<TElement>;\n }[];\n // ---\n\n constructor(\n public readonly elementType: TElement,\n public readonly elementCount: number,\n ) {\n if (!Number.isInteger(elementCount) || elementCount < 0) {\n throw new Error(\n `Cannot create disarray schema with invalid element count: ${elementCount}.`,\n );\n }\n }\n}\n","import { getName, setName } from '../shared/meta.ts';\nimport { $internal } from '../shared/symbols.ts';\nimport type { Unstruct } from './dataTypes.ts';\nimport type { BaseData } from './wgslTypes.ts';\n\n// ----------\n// Public API\n// ----------\n\n/**\n * Creates a loose struct schema that can be used to construct vertex buffers.\n * Describes structs with members of both loose and non-loose types.\n *\n * The order of members matches the passed in properties object.\n * Members are not aligned in respect to their `byteAlignment`,\n * unless they are explicitly decorated with the custom align attribute\n * via `d.align` function.\n *\n * @example\n * const CircleStruct = d.unstruct({ radius: d.f32, pos: d.vec3f }); // packed struct with no padding\n *\n * @example\n * const CircleStruct = d.unstruct({ radius: d.f32, pos: d.align(16, d.vec3f) });\n *\n * @param properties Record with `string` keys and `TgpuData` or `TgpuLooseData` values,\n * each entry describing one struct member.\n */\nexport function unstruct<TProps extends Record<string, BaseData>>(\n properties: TProps,\n): Unstruct<TProps> {\n const unstruct = <T>(props: T) => props;\n Object.setPrototypeOf(unstruct, UnstructImpl);\n unstruct.propTypes = properties;\n\n return unstruct as unknown as Unstruct<TProps>;\n}\n\n// --------------\n// Implementation\n// --------------\n\nconst UnstructImpl = {\n [$internal]: true,\n type: 'unstruct',\n\n $name(label: string) {\n setName(this, label);\n return this;\n },\n\n toString(): string {\n return `unstruct:${getName(this) ?? '<unnamed>'}`;\n },\n};\n","import type { Infer, MemIdentity } from '../shared/repr.ts';\nimport { $internal } from '../shared/symbols.ts';\nimport type { $gpuRepr, $memIdent, $repr } from '../shared/symbols.ts';\nimport type { Atomic, atomicI32, atomicU32, I32, U32 } from './wgslTypes.ts';\n\n// ----------\n// Public API\n// ----------\n\n/**\n * Marks a concrete integer scalar type schema (u32 or i32) as a WGSL atomic.\n *\n * @example\n * const atomicU32 = d.atomic(d.u32);\n * const atomicI32 = d.atomic(d.i32);\n *\n * @param data Underlying type schema.\n */\nexport function atomic<TSchema extends U32 | I32>(\n data: TSchema,\n): Atomic<TSchema> {\n return new AtomicImpl(data);\n}\n\n// --------------\n// Implementation\n// --------------\n\nclass AtomicImpl<TSchema extends U32 | I32> implements Atomic<TSchema> {\n public readonly [$internal] = true;\n public readonly type = 'atomic';\n\n // Type-tokens, not available at runtime\n declare readonly [$repr]: Infer<TSchema>;\n declare readonly [$memIdent]: MemIdentity<TSchema>;\n declare readonly [$gpuRepr]: TSchema extends U32 ? atomicU32 : atomicI32;\n // ---\n\n constructor(public readonly inner: TSchema) {}\n}\n","import type {\n Infer,\n InferGPU,\n InferPartial,\n MemIdentity,\n} from '../shared/repr.ts';\nimport { $internal } from '../shared/symbols.ts';\nimport type {\n $gpuRepr,\n $memIdent,\n $repr,\n $reprPartial,\n} from '../shared/symbols.ts';\nimport { alignmentOf } from './alignmentOf.ts';\nimport {\n type AnyData,\n type AnyLooseData,\n isLooseData,\n isLooseDecorated,\n type LooseDecorated,\n type LooseTypeLiteral,\n} from './dataTypes.ts';\nimport { sizeOf } from './sizeOf.ts';\nimport {\n type Align,\n type AnyWgslData,\n type BaseData,\n type Builtin,\n type Decorated,\n type FlatInterpolatableData,\n type FlatInterpolationType,\n type Interpolate,\n type InterpolationType,\n isAlignAttrib,\n isBuiltinAttrib,\n isDecorated,\n isSizeAttrib,\n isWgslData,\n type Location,\n type PerspectiveOrLinearInterpolatableData,\n type PerspectiveOrLinearInterpolationType,\n type Size,\n type WgslTypeLiteral,\n} from './wgslTypes.ts';\n\n// ----------\n// Public API\n// ----------\n\nexport const builtinNames = [\n 'vertex_index',\n 'instance_index',\n 'position',\n 'clip_distances',\n 'front_facing',\n 'frag_depth',\n 'sample_index',\n 'sample_mask',\n 'fragment',\n 'local_invocation_id',\n 'local_invocation_index',\n 'global_invocation_id',\n 'workgroup_id',\n 'num_workgroups',\n 'subgroup_invocation_id',\n 'subgroup_size',\n] as const;\n\nexport type BuiltinName = (typeof builtinNames)[number];\n\nexport type AnyAttribute<\n AllowedBuiltins extends Builtin<BuiltinName> = Builtin<BuiltinName>,\n> =\n | Align<number>\n | Size<number>\n | Location<number>\n | Interpolate<InterpolationType>\n | AllowedBuiltins;\n\nexport type ExtractAttributes<T> = T extends {\n readonly attribs: unknown[];\n} ? T['attribs']\n : [];\n\nexport type Undecorate<T> = T extends { readonly inner: infer TInner } ? TInner\n : T;\n\nexport type UndecorateRecord<T extends Record<string, unknown>> = {\n [Key in keyof T]: Undecorate<T[Key]>;\n};\n\n/**\n * Decorates a data-type `TData` with an attribute `TAttrib`.\n *\n * - if `TData` is loose\n * - if `TData` is already `LooseDecorated`\n * - Prepend `TAttrib` to the existing attribute tuple.\n * - else\n * - Wrap `TData` with `LooseDecorated` and a single attribute `[TAttrib]`\n * - else\n * - if `TData` is already `Decorated`\n * - Prepend `TAttrib` to the existing attribute tuple.\n * - else\n * - Wrap `TData` with `Decorated` and a single attribute `[TAttrib]`\n */\nexport type Decorate<\n TData extends BaseData,\n TAttrib extends AnyAttribute,\n> = TData['type'] extends WgslTypeLiteral\n ? Decorated<Undecorate<TData>, [TAttrib, ...ExtractAttributes<TData>]>\n : TData['type'] extends LooseTypeLiteral\n ? LooseDecorated<Undecorate<TData>, [TAttrib, ...ExtractAttributes<TData>]>\n : never;\n\nexport type IsBuiltin<T> = ExtractAttributes<T>[number] extends [] ? false\n : ExtractAttributes<T>[number] extends Builtin<BuiltinName> ? true\n : false;\n\nexport type HasCustomLocation<T> = ExtractAttributes<T>[number] extends []\n ? false\n : ExtractAttributes<T>[number] extends Location ? true\n : false;\n\nexport function attribute<TData extends BaseData, TAttrib extends AnyAttribute>(\n data: TData,\n attrib: TAttrib,\n): Decorated | LooseDecorated {\n if (isDecorated(data)) {\n return new DecoratedImpl(data.inner, [\n attrib,\n ...data.attribs,\n ]) as Decorated;\n }\n\n if (isLooseDecorated(data)) {\n return new LooseDecoratedImpl(data.inner, [\n attrib,\n ...data.attribs,\n ]) as LooseDecorated;\n }\n\n if (isLooseData(data)) {\n return new LooseDecoratedImpl(data, [attrib]) as unknown as LooseDecorated;\n }\n\n return new DecoratedImpl(data, [attrib]) as unknown as Decorated;\n}\n\n/**\n * Gives the wrapped data-type a custom byte alignment. Useful in order to\n * fulfill uniform alignment requirements.\n *\n * @example\n * const Data = d.struct({\n * a: u32, // takes up 4 bytes\n * // 12 bytes of padding, because `b` is custom aligned to multiples of 16 bytes\n * b: d.align(16, u32),\n * });\n *\n * @param alignment The multiple of bytes this data should align itself to.\n * @param data The data-type to align.\n */\nexport function align<TAlign extends number, TData extends AnyData>(\n alignment: TAlign,\n data: TData,\n): Decorate<TData, Align<TAlign>> {\n return attribute(data, {\n [$internal]: true,\n type: '@align',\n value: alignment,\n // biome-ignore lint/suspicious/noExplicitAny: <tired of lying to types>\n }) as any;\n}\n\n/**\n * Adds padding bytes after the wrapped data-type, until the whole value takes up `size` bytes.\n *\n * @example\n * const Data = d.struct({\n * a: d.size(16, u32), // takes up 16 bytes, instead of 4\n * b: u32, // starts at byte 16, because `a` has a custom size\n * });\n *\n * @param size The amount of bytes that should be reserved for this data-type.\n * @param data The data-type to wrap.\n */\nexport function size<TSize extends number, TData extends AnyData>(\n size: TSize,\n data: TData,\n): Decorate<TData, Size<TSize>> {\n return attribute(data, {\n [$internal]: true,\n type: '@size',\n value: size,\n // biome-ignore lint/suspicious/noExplicitAny: <tired of lying to types>\n }) as any;\n}\n\n/**\n * Assigns an explicit numeric location to a struct member or a parameter that has this type.\n *\n * @example\n * const VertexOutput = {\n * a: d.u32, // has implicit location 0\n * b: d.location(5, d.u32),\n * c: d.u32, // has implicit location 6\n * };\n *\n * @param location The explicit numeric location.\n * @param data The data-type to wrap.\n */\nexport function location<TLocation extends number, TData extends AnyData>(\n location: TLocation,\n data: TData,\n): Decorate<TData, Location<TLocation>> {\n return attribute(data, {\n [$internal]: true,\n type: '@location',\n value: location,\n // biome-ignore lint/suspicious/noExplicitAny: <tired of lying to types>\n }) as any;\n}\n\n/**\n * Specifies how user-defined vertex shader output (fragment shader input)\n * must be interpolated.\n *\n * Tip: Integer outputs cannot be interpolated.\n *\n * @example\n * const VertexOutput = {\n * a: d.f32, // has implicit 'perspective, center' interpolation\n * b: d.interpolate('linear, sample', d.f32),\n * };\n *\n * @param interpolationType How data should be interpolated.\n * @param data The data-type to wrap.\n */\nexport function interpolate<\n TInterpolation extends PerspectiveOrLinearInterpolationType,\n TData extends PerspectiveOrLinearInterpolatableData,\n>(\n interpolationType: TInterpolation,\n data: TData,\n): Decorate<TData, Interpolate<TInterpolation>>;\n\n/**\n * Specifies how user-defined vertex shader output (fragment shader input)\n * must be interpolated.\n *\n * Tip: Default sampling method of `flat` is `first`. Unless you specifically\n * need deterministic behavior provided by `'flat, first'`, prefer explicit\n * `'flat, either'` as it could be slightly faster in hardware.\n *\n * @example\n * const VertexOutput = {\n * a: d.f32, // has implicit 'perspective, center' interpolation\n * b: d.interpolate('flat, either', d.u32), // integer outputs cannot interpolate\n * };\n *\n * @param interpolationType How data should be interpolated.\n * @param data The data-type to wrap.\n */\nexport function interpolate<\n TInterpolation extends FlatInterpolationType,\n TData extends FlatInterpolatableData,\n>(\n interpolationType: TInterpolation,\n data: TData,\n): Decorate<TData, Interpolate<TInterpolation>>;\n\nexport function interpolate<\n TInterpolation extends InterpolationType,\n TData extends AnyData,\n>(\n interpolationType: TInterpolation,\n data: TData,\n): Decorate<TData, Interpolate<TInterpolation>> {\n return attribute(data, {\n [$internal]: true,\n type: '@interpolate',\n value: interpolationType,\n // biome-ignore lint/suspicious/noExplicitAny: <tired of lying to types>\n }) as any;\n}\n\nexport function isBuiltin<\n T extends\n | Decorated<AnyWgslData, AnyAttribute[]>\n | LooseDecorated<AnyLooseData, AnyAttribute[]>,\n>(value: T | unknown): value is T {\n return (\n (isDecorated(value) || isLooseDecorated(value)) &&\n value.attribs.find(isBuiltinAttrib) !== undefined\n );\n}\n\nexport function getAttributesString<T extends BaseData>(field: T): string {\n if (!isDecorated(field) && !isLooseDecorated(field)) {\n return '';\n }\n\n return (field.attribs as AnyAttribute[])\n .map((attrib) => `${attrib.type}(${attrib.value}) `)\n .join('');\n}\n\n// --------------\n// Implementation\n// --------------\n\nclass BaseDecoratedImpl<TInner extends BaseData, TAttribs extends unknown[]> {\n public readonly [$internal] = true;\n\n // Type-tokens, not available at runtime\n declare readonly [$repr]: Infer<TInner>;\n // ---\n\n constructor(\n public readonly inner: TInner,\n public readonly attribs: TAttribs,\n ) {\n const alignAttrib = attribs.find(isAlignAttrib)?.value;\n const sizeAttrib = attribs.find(isSizeAttrib)?.value;\n\n if (alignAttrib !== undefined) {\n if (alignAttrib <= 0) {\n throw new Error(\n `Custom data alignment must be a positive number, got: ${alignAttrib}.`,\n );\n }\n\n if (Math.log2(alignAttrib) % 1 !== 0) {\n throw new Error(\n `Alignment has to be a power of 2, got: ${alignAttrib}.`,\n );\n }\n\n if (isWgslData(this.inner)) {\n if (alignAttrib % alignmentOf(this.inner) !== 0) {\n throw new Error(\n `Custom alignment has to be a multiple of the standard data alignment. Got: ${alignAttrib}, expected multiple of: ${\n alignmentOf(this.inner)\n }.`,\n );\n }\n }\n }\n\n if (sizeAttrib !== undefined) {\n if (sizeAttrib < sizeOf(this.inner)) {\n throw new Error(\n `Custom data size cannot be smaller then the standard data size. Got: ${sizeAttrib}, expected at least: ${\n sizeOf(this.inner)\n }.`,\n );\n }\n\n if (sizeAttrib <= 0) {\n throw new Error(\n `Custom data size must be a positive number. Got: ${sizeAttrib}.`,\n );\n }\n }\n }\n}\n\nclass DecoratedImpl<TInner extends BaseData, TAttribs extends unknown[]>\n extends BaseDecoratedImpl<TInner, TAttribs>\n implements Decorated<TInner, TAttribs> {\n public readonly [$internal] = true;\n public readonly type = 'decorated';\n\n // Type-tokens, not available at runtime\n declare readonly [$gpuRepr]: InferGPU<TInner>;\n declare readonly [$reprPartial]: InferPartial<TInner>;\n declare readonly [$memIdent]: TAttribs extends Location[]\n ? MemIdentity<TInner> | Decorated<MemIdentity<TInner>, TAttribs>\n : Decorated<MemIdentity<TInner>, TAttribs>;\n // ---\n}\n\nclass LooseDecoratedImpl<TInner extends BaseData, TAttribs extends unknown[]>\n extends BaseDecoratedImpl<TInner, TAttribs>\n implements LooseDecorated<TInner, TAttribs> {\n public readonly [$internal] = true;\n public readonly type = 'loose-decorated';\n}\n","import { arrayOf } from './data/array.ts';\nimport { attribute } from './data/attributes.ts';\nimport type { LooseDecorated } from './data/dataTypes.ts';\nimport { bool, f32, u32 } from './data/numeric.ts';\nimport { vec3u, vec4f } from './data/vector.ts';\nimport type {\n AnyWgslData,\n BaseData,\n Bool,\n Builtin,\n Decorated,\n F32,\n U32,\n Vec3u,\n Vec4f,\n WgslArray,\n} from './data/wgslTypes.ts';\nimport { $internal } from './shared/symbols.ts';\n\n// ----------\n// Public API\n// ----------\n\nexport type BuiltinVertexIndex = Decorated<U32, [Builtin<'vertex_index'>]>;\nexport type BuiltinInstanceIndex = Decorated<U32, [Builtin<'instance_index'>]>;\nexport type BuiltinPosition = Decorated<Vec4f, [Builtin<'position'>]>;\nexport type BuiltinClipDistances = Decorated<\n WgslArray<U32>,\n [Builtin<'clip_distances'>]\n>;\nexport type BuiltinFrontFacing = Decorated<Bool, [Builtin<'front_facing'>]>;\nexport type BuiltinFragDepth = Decorated<F32, [Builtin<'frag_depth'>]>;\nexport type BuiltinSampleIndex = Decorated<U32, [Builtin<'sample_index'>]>;\nexport type BuiltinSampleMask = Decorated<U32, [Builtin<'sample_mask'>]>;\nexport type BuiltinLocalInvocationId = Decorated<\n Vec3u,\n [Builtin<'local_invocation_id'>]\n>;\nexport type BuiltinLocalInvocationIndex = Decorated<\n U32,\n [Builtin<'local_invocation_index'>]\n>;\nexport type BuiltinGlobalInvocationId = Decorated<\n Vec3u,\n [Builtin<'global_invocation_id'>]\n>;\nexport type BuiltinWorkgroupId = Decorated<Vec3u, [Builtin<'workgroup_id'>]>;\nexport type BuiltinNumWorkgroups = Decorated<\n Vec3u,\n [Builtin<'num_workgroups'>]\n>;\nexport type BuiltinSubgroupInvocationId = Decorated<\n U32,\n [Builtin<'subgroup_invocation_id'>]\n>;\nexport type BuiltinSubgroupSize = Decorated<U32, [Builtin<'subgroup_size'>]>;\n\nfunction defineBuiltin<T extends Decorated | LooseDecorated>(\n dataType: AnyWgslData,\n value: T['attribs'][0] extends { value: infer TValue } ? TValue : never,\n): T {\n return attribute(dataType, {\n [$internal]: true,\n type: '@builtin',\n // biome-ignore lint/suspicious/noExplicitAny: it's fine\n value: value as any,\n }) as T;\n}\n\nexport const builtin = {\n vertexIndex: defineBuiltin<BuiltinVertexIndex>(u32, 'vertex_index'),\n instanceIndex: defineBuiltin<BuiltinInstanceIndex>(u32, 'instance_index'),\n position: defineBuiltin<BuiltinPosition>(vec4f, 'position'),\n clipDistances: defineBuiltin<BuiltinClipDistances>(\n arrayOf(u32, 8),\n 'clip_distances',\n ),\n frontFacing: defineBuiltin<BuiltinFrontFacing>(bool, 'front_facing'),\n fragDepth: defineBuiltin<BuiltinFragDepth>(f32, 'frag_depth'),\n sampleIndex: defineBuiltin<BuiltinSampleIndex>(u32, 'sample_index'),\n sampleMask: defineBuiltin<BuiltinSampleMask>(u32, 'sample_mask'),\n localInvocationId: defineBuiltin<BuiltinLocalInvocationId>(\n vec3u,\n 'local_invocation_id',\n ),\n localInvocationIndex: defineBuiltin<BuiltinLocalInvocationIndex>(\n u32,\n 'local_invocation_index',\n ),\n globalInvocationId: defineBuiltin<BuiltinGlobalInvocationId>(\n vec3u,\n 'global_invocation_id',\n ),\n workgroupId: defineBuiltin<BuiltinWorkgroupId>(vec3u, 'workgroup_id'),\n numWorkgroups: defineBuiltin<BuiltinNumWorkgroups>(vec3u, 'num_workgroups'),\n subgroupInvocationId: defineBuiltin<BuiltinSubgroupInvocationId>(\n u32,\n 'subgroup_invocation_id',\n ),\n subgroupSize: defineBuiltin<BuiltinSubgroupSize>(u32, 'subgroup_size'),\n} as const;\n\nexport type AnyBuiltin = (typeof builtin)[keyof typeof builtin];\nexport type AnyComputeBuiltin =\n | BuiltinLocalInvocationId\n | BuiltinLocalInvocationIndex\n | BuiltinGlobalInvocationId\n | BuiltinWorkgroupId\n | BuiltinNumWorkgroups\n | BuiltinSubgroupInvocationId\n | BuiltinSubgroupSize;\nexport type AnyVertexInputBuiltin = BuiltinVertexIndex | BuiltinInstanceIndex;\nexport type AnyVertexOutputBuiltin = BuiltinClipDistances | BuiltinPosition;\nexport type AnyFragmentInputBuiltin =\n | BuiltinPosition\n | BuiltinFrontFacing\n | BuiltinSampleIndex\n | BuiltinSampleMask\n | BuiltinSubgroupInvocationId\n | BuiltinSubgroupSize;\nexport type AnyFragmentOutputBuiltin = BuiltinFragDepth | BuiltinSampleMask;\n\nexport type OmitBuiltins<S> = S extends AnyBuiltin ? never\n : S extends BaseData ? S\n : {\n [Key in keyof S as S[Key] extends AnyBuiltin ? never : Key]: S[Key];\n };\n"],"mappings":"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","names":["schemaCallWrapper","schema","item","result","maybeType","struct","props","structSchema","instanceProps","key","schema","schemaCallWrapper","WgslStructImpl","$internal","label","setName","getName","roundUp","value","modulo","bitMask","invBitMask","TgpuVertexFormatDataImpl","type","$internal","formatToWGSLType","u32","vec2u","vec4u","i32","vec2i","vec4i","f32","vec2f","vec4f","vec3f","vec3u","vec3i","packedFormats","uint8","uint8x2","uint8x4","sint8","sint8x2","sint8x4","unorm8","unorm8x2","unorm8x4","snorm8","snorm8x2","snorm8x4","uint16","uint16x2","uint16x4","sint16","sint16x2","sint16x4","unorm16","unorm16x2","unorm16x4","snorm16","snorm16x2","snorm16x4","float16","float16x2","float16x4","float32","float32x2","float32x3","float32x4","uint32","uint32x2","uint32x3","uint32x4","sint32","sint32x2","sint32x3","sint32x4","unorm10_10_10_2","unorm8x4_bgra","knownAlignmentMap","computeAlignment","data","dataType","knownAlignment","isWgslStruct","alignmentOf","a","b","isWgslArray","isUnstruct","firstProp","getCustomAlignment","isDisarray","isDecorated","isLooseDecorated","packedFormats","computeCustomAlignment","customAlignmentOf","cachedAlignments","cachedCustomAlignments","alignment","PUBLIC_alignmentOf","schema","knownSizesMap","sizeOfStruct","struct","size","property","roundUp","alignmentOf","sizeOf","sizeOfUnstruct","data","alignment","customAlignmentOf","computeSize","knownSize","isWgslStruct","isUnstruct","isWgslArray","isDisarray","isDecorated","isLooseDecorated","getCustomSize","cachedSizes","schema","PUBLIC_sizeOf","arrayOf","elementType","elementCount","WgslArrayImpl","sizeOf","$internal","disarrayOf","elementType","count","DisarrayImpl","elementCount","$internal","unstruct","properties","props","UnstructImpl","$internal","label","setName","getName","atomic","data","AtomicImpl","inner","$internal","attribute","data","attrib","isDecorated","DecoratedImpl","isLooseDecorated","LooseDecoratedImpl","isLooseData","align","alignment","$internal","size","location","interpolate","interpolationType","isBuiltin","value","isBuiltinAttrib","getAttributesString","field","BaseDecoratedImpl","inner","attribs","alignAttrib","isAlignAttrib","sizeAttrib","isSizeAttrib","isWgslData","alignmentOf","sizeOf","defineBuiltin","dataType","value","attribute","$internal","builtin","u32","vec4f","arrayOf","bool","f32","vec3u"]}
@@ -0,0 +1,2 @@
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _optionalChain(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }var _chunkUMHCZDPAcjs = require('./chunk-UMHCZDPA.cjs');var S=e=>Math.sqrt(e.x**2+e.y**2),D=e=>Math.sqrt(e.x**2+e.y**2+e.z**2),E=e=>Math.sqrt(e.x**2+e.y**2+e.z**2+e.w**2),ae=(e,n)=>e.x*n.x+e.y*n.y,re=(e,n)=>e.x*n.x+e.y*n.y+e.z*n.z,ve=(e,n)=>e.x*n.x+e.y*n.y+e.z*n.z+e.w*n.w,r=(e,n,s)=>Math.min(Math.max(n,e),s),u=e=>n=>_chunkUMHCZDPAcjs.ra.call(void 0, e(n.x),e(n.y)),w=e=>n=>_chunkUMHCZDPAcjs.sa.call(void 0, e(n.x),e(n.y)),R=e=>n=>_chunkUMHCZDPAcjs.ta.call(void 0, e(n.x),e(n.y)),K=e=>n=>_chunkUMHCZDPAcjs.ua.call(void 0, e(n.x),e(n.y)),y=e=>n=>_chunkUMHCZDPAcjs.wa.call(void 0, e(n.x),e(n.y),e(n.z)),l=e=>n=>_chunkUMHCZDPAcjs.xa.call(void 0, e(n.x),e(n.y),e(n.z)),$=e=>n=>_chunkUMHCZDPAcjs.ya.call(void 0, e(n.x),e(n.y),e(n.z)),k=e=>n=>_chunkUMHCZDPAcjs.za.call(void 0, e(n.x),e(n.y),e(n.z)),x=e=>n=>_chunkUMHCZDPAcjs.Ba.call(void 0, e(n.x),e(n.y),e(n.z),e(n.w)),o=e=>n=>_chunkUMHCZDPAcjs.Ca.call(void 0, e(n.x),e(n.y),e(n.z),e(n.w)),N=e=>n=>_chunkUMHCZDPAcjs.Da.call(void 0, e(n.x),e(n.y),e(n.z),e(n.w)),O=e=>n=>_chunkUMHCZDPAcjs.Ea.call(void 0, e(n.x),e(n.y),e(n.z),e(n.w)),ue=e=>n=>{let s=n.columns;return _chunkUMHCZDPAcjs.Pa.call(void 0, u(e)(s[0]),u(e)(s[1]))},we=e=>n=>{let s=n.columns;return _chunkUMHCZDPAcjs.Qa.call(void 0, y(e)(s[0]),y(e)(s[1]),y(e)(s[2]))},le=e=>n=>{let s=n.columns;return _chunkUMHCZDPAcjs.Ra.call(void 0, x(e)(s[0]),x(e)(s[1]),x(e)(s[2]),x(e)(s[3]))},F=e=>(n,s)=>_chunkUMHCZDPAcjs.ra.call(void 0, e(n.x,s.x),e(n.y,s.y)),j=e=>(n,s)=>_chunkUMHCZDPAcjs.sa.call(void 0, e(n.x,s.x),e(n.y,s.y)),J=e=>(n,s)=>_chunkUMHCZDPAcjs.ta.call(void 0, e(n.x,s.x),e(n.y,s.y)),Q=e=>(n,s)=>_chunkUMHCZDPAcjs.ua.call(void 0, e(n.x,s.x),e(n.y,s.y)),A=e=>(n,s)=>_chunkUMHCZDPAcjs.wa.call(void 0, e(n.x,s.x),e(n.y,s.y),e(n.z,s.z)),P=e=>(n,s)=>_chunkUMHCZDPAcjs.xa.call(void 0, e(n.x,s.x),e(n.y,s.y),e(n.z,s.z)),X=e=>(n,s)=>_chunkUMHCZDPAcjs.ya.call(void 0, e(n.x,s.x),e(n.y,s.y),e(n.z,s.z)),Y=e=>(n,s)=>_chunkUMHCZDPAcjs.za.call(void 0, e(n.x,s.x),e(n.y,s.y),e(n.z,s.z)),p=e=>(n,s)=>_chunkUMHCZDPAcjs.Ba.call(void 0, e(n.x,s.x),e(n.y,s.y),e(n.z,s.z),e(n.w,s.w)),Z=e=>(n,s)=>_chunkUMHCZDPAcjs.Ca.call(void 0, e(n.x,s.x),e(n.y,s.y),e(n.z,s.z),e(n.w,s.w)),ee=e=>(n,s)=>_chunkUMHCZDPAcjs.Da.call(void 0, e(n.x,s.x),e(n.y,s.y),e(n.z,s.z),e(n.w,s.w)),ne=e=>(n,s)=>_chunkUMHCZDPAcjs.Ea.call(void 0, e(n.x,s.x),e(n.y,s.y),e(n.z,s.z),e(n.w,s.w)),fe=e=>(n,s)=>{let t=n.columns,T=s.columns;return _chunkUMHCZDPAcjs.Pa.call(void 0, F(e)(t[0],T[0]),F(e)(t[1],T[1]))},ge=e=>(n,s)=>{let t=n.columns,T=s.columns;return _chunkUMHCZDPAcjs.Qa.call(void 0, A(e)(t[0],T[0]),A(e)(t[1],T[1]),A(e)(t[2],T[2]))},he=e=>(n,s)=>{let t=n.columns,T=s.columns;return _chunkUMHCZDPAcjs.Ra.call(void 0, p(e)(t[0],T[0]),p(e)(t[1],T[1]),p(e)(t[2],T[2]),p(e)(t[3],T[3]))},d={divInteger:(e,n)=>n===0?e:Math.trunc(e/n)},c= exports.a ={eq:{vec2f:(e,n)=>_chunkUMHCZDPAcjs.va.call(void 0, e.x===n.x,e.y===n.y),vec2h:(e,n)=>_chunkUMHCZDPAcjs.va.call(void 0, e.x===n.x,e.y===n.y),vec2i:(e,n)=>_chunkUMHCZDPAcjs.va.call(void 0, e.x===n.x,e.y===n.y),vec2u:(e,n)=>_chunkUMHCZDPAcjs.va.call(void 0, e.x===n.x,e.y===n.y),"vec2<bool>":(e,n)=>_chunkUMHCZDPAcjs.va.call(void 0, e.x===n.x,e.y===n.y),vec3f:(e,n)=>_chunkUMHCZDPAcjs.Aa.call(void 0, e.x===n.x,e.y===n.y,e.z===n.z),vec3h:(e,n)=>_chunkUMHCZDPAcjs.Aa.call(void 0, e.x===n.x,e.y===n.y,e.z===n.z),vec3i:(e,n)=>_chunkUMHCZDPAcjs.Aa.call(void 0, e.x===n.x,e.y===n.y,e.z===n.z),vec3u:(e,n)=>_chunkUMHCZDPAcjs.Aa.call(void 0, e.x===n.x,e.y===n.y,e.z===n.z),"vec3<bool>":(e,n)=>_chunkUMHCZDPAcjs.Aa.call(void 0, e.x===n.x,e.y===n.y,e.z===n.z),vec4f:(e,n)=>_chunkUMHCZDPAcjs.Fa.call(void 0, e.x===n.x,e.y===n.y,e.z===n.z,e.w===n.w),vec4h:(e,n)=>_chunkUMHCZDPAcjs.Fa.call(void 0, e.x===n.x,e.y===n.y,e.z===n.z,e.w===n.w),vec4i:(e,n)=>_chunkUMHCZDPAcjs.Fa.call(void 0, e.x===n.x,e.y===n.y,e.z===n.z,e.w===n.w),vec4u:(e,n)=>_chunkUMHCZDPAcjs.Fa.call(void 0, e.x===n.x,e.y===n.y,e.z===n.z,e.w===n.w),"vec4<bool>":(e,n)=>_chunkUMHCZDPAcjs.Fa.call(void 0, e.x===n.x,e.y===n.y,e.z===n.z,e.w===n.w)},lt:{vec2f:(e,n)=>_chunkUMHCZDPAcjs.va.call(void 0, e.x<n.x,e.y<n.y),vec2h:(e,n)=>_chunkUMHCZDPAcjs.va.call(void 0, e.x<n.x,e.y<n.y),vec2i:(e,n)=>_chunkUMHCZDPAcjs.va.call(void 0, e.x<n.x,e.y<n.y),vec2u:(e,n)=>_chunkUMHCZDPAcjs.va.call(void 0, e.x<n.x,e.y<n.y),vec3f:(e,n)=>_chunkUMHCZDPAcjs.Aa.call(void 0, e.x<n.x,e.y<n.y,e.z<n.z),vec3h:(e,n)=>_chunkUMHCZDPAcjs.Aa.call(void 0, e.x<n.x,e.y<n.y,e.z<n.z),vec3i:(e,n)=>_chunkUMHCZDPAcjs.Aa.call(void 0, e.x<n.x,e.y<n.y,e.z<n.z),vec3u:(e,n)=>_chunkUMHCZDPAcjs.Aa.call(void 0, e.x<n.x,e.y<n.y,e.z<n.z),vec4f:(e,n)=>_chunkUMHCZDPAcjs.Fa.call(void 0, e.x<n.x,e.y<n.y,e.z<n.z,e.w<n.w),vec4h:(e,n)=>_chunkUMHCZDPAcjs.Fa.call(void 0, e.x<n.x,e.y<n.y,e.z<n.z,e.w<n.w),vec4i:(e,n)=>_chunkUMHCZDPAcjs.Fa.call(void 0, e.x<n.x,e.y<n.y,e.z<n.z,e.w<n.w),vec4u:(e,n)=>_chunkUMHCZDPAcjs.Fa.call(void 0, e.x<n.x,e.y<n.y,e.z<n.z,e.w<n.w)},or:{"vec2<bool>":(e,n)=>_chunkUMHCZDPAcjs.va.call(void 0, e.x||n.x,e.y||n.y),"vec3<bool>":(e,n)=>_chunkUMHCZDPAcjs.Aa.call(void 0, e.x||n.x,e.y||n.y,e.z||n.z),"vec4<bool>":(e,n)=>_chunkUMHCZDPAcjs.Fa.call(void 0, e.x||n.x,e.y||n.y,e.z||n.z,e.w||n.w)},all:{"vec2<bool>":e=>e.x&&e.y,"vec3<bool>":e=>e.x&&e.y&&e.z,"vec4<bool>":e=>e.x&&e.y&&e.z&&e.w},abs:{vec2f:u(Math.abs),vec2h:w(Math.abs),vec2i:R(Math.abs),vec2u:K(Math.abs),vec3f:y(Math.abs),vec3h:l(Math.abs),vec3i:$(Math.abs),vec3u:k(Math.abs),vec4f:x(Math.abs),vec4h:o(Math.abs),vec4i:N(Math.abs),vec4u:O(Math.abs)},atan2:{vec2f:F(Math.atan2),vec2h:j(Math.atan2),vec3f:A(Math.atan2),vec3h:P(Math.atan2),vec4f:p(Math.atan2),vec4h:Z(Math.atan2)},acos:{vec2f:u(Math.acos),vec2h:w(Math.acos),vec2i:R(Math.acos),vec2u:K(Math.acos),vec3f:y(Math.acos),vec3h:l(Math.acos),vec3i:$(Math.acos),vec3u:k(Math.acos),vec4f:x(Math.acos),vec4h:o(Math.acos),vec4i:N(Math.acos),vec4u:O(Math.acos)},acosh:{vec2f:u(Math.acosh),vec2h:w(Math.acosh),vec3f:y(Math.acosh),vec3h:l(Math.acosh),vec4f:x(Math.acosh),vec4h:o(Math.acosh)},asin:{vec2f:u(Math.asin),vec2h:w(Math.asin),vec2i:R(Math.asin),vec2u:K(Math.asin),vec3f:y(Math.asin),vec3h:l(Math.asin),vec3i:$(Math.asin),vec3u:k(Math.asin),vec4f:x(Math.asin),vec4h:o(Math.asin),vec4i:N(Math.asin),vec4u:O(Math.asin)},ceil:{vec2f:u(Math.ceil),vec2h:w(Math.ceil),vec3f:y(Math.ceil),vec3h:l(Math.ceil),vec4f:x(Math.ceil),vec4h:o(Math.ceil)},clamp:{vec2f:(e,n,s)=>_chunkUMHCZDPAcjs.ra.call(void 0, r(e.x,n.x,s.x),r(e.y,n.y,s.y)),vec2h:(e,n,s)=>_chunkUMHCZDPAcjs.sa.call(void 0, r(e.x,n.x,s.x),r(e.y,n.y,s.y)),vec2i:(e,n,s)=>_chunkUMHCZDPAcjs.ta.call(void 0, r(e.x,n.x,s.x),r(e.y,n.y,s.y)),vec2u:(e,n,s)=>_chunkUMHCZDPAcjs.ua.call(void 0, r(e.x,n.x,s.x),r(e.y,n.y,s.y)),vec3f:(e,n,s)=>_chunkUMHCZDPAcjs.wa.call(void 0, r(e.x,n.x,s.x),r(e.y,n.y,s.y),r(e.z,n.z,s.z)),vec3h:(e,n,s)=>_chunkUMHCZDPAcjs.xa.call(void 0, r(e.x,n.x,s.x),r(e.y,n.y,s.y),r(e.z,n.z,s.z)),vec3i:(e,n,s)=>_chunkUMHCZDPAcjs.ya.call(void 0, r(e.x,n.x,s.x),r(e.y,n.y,s.y),r(e.z,n.z,s.z)),vec3u:(e,n,s)=>_chunkUMHCZDPAcjs.za.call(void 0, r(e.x,n.x,s.x),r(e.y,n.y,s.y),r(e.z,n.z,s.z)),vec4f:(e,n,s)=>_chunkUMHCZDPAcjs.Ba.call(void 0, r(e.x,n.x,s.x),r(e.y,n.y,s.y),r(e.z,n.z,s.z),r(e.w,n.w,s.w)),vec4h:(e,n,s)=>_chunkUMHCZDPAcjs.Ca.call(void 0, r(e.x,n.x,s.x),r(e.y,n.y,s.y),r(e.z,n.z,s.z),r(e.w,n.w,s.w)),vec4i:(e,n,s)=>_chunkUMHCZDPAcjs.Da.call(void 0, r(e.x,n.x,s.x),r(e.y,n.y,s.y),r(e.z,n.z,s.z),r(e.w,n.w,s.w)),vec4u:(e,n,s)=>_chunkUMHCZDPAcjs.Ea.call(void 0, r(e.x,n.x,s.x),r(e.y,n.y,s.y),r(e.z,n.z,s.z),r(e.w,n.w,s.w))},length:{vec2f:S,vec2h:S,vec3f:D,vec3h:D,vec4f:E,vec4h:E},add:{vec2f:F((e,n)=>e+n),vec2h:j((e,n)=>e+n),vec2i:J((e,n)=>e+n),vec2u:Q((e,n)=>e+n),vec3f:A((e,n)=>e+n),vec3h:P((e,n)=>e+n),vec3i:X((e,n)=>e+n),vec3u:Y((e,n)=>e+n),vec4f:p((e,n)=>e+n),vec4h:Z((e,n)=>e+n),vec4i:ee((e,n)=>e+n),vec4u:ne((e,n)=>e+n),mat2x2f:fe((e,n)=>e+n),mat3x3f:ge((e,n)=>e+n),mat4x4f:he((e,n)=>e+n)},addMixed:{vec2f:(e,n)=>u(s=>s+n)(e),vec2h:(e,n)=>w(s=>s+n)(e),vec2i:(e,n)=>R(s=>s+n)(e),vec2u:(e,n)=>K(s=>s+n)(e),vec3f:(e,n)=>y(s=>s+n)(e),vec3h:(e,n)=>l(s=>s+n)(e),vec3i:(e,n)=>$(s=>s+n)(e),vec3u:(e,n)=>k(s=>s+n)(e),vec4f:(e,n)=>x(s=>s+n)(e),vec4h:(e,n)=>o(s=>s+n)(e),vec4i:(e,n)=>N(s=>s+n)(e),vec4u:(e,n)=>O(s=>s+n)(e),mat2x2f:(e,n)=>ue(s=>s+n)(e),mat3x3f:(e,n)=>we(s=>s+n)(e),mat4x4f:(e,n)=>le(s=>s+n)(e)},mulSxV:{vec2f:(e,n)=>u(s=>e*s)(n),vec2h:(e,n)=>w(s=>e*s)(n),vec2i:(e,n)=>R(s=>e*s)(n),vec2u:(e,n)=>K(s=>e*s)(n),vec3f:(e,n)=>y(s=>e*s)(n),vec3h:(e,n)=>l(s=>e*s)(n),vec3i:(e,n)=>$(s=>e*s)(n),vec3u:(e,n)=>k(s=>e*s)(n),vec4f:(e,n)=>x(s=>e*s)(n),vec4h:(e,n)=>o(s=>e*s)(n),vec4i:(e,n)=>N(s=>e*s)(n),vec4u:(e,n)=>O(s=>e*s)(n),mat2x2f:(e,n)=>ue(s=>e*s)(n),mat3x3f:(e,n)=>we(s=>e*s)(n),mat4x4f:(e,n)=>le(s=>e*s)(n)},mulVxV:{vec2f:F((e,n)=>e*n),vec2h:j((e,n)=>e*n),vec2i:J((e,n)=>e*n),vec2u:Q((e,n)=>e*n),vec3f:A((e,n)=>e*n),vec3h:P((e,n)=>e*n),vec3i:X((e,n)=>e*n),vec3u:Y((e,n)=>e*n),vec4f:p((e,n)=>e*n),vec4h:Z((e,n)=>e*n),vec4i:ee((e,n)=>e*n),vec4u:ne((e,n)=>e*n),mat2x2f:(e,n)=>{let s=e.columns,t=n.columns;return _chunkUMHCZDPAcjs.Pa.call(void 0, s[0].x*t[0].x+s[1].x*t[0].y,s[0].y*t[0].x+s[1].y*t[0].y,s[0].x*t[1].x+s[1].x*t[1].y,s[0].y*t[1].x+s[1].y*t[1].y)},mat3x3f:(e,n)=>{let s=e.columns,t=n.columns;return _chunkUMHCZDPAcjs.Qa.call(void 0, s[0].x*t[0].x+s[1].x*t[0].y+s[2].x*t[0].z,s[0].y*t[0].x+s[1].y*t[0].y+s[2].y*t[0].z,s[0].z*t[0].x+s[1].z*t[0].y+s[2].z*t[0].z,s[0].x*t[1].x+s[1].x*t[1].y+s[2].x*t[1].z,s[0].y*t[1].x+s[1].y*t[1].y+s[2].y*t[1].z,s[0].z*t[1].x+s[1].z*t[1].y+s[2].z*t[1].z,s[0].x*t[2].x+s[1].x*t[2].y+s[2].x*t[2].z,s[0].y*t[2].x+s[1].y*t[2].y+s[2].y*t[2].z,s[0].z*t[2].x+s[1].z*t[2].y+s[2].z*t[2].z)},mat4x4f:(e,n)=>{let s=e.columns,t=n.columns;return _chunkUMHCZDPAcjs.Ra.call(void 0, s[0].x*t[0].x+s[1].x*t[0].y+s[2].x*t[0].z+s[3].x*t[0].w,s[0].y*t[0].x+s[1].y*t[0].y+s[2].y*t[0].z+s[3].y*t[0].w,s[0].z*t[0].x+s[1].z*t[0].y+s[2].z*t[0].z+s[3].z*t[0].w,s[0].w*t[0].x+s[1].w*t[0].y+s[2].w*t[0].z+s[3].w*t[0].w,s[0].x*t[1].x+s[1].x*t[1].y+s[2].x*t[1].z+s[3].x*t[1].w,s[0].y*t[1].x+s[1].y*t[1].y+s[2].y*t[1].z+s[3].y*t[1].w,s[0].z*t[1].x+s[1].z*t[1].y+s[2].z*t[1].z+s[3].z*t[1].w,s[0].w*t[1].x+s[1].w*t[1].y+s[2].w*t[1].z+s[3].w*t[1].w,s[0].x*t[2].x+s[1].x*t[2].y+s[2].x*t[2].z+s[3].x*t[2].w,s[0].y*t[2].x+s[1].y*t[2].y+s[2].y*t[2].z+s[3].y*t[2].w,s[0].z*t[2].x+s[1].z*t[2].y+s[2].z*t[2].z+s[3].z*t[2].w,s[0].w*t[2].x+s[1].w*t[2].y+s[2].w*t[2].z+s[3].w*t[2].w,s[0].x*t[3].x+s[1].x*t[3].y+s[2].x*t[3].z+s[3].x*t[3].w,s[0].y*t[3].x+s[1].y*t[3].y+s[2].y*t[3].z+s[3].y*t[3].w,s[0].z*t[3].x+s[1].z*t[3].y+s[2].z*t[3].z+s[3].z*t[3].w,s[0].w*t[3].x+s[1].w*t[3].y+s[2].w*t[3].z+s[3].w*t[3].w)}},mulMxV:{mat2x2f:(e,n)=>{let s=e.columns;return _chunkUMHCZDPAcjs.ra.call(void 0, s[0].x*n.x+s[1].x*n.y,s[0].y*n.x+s[1].y*n.y)},mat3x3f:(e,n)=>{let s=e.columns;return _chunkUMHCZDPAcjs.wa.call(void 0, s[0].x*n.x+s[1].x*n.y+s[2].x*n.z,s[0].y*n.x+s[1].y*n.y+s[2].y*n.z,s[0].z*n.x+s[1].z*n.y+s[2].z*n.z)},mat4x4f:(e,n)=>{let s=e.columns;return _chunkUMHCZDPAcjs.Ba.call(void 0, s[0].x*n.x+s[1].x*n.y+s[2].x*n.z+s[3].x*n.w,s[0].y*n.x+s[1].y*n.y+s[2].y*n.z+s[3].y*n.w,s[0].z*n.x+s[1].z*n.y+s[2].z*n.z+s[3].z*n.w,s[0].w*n.x+s[1].w*n.y+s[2].w*n.z+s[3].w*n.w)}},mulVxM:{mat2x2f:(e,n)=>{let s=n.columns;return _chunkUMHCZDPAcjs.ra.call(void 0, e.x*s[0].x+e.y*s[0].y,e.x*s[1].x+e.y*s[1].y)},mat3x3f:(e,n)=>{let s=n.columns;return _chunkUMHCZDPAcjs.wa.call(void 0, e.x*s[0].x+e.y*s[0].y+e.z*s[0].z,e.x*s[1].x+e.y*s[1].y+e.z*s[1].z,e.x*s[2].x+e.y*s[2].y+e.z*s[2].z)},mat4x4f:(e,n)=>{let s=n.columns;return _chunkUMHCZDPAcjs.Ba.call(void 0, e.x*s[0].x+e.y*s[0].y+e.z*s[0].z+e.w*s[0].w,e.x*s[1].x+e.y*s[1].y+e.z*s[1].z+e.w*s[1].w,e.x*s[2].x+e.y*s[2].y+e.z*s[2].z+e.w*s[2].w,e.x*s[3].x+e.y*s[3].y+e.z*s[3].z+e.w*s[3].w)}},div:{vec2f:F((e,n)=>e/n),vec2h:j((e,n)=>e/n),vec2i:J(d.divInteger),vec2u:Q(d.divInteger),vec3f:A((e,n)=>e/n),vec3h:P((e,n)=>e/n),vec3i:X(d.divInteger),vec3u:Y(d.divInteger),vec4f:p((e,n)=>e/n),vec4h:Z((e,n)=>e/n),vec4i:ee(d.divInteger),vec4u:ne(d.divInteger)},divMixed:{vec2f:(e,n)=>u(s=>s/n)(e),vec2h:(e,n)=>w(s=>s/n)(e),vec2i:(e,n)=>R(s=>d.divInteger(s,n))(e),vec2u:(e,n)=>K(s=>d.divInteger(s,n))(e),vec3f:(e,n)=>y(s=>s/n)(e),vec3h:(e,n)=>l(s=>s/n)(e),vec3i:(e,n)=>$(s=>d.divInteger(s,n))(e),vec3u:(e,n)=>k(s=>d.divInteger(s,n))(e),vec4f:(e,n)=>x(s=>s/n)(e),vec4h:(e,n)=>o(s=>s/n)(e),vec4i:(e,n)=>N(s=>d.divInteger(s,n))(e),vec4u:(e,n)=>O(s=>d.divInteger(s,n))(e)},dot:{vec2f:ae,vec2h:ae,vec2i:ae,vec2u:ae,vec3f:re,vec3h:re,vec3i:re,vec3u:re,vec4f:ve,vec4h:ve,vec4i:ve,vec4u:ve},normalize:{vec2f:e=>{let n=S(e);return _chunkUMHCZDPAcjs.ra.call(void 0, e.x/n,e.y/n)},vec2h:e=>{let n=S(e);return _chunkUMHCZDPAcjs.sa.call(void 0, e.x/n,e.y/n)},vec2i:e=>{let n=S(e);return _chunkUMHCZDPAcjs.ta.call(void 0, e.x/n,e.y/n)},vec2u:e=>{let n=S(e);return _chunkUMHCZDPAcjs.ua.call(void 0, e.x/n,e.y/n)},vec3f:e=>{let n=D(e);return _chunkUMHCZDPAcjs.wa.call(void 0, e.x/n,e.y/n,e.z/n)},vec3h:e=>{let n=D(e);return _chunkUMHCZDPAcjs.xa.call(void 0, e.x/n,e.y/n,e.z/n)},vec3i:e=>{let n=D(e);return _chunkUMHCZDPAcjs.ya.call(void 0, e.x/n,e.y/n,e.z/n)},vec3u:e=>{let n=D(e);return _chunkUMHCZDPAcjs.za.call(void 0, e.x/n,e.y/n,e.z/n)},vec4f:e=>{let n=E(e);return _chunkUMHCZDPAcjs.Ba.call(void 0, e.x/n,e.y/n,e.z/n,e.w/n)},vec4h:e=>{let n=E(e);return _chunkUMHCZDPAcjs.Ca.call(void 0, e.x/n,e.y/n,e.z/n,e.w/n)},vec4i:e=>{let n=E(e);return _chunkUMHCZDPAcjs.Da.call(void 0, e.x/n,e.y/n,e.z/n,e.w/n)},vec4u:e=>{let n=E(e);return _chunkUMHCZDPAcjs.Ea.call(void 0, e.x/n,e.y/n,e.z/n,e.w/n)}},cross:{vec3f:(e,n)=>_chunkUMHCZDPAcjs.wa.call(void 0, e.y*n.z-e.z*n.y,e.z*n.x-e.x*n.z,e.x*n.y-e.y*n.x),vec3h:(e,n)=>_chunkUMHCZDPAcjs.xa.call(void 0, e.y*n.z-e.z*n.y,e.z*n.x-e.x*n.z,e.x*n.y-e.y*n.x)},floor:{vec2f:u(Math.floor),vec2h:w(Math.floor),vec3f:y(Math.floor),vec3h:l(Math.floor),vec4f:x(Math.floor),vec4h:o(Math.floor)},max:{vec2f:F(Math.max),vec2h:j(Math.max),vec2i:J(Math.max),vec2u:Q(Math.max),vec3f:A(Math.max),vec3h:P(Math.max),vec3i:X(Math.max),vec3u:Y(Math.max),vec4f:p(Math.max),vec4h:Z(Math.max),vec4i:ee(Math.max),vec4u:ne(Math.max)},min:{vec2f:F(Math.min),vec2h:j(Math.min),vec2i:J(Math.min),vec2u:Q(Math.min),vec3f:A(Math.min),vec3h:P(Math.min),vec3i:X(Math.min),vec3u:Y(Math.min),vec4f:p(Math.min),vec4h:Z(Math.min),vec4i:ee(Math.min),vec4u:ne(Math.min)},pow:{vec2f:(e,n)=>_chunkUMHCZDPAcjs.ra.call(void 0, e.x**n.x,e.y**n.y),vec2h:(e,n)=>_chunkUMHCZDPAcjs.sa.call(void 0, e.x**n.x,e.y**n.y),vec3f:(e,n)=>_chunkUMHCZDPAcjs.wa.call(void 0, e.x**n.x,e.y**n.y,e.z**n.z),vec3h:(e,n)=>_chunkUMHCZDPAcjs.xa.call(void 0, e.x**n.x,e.y**n.y,e.z**n.z),vec4f:(e,n)=>_chunkUMHCZDPAcjs.Ba.call(void 0, e.x**n.x,e.y**n.y,e.z**n.z,e.w**n.w),vec4h:(e,n)=>_chunkUMHCZDPAcjs.Ca.call(void 0, e.x**n.x,e.y**n.y,e.z**n.z,e.w**n.w)},sign:{vec2f:u(Math.sign),vec2h:w(Math.sign),vec2i:R(Math.sign),vec3f:y(Math.sign),vec3h:l(Math.sign),vec3i:$(Math.sign),vec4f:x(Math.sign),vec4h:o(Math.sign),vec4i:N(Math.sign)},sqrt:{vec2f:u(Math.sqrt),vec2h:w(Math.sqrt),vec3f:y(Math.sqrt),vec3h:l(Math.sqrt),vec4f:x(Math.sqrt),vec4h:o(Math.sqrt)},mix:{vec2f:(e,n,s)=>typeof s=="number"?_chunkUMHCZDPAcjs.ra.call(void 0, e.x*(1-s)+n.x*s,e.y*(1-s)+n.y*s):_chunkUMHCZDPAcjs.ra.call(void 0, e.x*(1-s.x)+n.x*s.x,e.y*(1-s.y)+n.y*s.y),vec2h:(e,n,s)=>typeof s=="number"?_chunkUMHCZDPAcjs.sa.call(void 0, e.x*(1-s)+n.x*s,e.y*(1-s)+n.y*s):_chunkUMHCZDPAcjs.sa.call(void 0, e.x*(1-s.x)+n.x*s.x,e.y*(1-s.y)+n.y*s.y),vec3f:(e,n,s)=>typeof s=="number"?_chunkUMHCZDPAcjs.wa.call(void 0, e.x*(1-s)+n.x*s,e.y*(1-s)+n.y*s,e.z*(1-s)+n.z*s):_chunkUMHCZDPAcjs.wa.call(void 0, e.x*(1-s.x)+n.x*s.x,e.y*(1-s.y)+n.y*s.y,e.z*(1-s.z)+n.z*s.z),vec3h:(e,n,s)=>typeof s=="number"?_chunkUMHCZDPAcjs.xa.call(void 0, e.x*(1-s)+n.x*s,e.y*(1-s)+n.y*s,e.z*(1-s)+n.z*s):_chunkUMHCZDPAcjs.xa.call(void 0, e.x*(1-s.x)+n.x*s.x,e.y*(1-s.y)+n.y*s.y,e.z*(1-s.z)+n.z*s.z),vec4f:(e,n,s)=>typeof s=="number"?_chunkUMHCZDPAcjs.Ba.call(void 0, e.x*(1-s)+n.x*s,e.y*(1-s)+n.y*s,e.z*(1-s)+n.z*s,e.w*(1-s)+n.w*s):_chunkUMHCZDPAcjs.Ba.call(void 0, e.x*(1-s.x)+n.x*s.x,e.y*(1-s.y)+n.y*s.y,e.z*(1-s.z)+n.z*s.z,e.w*(1-s.w)+n.w*s.w),vec4h:(e,n,s)=>typeof s=="number"?_chunkUMHCZDPAcjs.Ca.call(void 0, e.x*(1-s)+n.x*s,e.y*(1-s)+n.y*s,e.z*(1-s)+n.z*s,e.w*(1-s)+n.w*s):_chunkUMHCZDPAcjs.Ca.call(void 0, e.x*(1-s.x)+n.x*s.x,e.y*(1-s.y)+n.y*s.y,e.z*(1-s.z)+n.z*s.z,e.w*(1-s.w)+n.w*s.w)},sin:{vec2f:u(Math.sin),vec2h:w(Math.sin),vec3f:y(Math.sin),vec3h:l(Math.sin),vec4f:x(Math.sin),vec4h:o(Math.sin)},cos:{vec2f:u(Math.cos),vec2h:w(Math.cos),vec3f:y(Math.cos),vec3h:l(Math.cos),vec4f:x(Math.cos),vec4h:o(Math.cos)},cosh:{vec2f:u(Math.cosh),vec2h:w(Math.cosh),vec3f:y(Math.cosh),vec3h:l(Math.cosh),vec4f:x(Math.cosh),vec4h:o(Math.cosh)},exp:{vec2f:u(Math.exp),vec2h:w(Math.exp),vec3f:y(Math.exp),vec3h:l(Math.exp),vec4f:x(Math.exp),vec4h:o(Math.exp)},exp2:{vec2f:u(e=>2**e),vec2h:w(e=>2**e),vec3f:y(e=>2**e),vec3h:l(e=>2**e),vec4f:x(e=>2**e),vec4h:o(e=>2**e)},log:{vec2f:u(Math.log),vec2h:w(Math.log),vec3f:y(Math.log),vec3h:l(Math.log),vec4f:x(Math.log),vec4h:o(Math.log)},log2:{vec2f:u(Math.log2),vec2h:w(Math.log2),vec3f:y(Math.log2),vec3h:l(Math.log2),vec4f:x(Math.log2),vec4h:o(Math.log2)},fract:{vec2f:u(e=>e-Math.floor(e)),vec2h:w(e=>e-Math.floor(e)),vec3f:y(e=>e-Math.floor(e)),vec3h:l(e=>e-Math.floor(e)),vec4f:x(e=>e-Math.floor(e)),vec4h:o(e=>e-Math.floor(e))},isCloseToZero:{vec2f:(e,n)=>Math.abs(e.x)<=n&&Math.abs(e.y)<=n,vec2h:(e,n)=>Math.abs(e.x)<=n&&Math.abs(e.y)<=n,vec3f:(e,n)=>Math.abs(e.x)<=n&&Math.abs(e.y)<=n&&Math.abs(e.z)<=n,vec3h:(e,n)=>Math.abs(e.x)<=n&&Math.abs(e.y)<=n&&Math.abs(e.z)<=n,vec4f:(e,n)=>Math.abs(e.x)<=n&&Math.abs(e.y)<=n&&Math.abs(e.z)<=n&&Math.abs(e.w)<=n,vec4h:(e,n)=>Math.abs(e.x)<=n&&Math.abs(e.y)<=n&&Math.abs(e.z)<=n&&Math.abs(e.w)<=n},neg:{vec2f:u(e=>-e),vec2h:w(e=>-e),vec2i:R(e=>-e),vec2u:K(e=>-e),"vec2<bool>":e=>_chunkUMHCZDPAcjs.va.call(void 0, !e.x,!e.y),vec3f:y(e=>-e),vec3h:l(e=>-e),vec3i:$(e=>-e),vec3u:k(e=>-e),"vec3<bool>":e=>_chunkUMHCZDPAcjs.Aa.call(void 0, !e.x,!e.y,!e.z),vec4f:x(e=>-e),vec4h:o(e=>-e),vec4i:N(e=>-e),vec4u:O(e=>-e),"vec4<bool>":e=>_chunkUMHCZDPAcjs.Fa.call(void 0, !e.x,!e.y,!e.z,!e.w)},select:{vec2f:(e,n,s)=>_chunkUMHCZDPAcjs.ra.call(void 0, s.x?n.x:e.x,s.y?n.y:e.y),vec2h:(e,n,s)=>_chunkUMHCZDPAcjs.sa.call(void 0, s.x?n.x:e.x,s.y?n.y:e.y),vec2i:(e,n,s)=>_chunkUMHCZDPAcjs.ta.call(void 0, s.x?n.x:e.x,s.y?n.y:e.y),vec2u:(e,n,s)=>_chunkUMHCZDPAcjs.ua.call(void 0, s.x?n.x:e.x,s.y?n.y:e.y),"vec2<bool>":(e,n,s)=>_chunkUMHCZDPAcjs.va.call(void 0, s.x?n.x:e.x,s.y?n.y:e.y),vec3f:(e,n,s)=>_chunkUMHCZDPAcjs.wa.call(void 0, s.x?n.x:e.x,s.y?n.y:e.y,s.z?n.z:e.z),vec3h:(e,n,s)=>_chunkUMHCZDPAcjs.xa.call(void 0, s.x?n.x:e.x,s.y?n.y:e.y,s.z?n.z:e.z),vec3i:(e,n,s)=>_chunkUMHCZDPAcjs.ya.call(void 0, s.x?n.x:e.x,s.y?n.y:e.y,s.z?n.z:e.z),vec3u:(e,n,s)=>_chunkUMHCZDPAcjs.za.call(void 0, s.x?n.x:e.x,s.y?n.y:e.y,s.z?n.z:e.z),"vec3<bool>":(e,n,s)=>_chunkUMHCZDPAcjs.Aa.call(void 0, s.x?n.x:e.x,s.y?n.y:e.y,s.z?n.z:e.z),vec4f:(e,n,s)=>_chunkUMHCZDPAcjs.Ba.call(void 0, s.x?n.x:e.x,s.y?n.y:e.y,s.z?n.z:e.z,s.w?n.w:e.w),vec4h:(e,n,s)=>_chunkUMHCZDPAcjs.Ca.call(void 0, s.x?n.x:e.x,s.y?n.y:e.y,s.z?n.z:e.z,s.w?n.w:e.w),vec4i:(e,n,s)=>_chunkUMHCZDPAcjs.Da.call(void 0, s.x?n.x:e.x,s.y?n.y:e.y,s.z?n.z:e.z,s.w?n.w:e.w),vec4u:(e,n,s)=>_chunkUMHCZDPAcjs.Ea.call(void 0, s.x?n.x:e.x,s.y?n.y:e.y,s.z?n.z:e.z,s.w?n.w:e.w),"vec4<bool>":(e,n,s)=>_chunkUMHCZDPAcjs.Fa.call(void 0, s.x?n.x:e.x,s.y?n.y:e.y,s.z?n.z:e.z,s.w?n.w:e.w)},tanh:{vec2f:u(Math.tanh),vec2h:w(Math.tanh),vec3f:y(Math.tanh),vec3h:l(Math.tanh),vec4f:x(Math.tanh),vec4h:o(Math.tanh)}};function G(e){return de(e.dataType)}function de(e){let n=_optionalChain([e, 'optionalAccess', _2 => _2.type]);return!!_optionalChain([e, 'optionalAccess', _3 => _3[_chunkUMHCZDPAcjs.a]])&&(n==="abstractInt"||n==="abstractFloat"||n==="f32"||n==="f16"||n==="i32"||n==="u32")}function oe(e,n){if(typeof e=="number"&&typeof n=="number")return e+n;if(typeof e=="number"&&_chunkUMHCZDPAcjs.D.call(void 0, n))return c.addMixed[n.kind](n,e);if(_chunkUMHCZDPAcjs.D.call(void 0, e)&&typeof n=="number")return c.addMixed[e.kind](e,n);if(_chunkUMHCZDPAcjs.D.call(void 0, e)&&_chunkUMHCZDPAcjs.D.call(void 0, n)||_chunkUMHCZDPAcjs.H.call(void 0, e)&&_chunkUMHCZDPAcjs.H.call(void 0, n))return c.add[e.kind](e,n);throw new Error("Add/Sub called with invalid arguments.")}var ke=_chunkUMHCZDPAcjs.ia.call(void 0, oe,(e,n)=>_chunkUMHCZDPAcjs.fa.call(void 0, `(${e.value} + ${n.value})`,G(e)?n.dataType:e.dataType),"coerce");function Te(e,n){return oe(e,me(-1,n))}var ie=_chunkUMHCZDPAcjs.ia.call(void 0, Te,(e,n)=>_chunkUMHCZDPAcjs.fa.call(void 0, `(${e.value} - ${n.value})`,G(e)?n.dataType:e.dataType),"sub","coerce");function be(e,n){if(typeof e=="number"&&typeof n=="number")return e*n;if(typeof e=="number"&&(_chunkUMHCZDPAcjs.D.call(void 0, n)||_chunkUMHCZDPAcjs.H.call(void 0, n)))return c.mulSxV[n.kind](e,n);if((_chunkUMHCZDPAcjs.D.call(void 0, e)||_chunkUMHCZDPAcjs.H.call(void 0, e))&&typeof n=="number")return c.mulSxV[e.kind](n,e);if(_chunkUMHCZDPAcjs.D.call(void 0, e)&&_chunkUMHCZDPAcjs.D.call(void 0, n))return c.mulVxV[e.kind](e,n);if(_chunkUMHCZDPAcjs.L.call(void 0, e)&&_chunkUMHCZDPAcjs.H.call(void 0, n))return c.mulVxM[n.kind](e,n);if(_chunkUMHCZDPAcjs.H.call(void 0, e)&&_chunkUMHCZDPAcjs.L.call(void 0, n))return c.mulMxV[e.kind](e,n);if(_chunkUMHCZDPAcjs.H.call(void 0, e)&&_chunkUMHCZDPAcjs.H.call(void 0, n))return c.mulVxV[e.kind](e,n);throw new Error("Mul called with invalid arguments.")}var me=_chunkUMHCZDPAcjs.ia.call(void 0, be,(e,n)=>{let s=G(e)?n.dataType:G(n)||e.dataType.type.startsWith("vec")?e.dataType:n.dataType.type.startsWith("vec")?n.dataType:e.dataType;return _chunkUMHCZDPAcjs.fa.call(void 0, `(${e.value} * ${n.value})`,s)},"mul");function Me(e,n){if(typeof e=="number"&&typeof n=="number")return e/n;if(typeof e=="number"&&_chunkUMHCZDPAcjs.D.call(void 0, n))return c.divMixed[n.kind](n,e);if(_chunkUMHCZDPAcjs.D.call(void 0, e)&&typeof n=="number")return c.divMixed[e.kind](e,n);if(_chunkUMHCZDPAcjs.D.call(void 0, e)&&_chunkUMHCZDPAcjs.D.call(void 0, n))return c.div[e.kind](e,n);throw new Error("Div called with invalid arguments.")}var Oe=_chunkUMHCZDPAcjs.ia.call(void 0, Me,(e,n)=>G(e)&&G(n)?_chunkUMHCZDPAcjs.fa.call(void 0, `(f32(${e.value}) / ${n.value})`,_chunkUMHCZDPAcjs.pa):_chunkUMHCZDPAcjs.fa.call(void 0, `(${e.value} / ${n.value})`,e.dataType),"div"),Le= exports.h =_chunkUMHCZDPAcjs.ia.call(void 0, e=>typeof e=="number"?Math.abs(e):c.abs[e.kind](e),e=>_chunkUMHCZDPAcjs.fa.call(void 0, `abs(${e.value})`,e.dataType),"abs"),_e= exports.i =_chunkUMHCZDPAcjs.ia.call(void 0, (e,n)=>typeof e=="number"&&typeof n=="number"?Math.atan2(e,n):c.atan2[e.kind](e,n),(e,n)=>_chunkUMHCZDPAcjs.fa.call(void 0, `atan2(${e.value}, ${n.value})`,e.dataType),"atan2"),Ue= exports.j =_chunkUMHCZDPAcjs.ia.call(void 0, e=>typeof e=="number"?Math.acos(e):c.acos[e.kind](e),e=>_chunkUMHCZDPAcjs.fa.call(void 0, `acos(${e.value})`,e.dataType),"acos"),We= exports.k =_chunkUMHCZDPAcjs.ia.call(void 0, e=>typeof e=="number"?Math.acosh(e):c.acosh[e.kind](e),e=>_chunkUMHCZDPAcjs.fa.call(void 0, `acosh(${e.value})`,e.dataType),"acosh"),qe= exports.l =_chunkUMHCZDPAcjs.ia.call(void 0, e=>typeof e=="number"?Math.asin(e):c.asin[e.kind](e),e=>_chunkUMHCZDPAcjs.fa.call(void 0, `asin(${e.value})`,e.dataType),"asin"),Ce= exports.m =_chunkUMHCZDPAcjs.ia.call(void 0, e=>typeof e=="number"?Math.ceil(e):c.ceil[e.kind](e),e=>_chunkUMHCZDPAcjs.fa.call(void 0, `ceil(${e.value})`,e.dataType),"ceil"),Se= exports.n =_chunkUMHCZDPAcjs.ia.call(void 0, (e,n,s)=>typeof e=="number"?Math.min(Math.max(n,e),s):c.clamp[e.kind](e,n,s),(e,n,s)=>_chunkUMHCZDPAcjs.fa.call(void 0, `clamp(${e.value}, ${n.value}, ${s.value})`,e.dataType),"clamp"),De= exports.o =_chunkUMHCZDPAcjs.ia.call(void 0, e=>typeof e=="number"?Math.cos(e):c.cos[e.kind](e),e=>_chunkUMHCZDPAcjs.fa.call(void 0, `cos(${e.value})`,e.dataType),"cos"),Ee= exports.p =_chunkUMHCZDPAcjs.ia.call(void 0, e=>typeof e=="number"?Math.cosh(e):c.cosh[e.kind](e),e=>_chunkUMHCZDPAcjs.fa.call(void 0, `cosh(${e.value})`,e.dataType),"cosh"),je= exports.q =_chunkUMHCZDPAcjs.ia.call(void 0, (e,n)=>c.cross[e.kind](e,n),(e,n)=>_chunkUMHCZDPAcjs.fa.call(void 0, `cross(${e.value}, ${n.value})`,e.dataType),"cross"),ze= exports.r =_chunkUMHCZDPAcjs.ia.call(void 0, (e,n)=>c.dot[e.kind](e,n),(e,n)=>_chunkUMHCZDPAcjs.fa.call(void 0, `dot(${e.value}, ${n.value})`,_chunkUMHCZDPAcjs.pa),"dot"),Pe= exports.s =_chunkUMHCZDPAcjs.ia.call(void 0, e=>c.normalize[e.kind](e),e=>_chunkUMHCZDPAcjs.fa.call(void 0, `normalize(${e.value})`,e.dataType),"normalize"),Ze= exports.t =_chunkUMHCZDPAcjs.ia.call(void 0, e=>typeof e=="number"?Math.floor(e):c.floor[e.kind](e),e=>_chunkUMHCZDPAcjs.fa.call(void 0, `floor(${e.value})`,e.dataType),"floor"),Ge= exports.u =_chunkUMHCZDPAcjs.ia.call(void 0, e=>typeof e=="number"?e-Math.floor(e):c.fract[e.kind](e),e=>_chunkUMHCZDPAcjs.fa.call(void 0, `fract(${e.value})`,e.dataType),"fract"),pe= exports.v =_chunkUMHCZDPAcjs.ia.call(void 0, e=>typeof e=="number"?Math.abs(e):c.length[e.kind](e),e=>_chunkUMHCZDPAcjs.fa.call(void 0, `length(${e.value})`,_chunkUMHCZDPAcjs.pa),"length"),He= exports.w =_chunkUMHCZDPAcjs.ia.call(void 0, e=>typeof e=="number"?Math.log(e):c.log[e.kind](e),e=>_chunkUMHCZDPAcjs.fa.call(void 0, `log(${e.value})`,e.dataType),"log"),Je= exports.x =_chunkUMHCZDPAcjs.ia.call(void 0, e=>typeof e=="number"?Math.log2(e):c.log2[e.kind](e),e=>_chunkUMHCZDPAcjs.fa.call(void 0, `log2(${e.value})`,e.dataType),"log2"),Qe= exports.y =_chunkUMHCZDPAcjs.ia.call(void 0, (e,n)=>typeof e=="number"?Math.max(e,n):c.max[e.kind](e,n),(e,n)=>_chunkUMHCZDPAcjs.fa.call(void 0, `max(${e.value}, ${n.value})`,e.dataType),"max","coerce"),Xe= exports.z =_chunkUMHCZDPAcjs.ia.call(void 0, (e,n)=>typeof e=="number"?Math.min(e,n):c.min[e.kind](e,n),(e,n)=>_chunkUMHCZDPAcjs.fa.call(void 0, `min(${e.value}, ${n.value})`,e.dataType),"min","coerce"),Ye= exports.A =_chunkUMHCZDPAcjs.ia.call(void 0, e=>typeof e=="number"?Math.sign(e):c.sign[e.kind](e),e=>_chunkUMHCZDPAcjs.fa.call(void 0, `sign(${e.value})`,e.dataType),"sign"),en= exports.B =_chunkUMHCZDPAcjs.ia.call(void 0, e=>typeof e=="number"?Math.sin(e):c.sin[e.kind](e),e=>_chunkUMHCZDPAcjs.fa.call(void 0, `sin(${e.value})`,e.dataType),"sin"),nn= exports.C =_chunkUMHCZDPAcjs.ia.call(void 0, e=>typeof e=="number"?Math.exp(e):c.exp[e.kind](e),e=>_chunkUMHCZDPAcjs.fa.call(void 0, `exp(${e.value})`,e.dataType),"exp"),sn= exports.D =_chunkUMHCZDPAcjs.ia.call(void 0, e=>typeof e=="number"?2**e:c.exp2[e.kind](e),e=>_chunkUMHCZDPAcjs.fa.call(void 0, `exp2(${e.value})`,e.dataType),"exp2"),tn= exports.E =_chunkUMHCZDPAcjs.ia.call(void 0, (e,n)=>{if(typeof e=="number"&&typeof n=="number")return e**n;if(typeof e=="object"&&typeof n=="object"&&"kind"in e&&"kind"in n)return c.pow[e.kind](e,n);throw new Error("Invalid arguments to pow()")},(e,n)=>_chunkUMHCZDPAcjs.fa.call(void 0, `pow(${e.value}, ${n.value})`,e.dataType),"pow"),cn= exports.F =_chunkUMHCZDPAcjs.ia.call(void 0, (e,n,s)=>{if(typeof e=="number"){if(typeof s!="number"||typeof n!="number")throw new Error("When e1 and e2 are numbers, the blend factor must be a number.");return e*(1-s)+n*s}if(typeof e=="number"||typeof n=="number")throw new Error("e1 and e2 need to both be vectors of the same kind.");return c.mix[e.kind](e,n,s)},(e,n,s)=>_chunkUMHCZDPAcjs.fa.call(void 0, `mix(${e.value}, ${n.value}, ${s.value})`,e.dataType),"mix"),an= exports.G =_chunkUMHCZDPAcjs.ia.call(void 0, (e,n)=>ie(e,me(2*ze(n,e),n)),(e,n)=>_chunkUMHCZDPAcjs.fa.call(void 0, `reflect(${e.value}, ${n.value})`,e.dataType),"reflect"),rn= exports.H =_chunkUMHCZDPAcjs.ia.call(void 0, (e,n)=>typeof e=="number"&&typeof n=="number"?Math.abs(e-n):pe(ie(e,n)),(e,n)=>_chunkUMHCZDPAcjs.fa.call(void 0, `distance(${e.value}, ${n.value})`,_chunkUMHCZDPAcjs.pa),"distance"),vn= exports.I =_chunkUMHCZDPAcjs.ia.call(void 0, e=>typeof e=="number"?-e:c.neg[e.kind](e),e=>_chunkUMHCZDPAcjs.fa.call(void 0, `-(${e.value})`,e.dataType),"neg"),xn= exports.J =_chunkUMHCZDPAcjs.ia.call(void 0, e=>typeof e=="number"?Math.sqrt(e):c.sqrt[e.kind](e),e=>_chunkUMHCZDPAcjs.fa.call(void 0, `sqrt(${e.value})`,e.dataType),"sqrt"),yn= exports.K =_chunkUMHCZDPAcjs.ia.call(void 0, e=>typeof e=="number"?Math.tanh(e):c.tanh[e.kind](e),e=>_chunkUMHCZDPAcjs.fa.call(void 0, `tanh(${e.value})`,e.dataType),"tanh");exports.a = c; exports.b = G; exports.c = de; exports.d = ke; exports.e = ie; exports.f = me; exports.g = Oe; exports.h = Le; exports.i = _e; exports.j = Ue; exports.k = We; exports.l = qe; exports.m = Ce; exports.n = Se; exports.o = De; exports.p = Ee; exports.q = je; exports.r = ze; exports.s = Pe; exports.t = Ze; exports.u = Ge; exports.v = pe; exports.w = He; exports.x = Je; exports.y = Qe; exports.z = Xe; exports.A = Ye; exports.B = en; exports.C = nn; exports.D = sn; exports.E = tn; exports.F = cn; exports.G = an; exports.H = rn; exports.I = vn; exports.J = xn; exports.K = yn;
2
+ //# sourceMappingURL=chunk-TG4A6AM3.cjs.map