typegpu 0.4.4 → 0.4.5
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.
- package/{attributes-Cfiq6vud.d.ts → attributes-B4JpvOTz.d.ts} +1 -1
- package/{attributes-B5bhZAAK.d.cts → attributes-DSOqT8yA.d.cts} +1 -1
- package/chunk-7S2KQX6O.js +4 -0
- package/chunk-7S2KQX6O.js.map +1 -0
- package/chunk-JSF3RDCP.js +2 -0
- package/chunk-JSF3RDCP.js.map +1 -0
- package/chunk-TLEBUZ6A.cjs +4 -0
- package/{chunk-7X4KDNDZ.cjs.map → chunk-TLEBUZ6A.cjs.map} +1 -1
- package/chunk-WVFPBCIE.cjs +2 -0
- package/chunk-WVFPBCIE.cjs.map +1 -0
- package/data/index.cjs +1 -1
- package/data/index.cjs.map +1 -1
- package/data/index.d.cts +10 -5
- package/data/index.d.ts +10 -5
- package/data/index.js +1 -1
- package/index.cjs +13 -11
- package/index.cjs.map +1 -1
- package/index.d.cts +10 -7
- package/index.d.ts +10 -7
- package/index.js +13 -11
- package/index.js.map +1 -1
- package/package.json +2 -2
- package/std/index.cjs +1 -1
- package/std/index.cjs.map +1 -1
- package/std/index.d.cts +20 -2
- package/std/index.d.ts +20 -2
- package/std/index.js +1 -1
- package/std/index.js.map +1 -1
- package/{wgslTypes-DgaoTc4M.d.ts → wgslTypes-VtSRoe90.d.cts} +90 -6
- package/{wgslTypes-DgaoTc4M.d.cts → wgslTypes-VtSRoe90.d.ts} +90 -6
- package/chunk-7X4KDNDZ.cjs +0 -4
- package/chunk-C6C35PDM.cjs +0 -2
- package/chunk-C6C35PDM.cjs.map +0 -1
- package/chunk-ZHXAQ2YE.js +0 -4
- package/chunk-ZHXAQ2YE.js.map +0 -1
- package/chunk-ZJMGYM7L.js +0 -2
- package/chunk-ZJMGYM7L.js.map +0 -1
package/std/index.d.cts
CHANGED
@@ -1,4 +1,6 @@
|
|
1
|
-
import {
|
1
|
+
import { bk as VecKind, J as AnyMatInstance, bl as vBaseForMat, ai as v3f, aj as v3i, ak as v3u, af as v2f, al as v4f, bm as v2h, bn as v3h, bo as v4h, bp as atomicI32, bq as atomicU32 } from '../wgslTypes-VtSRoe90.cjs';
|
2
|
+
|
3
|
+
declare function discard(): never;
|
2
4
|
|
3
5
|
type vBase = {
|
4
6
|
kind: VecKind;
|
@@ -9,6 +11,7 @@ declare function mul<T extends AnyMatInstance, TVec extends vBaseForMat<T>>(s: T
|
|
9
11
|
declare function mul<T extends AnyMatInstance, TVec extends vBaseForMat<T>>(s: TVec, v: T): TVec;
|
10
12
|
declare function mul<T extends vBase | AnyMatInstance>(s: number | T, v: T): T;
|
11
13
|
declare function abs<T extends vBase | number>(value: T): T;
|
14
|
+
declare function atan2<T extends vBase | number>(y: T, x: T): T;
|
12
15
|
/**
|
13
16
|
* @privateRemarks
|
14
17
|
* https://www.w3.org/TR/WGSL/#ceil-builtin
|
@@ -63,5 +66,20 @@ declare function pow<T extends v2f | v3f | v4f | v2h | v3h | v4h>(base: T, expon
|
|
63
66
|
declare function mix(e1: number, e2: number, e3: number): number;
|
64
67
|
declare function mix<T extends v2f | v3f | v4f | v2h | v3h | v4h>(e1: T, e2: T, e3: number): T;
|
65
68
|
declare function mix<T extends v2f | v3f | v4f | v2h | v3h | v4h>(e1: T, e2: T, e3: T): T;
|
69
|
+
declare function reflect<T extends vBase>(e1: T, e2: T): T;
|
70
|
+
|
71
|
+
type AnyAtomic = atomicI32 | atomicU32;
|
72
|
+
declare function workgroupBarrier(): void;
|
73
|
+
declare function storageBarrier(): void;
|
74
|
+
declare function textureBarrier(): void;
|
75
|
+
declare function atomicLoad<T extends AnyAtomic>(a: T): number;
|
76
|
+
declare function atomicStore<T extends AnyAtomic>(a: T, value: number): void;
|
77
|
+
declare function atomicAdd<T extends AnyAtomic>(a: T, value: number): number;
|
78
|
+
declare function atomicSub<T extends AnyAtomic>(a: T, value: number): number;
|
79
|
+
declare function atomicMax<T extends AnyAtomic>(a: T, value: number): number;
|
80
|
+
declare function atomicMin<T extends AnyAtomic>(a: T, value: number): number;
|
81
|
+
declare function atomicAnd<T extends AnyAtomic>(a: T, value: number): number;
|
82
|
+
declare function atomicOr<T extends AnyAtomic>(a: T, value: number): number;
|
83
|
+
declare function atomicXor<T extends AnyAtomic>(a: T, value: number): number;
|
66
84
|
|
67
|
-
export { abs, add, ceil, clamp, cos, cross, dot, exp, floor, fract, length, max, min, mix, mul, normalize, pow, sin, sub };
|
85
|
+
export { abs, add, atan2, atomicAdd, atomicAnd, atomicLoad, atomicMax, atomicMin, atomicOr, atomicStore, atomicSub, atomicXor, ceil, clamp, cos, cross, discard, dot, exp, floor, fract, length, max, min, mix, mul, normalize, pow, reflect, sin, storageBarrier, sub, textureBarrier, workgroupBarrier };
|
package/std/index.d.ts
CHANGED
@@ -1,4 +1,6 @@
|
|
1
|
-
import {
|
1
|
+
import { bk as VecKind, J as AnyMatInstance, bl as vBaseForMat, ai as v3f, aj as v3i, ak as v3u, af as v2f, al as v4f, bm as v2h, bn as v3h, bo as v4h, bp as atomicI32, bq as atomicU32 } from '../wgslTypes-VtSRoe90.js';
|
2
|
+
|
3
|
+
declare function discard(): never;
|
2
4
|
|
3
5
|
type vBase = {
|
4
6
|
kind: VecKind;
|
@@ -9,6 +11,7 @@ declare function mul<T extends AnyMatInstance, TVec extends vBaseForMat<T>>(s: T
|
|
9
11
|
declare function mul<T extends AnyMatInstance, TVec extends vBaseForMat<T>>(s: TVec, v: T): TVec;
|
10
12
|
declare function mul<T extends vBase | AnyMatInstance>(s: number | T, v: T): T;
|
11
13
|
declare function abs<T extends vBase | number>(value: T): T;
|
14
|
+
declare function atan2<T extends vBase | number>(y: T, x: T): T;
|
12
15
|
/**
|
13
16
|
* @privateRemarks
|
14
17
|
* https://www.w3.org/TR/WGSL/#ceil-builtin
|
@@ -63,5 +66,20 @@ declare function pow<T extends v2f | v3f | v4f | v2h | v3h | v4h>(base: T, expon
|
|
63
66
|
declare function mix(e1: number, e2: number, e3: number): number;
|
64
67
|
declare function mix<T extends v2f | v3f | v4f | v2h | v3h | v4h>(e1: T, e2: T, e3: number): T;
|
65
68
|
declare function mix<T extends v2f | v3f | v4f | v2h | v3h | v4h>(e1: T, e2: T, e3: T): T;
|
69
|
+
declare function reflect<T extends vBase>(e1: T, e2: T): T;
|
70
|
+
|
71
|
+
type AnyAtomic = atomicI32 | atomicU32;
|
72
|
+
declare function workgroupBarrier(): void;
|
73
|
+
declare function storageBarrier(): void;
|
74
|
+
declare function textureBarrier(): void;
|
75
|
+
declare function atomicLoad<T extends AnyAtomic>(a: T): number;
|
76
|
+
declare function atomicStore<T extends AnyAtomic>(a: T, value: number): void;
|
77
|
+
declare function atomicAdd<T extends AnyAtomic>(a: T, value: number): number;
|
78
|
+
declare function atomicSub<T extends AnyAtomic>(a: T, value: number): number;
|
79
|
+
declare function atomicMax<T extends AnyAtomic>(a: T, value: number): number;
|
80
|
+
declare function atomicMin<T extends AnyAtomic>(a: T, value: number): number;
|
81
|
+
declare function atomicAnd<T extends AnyAtomic>(a: T, value: number): number;
|
82
|
+
declare function atomicOr<T extends AnyAtomic>(a: T, value: number): number;
|
83
|
+
declare function atomicXor<T extends AnyAtomic>(a: T, value: number): number;
|
66
84
|
|
67
|
-
export { abs, add, ceil, clamp, cos, cross, dot, exp, floor, fract, length, max, min, mix, mul, normalize, pow, sin, sub };
|
85
|
+
export { abs, add, atan2, atomicAdd, atomicAnd, atomicLoad, atomicMax, atomicMin, atomicOr, atomicStore, atomicSub, atomicXor, ceil, clamp, cos, cross, discard, dot, exp, floor, fract, length, max, min, mix, mul, normalize, pow, reflect, sin, storageBarrier, sub, textureBarrier, workgroupBarrier };
|
package/std/index.js
CHANGED
@@ -1,2 +1,2 @@
|
|
1
|
-
import{A as V,B as $,m as w,n as r,o as f,p as i,q as h,r as y,s as v,t as a,u as g,v as c,w as u,x as m,y as o,z as B}from"../chunk-ZHXAQ2YE.js";var z=s=>Math.sqrt(s.x**2+s.y**2),M=s=>Math.sqrt(s.x**2+s.y**2+s.z**2),T=s=>Math.sqrt(s.x**2+s.y**2+s.z**2+s.w**2),d=(s,t)=>s.x*t.x+s.y*t.y,p=(s,t)=>s.x*t.x+s.y*t.y+s.z*t.z,k=(s,t)=>s.x*t.x+s.y*t.y+s.z*t.z+s.w*t.w,e=(s,t,n)=>Math.min(Math.max(t,s),n),l={abs:{vec2f:s=>r(Math.abs(s.x),Math.abs(s.y)),vec2h:s=>f(Math.abs(s.x),Math.abs(s.y)),vec2i:s=>i(Math.abs(s.x),Math.abs(s.y)),vec2u:s=>h(Math.abs(s.x),Math.abs(s.y)),vec3f:s=>y(Math.abs(s.x),Math.abs(s.y),Math.abs(s.z)),vec3h:s=>v(Math.abs(s.x),Math.abs(s.y),Math.abs(s.z)),vec3i:s=>a(Math.abs(s.x),Math.abs(s.y),Math.abs(s.z)),vec3u:s=>g(Math.abs(s.x),Math.abs(s.y),Math.abs(s.z)),vec4f:s=>c(Math.abs(s.x),Math.abs(s.y),Math.abs(s.z),Math.abs(s.w)),vec4h:s=>u(Math.abs(s.x),Math.abs(s.y),Math.abs(s.z),Math.abs(s.w)),vec4i:s=>m(Math.abs(s.x),Math.abs(s.y),Math.abs(s.z),Math.abs(s.w)),vec4u:s=>o(Math.abs(s.x),Math.abs(s.y),Math.abs(s.z),Math.abs(s.w))},ceil:{vec2f:s=>r(Math.ceil(s.x),Math.ceil(s.y)),vec2h:s=>f(Math.ceil(s.x),Math.ceil(s.y)),vec2i:s=>i(Math.ceil(s.x),Math.ceil(s.y)),vec2u:s=>h(Math.ceil(s.x),Math.ceil(s.y)),vec3f:s=>y(Math.ceil(s.x),Math.ceil(s.y),Math.ceil(s.z)),vec3h:s=>v(Math.ceil(s.x),Math.ceil(s.y),Math.ceil(s.z)),vec3i:s=>a(Math.ceil(s.x),Math.ceil(s.y),Math.ceil(s.z)),vec3u:s=>g(Math.ceil(s.x),Math.ceil(s.y),Math.ceil(s.z)),vec4f:s=>c(Math.ceil(s.x),Math.ceil(s.y),Math.ceil(s.z),Math.ceil(s.w)),vec4h:s=>u(Math.ceil(s.x),Math.ceil(s.y),Math.ceil(s.z),Math.ceil(s.w)),vec4i:s=>m(Math.ceil(s.x),Math.ceil(s.y),Math.ceil(s.z),Math.ceil(s.w)),vec4u:s=>o(Math.ceil(s.x),Math.ceil(s.y),Math.ceil(s.z),Math.ceil(s.w))},clamp:{vec2f:(s,t,n)=>r(e(s.x,t.x,n.x),e(s.y,t.y,n.y)),vec2h:(s,t,n)=>f(e(s.x,t.x,n.x),e(s.y,t.y,n.y)),vec2i:(s,t,n)=>i(e(s.x,t.x,n.x),e(s.y,t.y,n.y)),vec2u:(s,t,n)=>h(e(s.x,t.x,n.x),e(s.y,t.y,n.y)),vec3f:(s,t,n)=>y(e(s.x,t.x,n.x),e(s.y,t.y,n.y),e(s.z,t.z,n.z)),vec3h:(s,t,n)=>v(e(s.x,t.x,n.x),e(s.y,t.y,n.y),e(s.z,t.z,n.z)),vec3i:(s,t,n)=>a(e(s.x,t.x,n.x),e(s.y,t.y,n.y),e(s.z,t.z,n.z)),vec3u:(s,t,n)=>g(e(s.x,t.x,n.x),e(s.y,t.y,n.y),e(s.z,t.z,n.z)),vec4f:(s,t,n)=>c(e(s.x,t.x,n.x),e(s.y,t.y,n.y),e(s.z,t.z,n.z),e(s.w,t.w,n.w)),vec4h:(s,t,n)=>u(e(s.x,t.x,n.x),e(s.y,t.y,n.y),e(s.z,t.z,n.z),e(s.w,t.w,n.w)),vec4i:(s,t,n)=>m(e(s.x,t.x,n.x),e(s.y,t.y,n.y),e(s.z,t.z,n.z),e(s.w,t.w,n.w)),vec4u:(s,t,n)=>o(e(s.x,t.x,n.x),e(s.y,t.y,n.y),e(s.z,t.z,n.z),e(s.w,t.w,n.w))},length:{vec2f:z,vec2h:z,vec2i:z,vec2u:z,vec3f:M,vec3h:M,vec3i:M,vec3u:M,vec4f:T,vec4h:T,vec4i:T,vec4u:T},add:{vec2f:(s,t)=>r(s.x+t.x,s.y+t.y),vec2h:(s,t)=>f(s.x+t.x,s.y+t.y),vec2i:(s,t)=>i(s.x+t.x,s.y+t.y),vec2u:(s,t)=>h(s.x+t.x,s.y+t.y),vec3f:(s,t)=>y(s.x+t.x,s.y+t.y,s.z+t.z),vec3h:(s,t)=>v(s.x+t.x,s.y+t.y,s.z+t.z),vec3i:(s,t)=>a(s.x+t.x,s.y+t.y,s.z+t.z),vec3u:(s,t)=>g(s.x+t.x,s.y+t.y,s.z+t.z),vec4f:(s,t)=>c(s.x+t.x,s.y+t.y,s.z+t.z,s.w+t.w),vec4h:(s,t)=>u(s.x+t.x,s.y+t.y,s.z+t.z,s.w+t.w),vec4i:(s,t)=>m(s.x+t.x,s.y+t.y,s.z+t.z,s.w+t.w),vec4u:(s,t)=>o(s.x+t.x,s.y+t.y,s.z+t.z,s.w+t.w)},sub:{vec2f:(s,t)=>r(s.x-t.x,s.y-t.y),vec2h:(s,t)=>f(s.x-t.x,s.y-t.y),vec2i:(s,t)=>i(s.x-t.x,s.y-t.y),vec2u:(s,t)=>h(s.x-t.x,s.y-t.y),vec3f:(s,t)=>y(s.x-t.x,s.y-t.y,s.z-t.z),vec3h:(s,t)=>v(s.x-t.x,s.y-t.y,s.z-t.z),vec3i:(s,t)=>a(s.x-t.x,s.y-t.y,s.z-t.z),vec3u:(s,t)=>g(s.x-t.x,s.y-t.y,s.z-t.z),vec4f:(s,t)=>c(s.x-t.x,s.y-t.y,s.z-t.z,s.w-t.w),vec4h:(s,t)=>u(s.x-t.x,s.y-t.y,s.z-t.z,s.w-t.w),vec4i:(s,t)=>m(s.x-t.x,s.y-t.y,s.z-t.z,s.w-t.w),vec4u:(s,t)=>o(s.x-t.x,s.y-t.y,s.z-t.z,s.w-t.w)},mulSxV:{vec2f:(s,t)=>r(s*t.x,s*t.y),vec2h:(s,t)=>f(s*t.x,s*t.y),vec2i:(s,t)=>i(s*t.x,s*t.y),vec2u:(s,t)=>h(s*t.x,s*t.y),vec3f:(s,t)=>y(s*t.x,s*t.y,s*t.z),vec3h:(s,t)=>v(s*t.x,s*t.y,s*t.z),vec3i:(s,t)=>a(s*t.x,s*t.y,s*t.z),vec3u:(s,t)=>g(s*t.x,s*t.y,s*t.z),vec4f:(s,t)=>c(s*t.x,s*t.y,s*t.z,s*t.w),vec4h:(s,t)=>u(s*t.x,s*t.y,s*t.z,s*t.w),vec4i:(s,t)=>m(s*t.x,s*t.y,s*t.z,s*t.w),vec4u:(s,t)=>o(s*t.x,s*t.y,s*t.z,s*t.w),mat2x2f:(s,t)=>{let n=t.columns;return B(s*n[0].x,s*n[0].y,s*n[1].x,s*n[1].y)},mat3x3f:(s,t)=>{let n=t.columns;return V(s*n[0].x,s*n[0].y,s*n[0].z,s*n[1].x,s*n[1].y,s*n[1].z,s*n[2].x,s*n[2].y,s*n[2].z)},mat4x4f:(s,t)=>{let n=t.columns;return $(s*n[0].x,s*n[0].y,s*n[0].z,s*n[0].w,s*n[1].x,s*n[1].y,s*n[1].z,s*n[1].w,s*n[2].x,s*n[2].y,s*n[2].z,s*n[2].w,s*n[3].x,s*n[3].y,s*n[3].z,s*n[3].w)}},mulVxV:{vec2f:(s,t)=>r(s.x*t.x,s.y*t.y),vec2h:(s,t)=>f(s.x*t.x,s.y*t.y),vec2i:(s,t)=>i(s.x*t.x,s.y*t.y),vec2u:(s,t)=>h(s.x*t.x,s.y*t.y),vec3f:(s,t)=>y(s.x*t.x,s.y*t.y,s.z*t.z),vec3h:(s,t)=>v(s.x*t.x,s.y*t.y,s.z*t.z),vec3i:(s,t)=>a(s.x*t.x,s.y*t.y,s.z*t.z),vec3u:(s,t)=>g(s.x*t.x,s.y*t.y,s.z*t.z),vec4f:(s,t)=>c(s.x*t.x,s.y*t.y,s.z*t.z,s.w*t.w),vec4h:(s,t)=>u(s.x*t.x,s.y*t.y,s.z*t.z,s.w*t.w),vec4i:(s,t)=>m(s.x*t.x,s.y*t.y,s.z*t.z,s.w*t.w),vec4u:(s,t)=>o(s.x*t.x,s.y*t.y,s.z*t.z,s.w*t.w),mat2x2f:(s,t)=>{let n=s.columns,x=t.columns;return B(n[0].x*x[0].x+n[1].x*x[0].y,n[0].y*x[0].x+n[1].y*x[0].y,n[0].x*x[1].x+n[1].x*x[1].y,n[0].y*x[1].x+n[1].y*x[1].y)},mat3x3f:(s,t)=>{let n=s.columns,x=t.columns;return V(n[0].x*x[0].x+n[1].x*x[0].y+n[2].x*x[0].z,n[0].y*x[0].x+n[1].y*x[0].y+n[2].y*x[0].z,n[0].z*x[0].x+n[1].z*x[0].y+n[2].z*x[0].z,n[0].x*x[1].x+n[1].x*x[1].y+n[2].x*x[1].z,n[0].y*x[1].x+n[1].y*x[1].y+n[2].y*x[1].z,n[0].z*x[1].x+n[1].z*x[1].y+n[2].z*x[1].z,n[0].x*x[2].x+n[1].x*x[2].y+n[2].x*x[2].z,n[0].y*x[2].x+n[1].y*x[2].y+n[2].y*x[2].z,n[0].z*x[2].x+n[1].z*x[2].y+n[2].z*x[2].z)},mat4x4f:(s,t)=>{let n=s.columns,x=t.columns;return $(n[0].x*x[0].x+n[1].x*x[0].y+n[2].x*x[0].z+n[3].x*x[0].w,n[0].y*x[0].x+n[1].y*x[0].y+n[2].y*x[0].z+n[3].y*x[0].w,n[0].z*x[0].x+n[1].z*x[0].y+n[2].z*x[0].z+n[3].z*x[0].w,n[0].w*x[0].x+n[1].w*x[0].y+n[2].w*x[0].z+n[3].w*x[0].w,n[0].x*x[1].x+n[1].x*x[1].y+n[2].x*x[1].z+n[3].x*x[1].w,n[0].y*x[1].x+n[1].y*x[1].y+n[2].y*x[1].z+n[3].y*x[1].w,n[0].z*x[1].x+n[1].z*x[1].y+n[2].z*x[1].z+n[3].z*x[1].w,n[0].w*x[1].x+n[1].w*x[1].y+n[2].w*x[1].z+n[3].w*x[1].w,n[0].x*x[2].x+n[1].x*x[2].y+n[2].x*x[2].z+n[3].x*x[2].w,n[0].y*x[2].x+n[1].y*x[2].y+n[2].y*x[2].z+n[3].y*x[2].w,n[0].z*x[2].x+n[1].z*x[2].y+n[2].z*x[2].z+n[3].z*x[2].w,n[0].w*x[2].x+n[1].w*x[2].y+n[2].w*x[2].z+n[3].w*x[2].w,n[0].x*x[3].x+n[1].x*x[3].y+n[2].x*x[3].z+n[3].x*x[3].w,n[0].y*x[3].x+n[1].y*x[3].y+n[2].y*x[3].z+n[3].y*x[3].w,n[0].z*x[3].x+n[1].z*x[3].y+n[2].z*x[3].z+n[3].z*x[3].w,n[0].w*x[3].x+n[1].w*x[3].y+n[2].w*x[3].z+n[3].w*x[3].w)}},mulMxV:{mat2x2f:(s,t)=>{let n=s.columns;return r(n[0].x*t.x+n[1].x*t.y,n[0].y*t.x+n[1].y*t.y)},mat3x3f:(s,t)=>{let n=s.columns;return y(n[0].x*t.x+n[1].x*t.y+n[2].x*t.z,n[0].y*t.x+n[1].y*t.y+n[2].y*t.z,n[0].z*t.x+n[1].z*t.y+n[2].z*t.z)},mat4x4f:(s,t)=>{let n=s.columns;return c(n[0].x*t.x+n[1].x*t.y+n[2].x*t.z+n[3].x*t.w,n[0].y*t.x+n[1].y*t.y+n[2].y*t.z+n[3].y*t.w,n[0].z*t.x+n[1].z*t.y+n[2].z*t.z+n[3].z*t.w,n[0].w*t.x+n[1].w*t.y+n[2].w*t.z+n[3].w*t.w)}},mulVxM:{mat2x2f:(s,t)=>{let n=t.columns;return r(s.x*n[0].x+s.y*n[0].y,s.x*n[1].x+s.y*n[1].y)},mat3x3f:(s,t)=>{let n=t.columns;return y(s.x*n[0].x+s.y*n[0].y+s.z*n[0].z,s.x*n[1].x+s.y*n[1].y+s.z*n[1].z,s.x*n[2].x+s.y*n[2].y+s.z*n[2].z)},mat4x4f:(s,t)=>{let n=t.columns;return c(s.x*n[0].x+s.y*n[0].y+s.z*n[0].z+s.w*n[0].w,s.x*n[1].x+s.y*n[1].y+s.z*n[1].z+s.w*n[1].w,s.x*n[2].x+s.y*n[2].y+s.z*n[2].z+s.w*n[2].w,s.x*n[3].x+s.y*n[3].y+s.z*n[3].z+s.w*n[3].w)}},dot:{vec2f:d,vec2h:d,vec2i:d,vec2u:d,vec3f:p,vec3h:p,vec3i:p,vec3u:p,vec4f:k,vec4h:k,vec4i:k,vec4u:k},normalize:{vec2f:s=>{let t=z(s);return r(s.x/t,s.y/t)},vec2h:s=>{let t=z(s);return f(s.x/t,s.y/t)},vec2i:s=>{let t=z(s);return i(s.x/t,s.y/t)},vec2u:s=>{let t=z(s);return h(s.x/t,s.y/t)},vec3f:s=>{let t=M(s);return y(s.x/t,s.y/t,s.z/t)},vec3h:s=>{let t=M(s);return v(s.x/t,s.y/t,s.z/t)},vec3i:s=>{let t=M(s);return a(s.x/t,s.y/t,s.z/t)},vec3u:s=>{let t=M(s);return g(s.x/t,s.y/t,s.z/t)},vec4f:s=>{let t=T(s);return c(s.x/t,s.y/t,s.z/t,s.w/t)},vec4h:s=>{let t=T(s);return u(s.x/t,s.y/t,s.z/t,s.w/t)},vec4i:s=>{let t=T(s);return m(s.x/t,s.y/t,s.z/t,s.w/t)},vec4u:s=>{let t=T(s);return o(s.x/t,s.y/t,s.z/t,s.w/t)}},cross:{vec3f:(s,t)=>y(s.y*t.z-s.z*t.y,s.z*t.x-s.x*t.z,s.x*t.y-s.y*t.x),vec3h:(s,t)=>v(s.y*t.z-s.z*t.y,s.z*t.x-s.x*t.z,s.x*t.y-s.y*t.x),vec3i:(s,t)=>a(s.y*t.z-s.z*t.y,s.z*t.x-s.x*t.z,s.x*t.y-s.y*t.x),vec3u:(s,t)=>g(s.y*t.z-s.z*t.y,s.z*t.x-s.x*t.z,s.x*t.y-s.y*t.x)},floor:{vec2f:s=>r(Math.floor(s.x),Math.floor(s.y)),vec2h:s=>f(Math.floor(s.x),Math.floor(s.y)),vec2i:s=>i(Math.floor(s.x),Math.floor(s.y)),vec2u:s=>h(Math.floor(s.x),Math.floor(s.y)),vec3f:s=>y(Math.floor(s.x),Math.floor(s.y),Math.floor(s.z)),vec3h:s=>v(Math.floor(s.x),Math.floor(s.y),Math.floor(s.z)),vec3i:s=>a(Math.floor(s.x),Math.floor(s.y),Math.floor(s.z)),vec3u:s=>g(Math.floor(s.x),Math.floor(s.y),Math.floor(s.z)),vec4f:s=>c(Math.floor(s.x),Math.floor(s.y),Math.floor(s.z),Math.floor(s.w)),vec4h:s=>u(Math.floor(s.x),Math.floor(s.y),Math.floor(s.z),Math.floor(s.w)),vec4i:s=>m(Math.floor(s.x),Math.floor(s.y),Math.floor(s.z),Math.floor(s.w)),vec4u:s=>o(Math.floor(s.x),Math.floor(s.y),Math.floor(s.z),Math.floor(s.w))},max:{vec2f:(s,t)=>r(Math.max(s.x,t.x),Math.max(s.y,t.y)),vec2h:(s,t)=>f(Math.max(s.x,t.x),Math.max(s.y,t.y)),vec2i:(s,t)=>i(Math.max(s.x,t.x),Math.max(s.y,t.y)),vec2u:(s,t)=>h(Math.max(s.x,t.x),Math.max(s.y,t.y)),vec3f:(s,t)=>y(Math.max(s.x,t.x),Math.max(s.y,t.y),Math.max(s.z,t.z)),vec3h:(s,t)=>v(Math.max(s.x,t.x),Math.max(s.y,t.y),Math.max(s.z,t.z)),vec3i:(s,t)=>a(Math.max(s.x,t.x),Math.max(s.y,t.y),Math.max(s.z,t.z)),vec3u:(s,t)=>g(Math.max(s.x,t.x),Math.max(s.y,t.y),Math.max(s.z,t.z)),vec4f:(s,t)=>c(Math.max(s.x,t.x),Math.max(s.y,t.y),Math.max(s.z,t.z),Math.max(s.w,t.w)),vec4h:(s,t)=>u(Math.max(s.x,t.x),Math.max(s.y,t.y),Math.max(s.z,t.z),Math.max(s.w,t.w)),vec4i:(s,t)=>m(Math.max(s.x,t.x),Math.max(s.y,t.y),Math.max(s.z,t.z),Math.max(s.w,t.w)),vec4u:(s,t)=>o(Math.max(s.x,t.x),Math.max(s.y,t.y),Math.max(s.z,t.z),Math.max(s.w,t.w))},min:{vec2f:(s,t)=>r(Math.min(s.x,t.x),Math.min(s.y,t.y)),vec2h:(s,t)=>f(Math.min(s.x,t.x),Math.min(s.y,t.y)),vec2i:(s,t)=>i(Math.min(s.x,t.x),Math.min(s.y,t.y)),vec2u:(s,t)=>h(Math.min(s.x,t.x),Math.min(s.y,t.y)),vec3f:(s,t)=>y(Math.min(s.x,t.x),Math.min(s.y,t.y),Math.min(s.z,t.z)),vec3h:(s,t)=>v(Math.min(s.x,t.x),Math.min(s.y,t.y),Math.min(s.z,t.z)),vec3i:(s,t)=>a(Math.min(s.x,t.x),Math.min(s.y,t.y),Math.min(s.z,t.z)),vec3u:(s,t)=>g(Math.min(s.x,t.x),Math.min(s.y,t.y),Math.min(s.z,t.z)),vec4f:(s,t)=>c(Math.min(s.x,t.x),Math.min(s.y,t.y),Math.min(s.z,t.z),Math.min(s.w,t.w)),vec4h:(s,t)=>u(Math.min(s.x,t.x),Math.min(s.y,t.y),Math.min(s.z,t.z),Math.min(s.w,t.w)),vec4i:(s,t)=>m(Math.min(s.x,t.x),Math.min(s.y,t.y),Math.min(s.z,t.z),Math.min(s.w,t.w)),vec4u:(s,t)=>o(Math.min(s.x,t.x),Math.min(s.y,t.y),Math.min(s.z,t.z),Math.min(s.w,t.w))},pow:{vec2f:(s,t)=>r(s.x**t.x,s.y**t.y),vec2h:(s,t)=>f(s.x**t.x,s.y**t.y),vec3f:(s,t)=>y(s.x**t.x,s.y**t.y,s.z**t.z),vec3h:(s,t)=>v(s.x**t.x,s.y**t.y,s.z**t.z),vec4f:(s,t)=>c(s.x**t.x,s.y**t.y,s.z**t.z,s.w**t.w),vec4h:(s,t)=>u(s.x**t.x,s.y**t.y,s.z**t.z,s.w**t.w)},mix:{vec2f:(s,t,n)=>typeof n=="number"?r(s.x*(1-n)+t.x*n,s.y*(1-n)+t.y*n):r(s.x*(1-n.x)+t.x*n.x,s.y*(1-n.y)+t.y*n.y),vec2h:(s,t,n)=>typeof n=="number"?f(s.x*(1-n)+t.x*n,s.y*(1-n)+t.y*n):f(s.x*(1-n.x)+t.x*n.x,s.y*(1-n.y)+t.y*n.y),vec3f:(s,t,n)=>typeof n=="number"?y(s.x*(1-n)+t.x*n,s.y*(1-n)+t.y*n,s.z*(1-n)+t.z*n):y(s.x*(1-n.x)+t.x*n.x,s.y*(1-n.y)+t.y*n.y,s.z*(1-n.z)+t.z*n.z),vec3h:(s,t,n)=>typeof n=="number"?v(s.x*(1-n)+t.x*n,s.y*(1-n)+t.y*n,s.z*(1-n)+t.z*n):v(s.x*(1-n.x)+t.x*n.x,s.y*(1-n.y)+t.y*n.y,s.z*(1-n.z)+t.z*n.z),vec4f:(s,t,n)=>typeof n=="number"?c(s.x*(1-n)+t.x*n,s.y*(1-n)+t.y*n,s.z*(1-n)+t.z*n,s.w*(1-n)+t.w*n):c(s.x*(1-n.x)+t.x*n.x,s.y*(1-n.y)+t.y*n.y,s.z*(1-n.z)+t.z*n.z,s.w*(1-n.w)+t.w*n.w),vec4h:(s,t,n)=>typeof n=="number"?u(s.x*(1-n)+t.x*n,s.y*(1-n)+t.y*n,s.z*(1-n)+t.z*n,s.w*(1-n)+t.w*n):u(s.x*(1-n.x)+t.x*n.x,s.y*(1-n.y)+t.y*n.y,s.z*(1-n.z)+t.z*n.z,s.w*(1-n.w)+t.w*n.w)}};function K(s,t){return w()?`(${s} + ${t})`:l.add[s.kind](s,t)}function I(s,t){return w()?`(${s} - ${t})`:l.sub[s.kind](s,t)}function A(s,t){if(w())return`(${s} * ${t})`;if(typeof s=="number")return l.mulSxV[t.kind](s,t);if(typeof s=="object"&&typeof t=="object"&&"kind"in s&&"kind"in t){let n=!s.kind.startsWith("mat"),x=!t.kind.startsWith("mat");if(!n&&x)return l.mulMxV[s.kind](s,t);if(n&&!x)return l.mulVxM[t.kind](s,t)}return l.mulVxV[t.kind](s,t)}function R(s){return w()?`abs(${s})`:typeof s=="number"?Math.abs(s):l.abs[s.kind](s)}function _(s){return w()?`ceil(${s})`:typeof s=="number"?Math.ceil(s):l.ceil[s.kind](s)}function F(s,t,n){return w()?`clamp(${s}, ${t}, ${n})`:typeof s=="number"?Math.min(Math.max(t,s),n):l.clamp[s.kind](s,t,n)}function j(s){return w()?`cos(${s})`:Math.cos(s)}function q(s,t){return w()?`cross(${s}, ${t})`:l.cross[s.kind](s,t)}function E(s,t){return w()?`dot(${s}, ${t})`:l.dot[s.kind](s,t)}function W(s){return w()?`normalize(${s})`:l.normalize[s.kind](s)}function O(s){return w()?`floor(${s})`:typeof s=="number"?Math.floor(s):l.floor[s.kind](s)}function S(s){return w()?`fract(${s})`:s-Math.floor(s)}function G(s){return w()?`length(${s})`:typeof s=="number"?Math.abs(s):l.length[s.kind](s)}function P(s,t){return w()?`max(${s}, ${t})`:typeof s=="number"?Math.max(s,t):l.max[s.kind](s,t)}function U(s,t){return w()?`min(${s}, ${t})`:typeof s=="number"?Math.min(s,t):l.min[s.kind](s,t)}function C(s){return w()?`sin(${s})`:Math.sin(s)}function D(s){return w()?`exp(${s})`:Math.exp(s)}function H(s,t){if(w())return`pow(${s}, ${t})`;if(typeof s=="number"&&typeof t=="number")return s**t;if(typeof s=="object"&&typeof t=="object"&&"kind"in s&&"kind"in t)return l.pow[s.kind](s,t);throw new Error("Invalid arguments to pow()")}function J(s,t,n){if(w())return`mix(${s}, ${t}, ${n})`;if(typeof s=="number"){if(typeof n!="number"||typeof t!="number")throw new Error("When e1 and e2 are numbers, the blend factor must be a number.");return s*(1-n)+t*n}if(typeof s=="number"||typeof t=="number")throw new Error("e1 and e2 need to both be vectors of the same kind.");return l.mix[s.kind](s,t,n)}export{R as abs,K as add,_ as ceil,F as clamp,j as cos,q as cross,E as dot,D as exp,O as floor,S as fract,G as length,P as max,U as min,J as mix,A as mul,W as normalize,H as pow,C as sin,I as sub};
|
1
|
+
import{A as g,B as z,C as k,D as A,E as $,p as s,q as o,r as v,s as l,t as m,u as w,v as y,w as f,x as a,y as u,z as i}from"../chunk-7S2KQX6O.js";function en(){if(!s())throw new Error("discard() can only be used on the GPU.");return"discard;"}var d=n=>Math.sqrt(n.x**2+n.y**2),T=n=>Math.sqrt(n.x**2+n.y**2+n.z**2),h=n=>Math.sqrt(n.x**2+n.y**2+n.z**2+n.w**2),M=(n,e)=>n.x*e.x+n.y*e.y,p=(n,e)=>n.x*e.x+n.y*e.y+n.z*e.z,B=(n,e)=>n.x*e.x+n.y*e.y+n.z*e.z+n.w*e.w,c=(n,e,t)=>Math.min(Math.max(e,n),t),b=n=>e=>o(n(e.x),n(e.y)),V=n=>e=>v(n(e.x),n(e.y)),O=n=>e=>l(n(e.x),n(e.y)),U=n=>e=>m(n(e.x),n(e.y)),I=n=>e=>w(n(e.x),n(e.y),n(e.z)),K=n=>e=>y(n(e.x),n(e.y),n(e.z)),R=n=>e=>f(n(e.x),n(e.y),n(e.z)),G=n=>e=>a(n(e.x),n(e.y),n(e.z)),P=n=>e=>u(n(e.x),n(e.y),n(e.z),n(e.w)),W=n=>e=>i(n(e.x),n(e.y),n(e.z),n(e.w)),_=n=>e=>g(n(e.x),n(e.y),n(e.z),n(e.w)),E=n=>e=>z(n(e.x),n(e.y),n(e.z),n(e.w)),C=n=>(e,t)=>o(n(e.x,t.x),n(e.y,t.y)),F=n=>(e,t)=>v(n(e.x,t.x),n(e.y,t.y)),S=n=>(e,t)=>l(n(e.x,t.x),n(e.y,t.y)),j=n=>(e,t)=>m(n(e.x,t.x),n(e.y,t.y)),q=n=>(e,t)=>w(n(e.x,t.x),n(e.y,t.y),n(e.z,t.z)),L=n=>(e,t)=>y(n(e.x,t.x),n(e.y,t.y),n(e.z,t.z)),X=n=>(e,t)=>f(n(e.x,t.x),n(e.y,t.y),n(e.z,t.z)),D=n=>(e,t)=>a(n(e.x,t.x),n(e.y,t.y),n(e.z,t.z)),H=n=>(e,t)=>u(n(e.x,t.x),n(e.y,t.y),n(e.z,t.z),n(e.w,t.w)),J=n=>(e,t)=>i(n(e.x,t.x),n(e.y,t.y),n(e.z,t.z),n(e.w,t.w)),N=n=>(e,t)=>g(n(e.x,t.x),n(e.y,t.y),n(e.z,t.z),n(e.w,t.w)),Q=n=>(e,t)=>z(n(e.x,t.x),n(e.y,t.y),n(e.z,t.z),n(e.w,t.w)),x={abs:{vec2f:b(Math.abs),vec2h:V(Math.abs),vec2i:O(Math.abs),vec2u:U(Math.abs),vec3f:I(Math.abs),vec3h:K(Math.abs),vec3i:R(Math.abs),vec3u:G(Math.abs),vec4f:P(Math.abs),vec4h:W(Math.abs),vec4i:_(Math.abs),vec4u:E(Math.abs)},atan2:{vec2f:C(Math.atan2),vec2h:F(Math.atan2),vec2i:S(Math.atan2),vec2u:j(Math.atan2),vec3f:q(Math.atan2),vec3h:L(Math.atan2),vec3i:X(Math.atan2),vec3u:D(Math.atan2),vec4f:H(Math.atan2),vec4h:J(Math.atan2),vec4i:N(Math.atan2),vec4u:Q(Math.atan2)},ceil:{vec2f:b(Math.ceil),vec2h:V(Math.ceil),vec2i:O(Math.ceil),vec2u:U(Math.ceil),vec3f:I(Math.ceil),vec3h:K(Math.ceil),vec3i:R(Math.ceil),vec3u:G(Math.ceil),vec4f:P(Math.ceil),vec4h:W(Math.ceil),vec4i:_(Math.ceil),vec4u:E(Math.ceil)},clamp:{vec2f:(n,e,t)=>o(c(n.x,e.x,t.x),c(n.y,e.y,t.y)),vec2h:(n,e,t)=>v(c(n.x,e.x,t.x),c(n.y,e.y,t.y)),vec2i:(n,e,t)=>l(c(n.x,e.x,t.x),c(n.y,e.y,t.y)),vec2u:(n,e,t)=>m(c(n.x,e.x,t.x),c(n.y,e.y,t.y)),vec3f:(n,e,t)=>w(c(n.x,e.x,t.x),c(n.y,e.y,t.y),c(n.z,e.z,t.z)),vec3h:(n,e,t)=>y(c(n.x,e.x,t.x),c(n.y,e.y,t.y),c(n.z,e.z,t.z)),vec3i:(n,e,t)=>f(c(n.x,e.x,t.x),c(n.y,e.y,t.y),c(n.z,e.z,t.z)),vec3u:(n,e,t)=>a(c(n.x,e.x,t.x),c(n.y,e.y,t.y),c(n.z,e.z,t.z)),vec4f:(n,e,t)=>u(c(n.x,e.x,t.x),c(n.y,e.y,t.y),c(n.z,e.z,t.z),c(n.w,e.w,t.w)),vec4h:(n,e,t)=>i(c(n.x,e.x,t.x),c(n.y,e.y,t.y),c(n.z,e.z,t.z),c(n.w,e.w,t.w)),vec4i:(n,e,t)=>g(c(n.x,e.x,t.x),c(n.y,e.y,t.y),c(n.z,e.z,t.z),c(n.w,e.w,t.w)),vec4u:(n,e,t)=>z(c(n.x,e.x,t.x),c(n.y,e.y,t.y),c(n.z,e.z,t.z),c(n.w,e.w,t.w))},length:{vec2f:d,vec2h:d,vec2i:d,vec2u:d,vec3f:T,vec3h:T,vec3i:T,vec3u:T,vec4f:h,vec4h:h,vec4i:h,vec4u:h},add:{vec2f:(n,e)=>o(n.x+e.x,n.y+e.y),vec2h:(n,e)=>v(n.x+e.x,n.y+e.y),vec2i:(n,e)=>l(n.x+e.x,n.y+e.y),vec2u:(n,e)=>m(n.x+e.x,n.y+e.y),vec3f:(n,e)=>w(n.x+e.x,n.y+e.y,n.z+e.z),vec3h:(n,e)=>y(n.x+e.x,n.y+e.y,n.z+e.z),vec3i:(n,e)=>f(n.x+e.x,n.y+e.y,n.z+e.z),vec3u:(n,e)=>a(n.x+e.x,n.y+e.y,n.z+e.z),vec4f:(n,e)=>u(n.x+e.x,n.y+e.y,n.z+e.z,n.w+e.w),vec4h:(n,e)=>i(n.x+e.x,n.y+e.y,n.z+e.z,n.w+e.w),vec4i:(n,e)=>g(n.x+e.x,n.y+e.y,n.z+e.z,n.w+e.w),vec4u:(n,e)=>z(n.x+e.x,n.y+e.y,n.z+e.z,n.w+e.w)},sub:{vec2f:(n,e)=>o(n.x-e.x,n.y-e.y),vec2h:(n,e)=>v(n.x-e.x,n.y-e.y),vec2i:(n,e)=>l(n.x-e.x,n.y-e.y),vec2u:(n,e)=>m(n.x-e.x,n.y-e.y),vec3f:(n,e)=>w(n.x-e.x,n.y-e.y,n.z-e.z),vec3h:(n,e)=>y(n.x-e.x,n.y-e.y,n.z-e.z),vec3i:(n,e)=>f(n.x-e.x,n.y-e.y,n.z-e.z),vec3u:(n,e)=>a(n.x-e.x,n.y-e.y,n.z-e.z),vec4f:(n,e)=>u(n.x-e.x,n.y-e.y,n.z-e.z,n.w-e.w),vec4h:(n,e)=>i(n.x-e.x,n.y-e.y,n.z-e.z,n.w-e.w),vec4i:(n,e)=>g(n.x-e.x,n.y-e.y,n.z-e.z,n.w-e.w),vec4u:(n,e)=>z(n.x-e.x,n.y-e.y,n.z-e.z,n.w-e.w)},mulSxV:{vec2f:(n,e)=>o(n*e.x,n*e.y),vec2h:(n,e)=>v(n*e.x,n*e.y),vec2i:(n,e)=>l(n*e.x,n*e.y),vec2u:(n,e)=>m(n*e.x,n*e.y),vec3f:(n,e)=>w(n*e.x,n*e.y,n*e.z),vec3h:(n,e)=>y(n*e.x,n*e.y,n*e.z),vec3i:(n,e)=>f(n*e.x,n*e.y,n*e.z),vec3u:(n,e)=>a(n*e.x,n*e.y,n*e.z),vec4f:(n,e)=>u(n*e.x,n*e.y,n*e.z,n*e.w),vec4h:(n,e)=>i(n*e.x,n*e.y,n*e.z,n*e.w),vec4i:(n,e)=>g(n*e.x,n*e.y,n*e.z,n*e.w),vec4u:(n,e)=>z(n*e.x,n*e.y,n*e.z,n*e.w),mat2x2f:(n,e)=>{let t=e.columns;return k(n*t[0].x,n*t[0].y,n*t[1].x,n*t[1].y)},mat3x3f:(n,e)=>{let t=e.columns;return A(n*t[0].x,n*t[0].y,n*t[0].z,n*t[1].x,n*t[1].y,n*t[1].z,n*t[2].x,n*t[2].y,n*t[2].z)},mat4x4f:(n,e)=>{let t=e.columns;return $(n*t[0].x,n*t[0].y,n*t[0].z,n*t[0].w,n*t[1].x,n*t[1].y,n*t[1].z,n*t[1].w,n*t[2].x,n*t[2].y,n*t[2].z,n*t[2].w,n*t[3].x,n*t[3].y,n*t[3].z,n*t[3].w)}},mulVxV:{vec2f:(n,e)=>o(n.x*e.x,n.y*e.y),vec2h:(n,e)=>v(n.x*e.x,n.y*e.y),vec2i:(n,e)=>l(n.x*e.x,n.y*e.y),vec2u:(n,e)=>m(n.x*e.x,n.y*e.y),vec3f:(n,e)=>w(n.x*e.x,n.y*e.y,n.z*e.z),vec3h:(n,e)=>y(n.x*e.x,n.y*e.y,n.z*e.z),vec3i:(n,e)=>f(n.x*e.x,n.y*e.y,n.z*e.z),vec3u:(n,e)=>a(n.x*e.x,n.y*e.y,n.z*e.z),vec4f:(n,e)=>u(n.x*e.x,n.y*e.y,n.z*e.z,n.w*e.w),vec4h:(n,e)=>i(n.x*e.x,n.y*e.y,n.z*e.z,n.w*e.w),vec4i:(n,e)=>g(n.x*e.x,n.y*e.y,n.z*e.z,n.w*e.w),vec4u:(n,e)=>z(n.x*e.x,n.y*e.y,n.z*e.z,n.w*e.w),mat2x2f:(n,e)=>{let t=n.columns,r=e.columns;return k(t[0].x*r[0].x+t[1].x*r[0].y,t[0].y*r[0].x+t[1].y*r[0].y,t[0].x*r[1].x+t[1].x*r[1].y,t[0].y*r[1].x+t[1].y*r[1].y)},mat3x3f:(n,e)=>{let t=n.columns,r=e.columns;return A(t[0].x*r[0].x+t[1].x*r[0].y+t[2].x*r[0].z,t[0].y*r[0].x+t[1].y*r[0].y+t[2].y*r[0].z,t[0].z*r[0].x+t[1].z*r[0].y+t[2].z*r[0].z,t[0].x*r[1].x+t[1].x*r[1].y+t[2].x*r[1].z,t[0].y*r[1].x+t[1].y*r[1].y+t[2].y*r[1].z,t[0].z*r[1].x+t[1].z*r[1].y+t[2].z*r[1].z,t[0].x*r[2].x+t[1].x*r[2].y+t[2].x*r[2].z,t[0].y*r[2].x+t[1].y*r[2].y+t[2].y*r[2].z,t[0].z*r[2].x+t[1].z*r[2].y+t[2].z*r[2].z)},mat4x4f:(n,e)=>{let t=n.columns,r=e.columns;return $(t[0].x*r[0].x+t[1].x*r[0].y+t[2].x*r[0].z+t[3].x*r[0].w,t[0].y*r[0].x+t[1].y*r[0].y+t[2].y*r[0].z+t[3].y*r[0].w,t[0].z*r[0].x+t[1].z*r[0].y+t[2].z*r[0].z+t[3].z*r[0].w,t[0].w*r[0].x+t[1].w*r[0].y+t[2].w*r[0].z+t[3].w*r[0].w,t[0].x*r[1].x+t[1].x*r[1].y+t[2].x*r[1].z+t[3].x*r[1].w,t[0].y*r[1].x+t[1].y*r[1].y+t[2].y*r[1].z+t[3].y*r[1].w,t[0].z*r[1].x+t[1].z*r[1].y+t[2].z*r[1].z+t[3].z*r[1].w,t[0].w*r[1].x+t[1].w*r[1].y+t[2].w*r[1].z+t[3].w*r[1].w,t[0].x*r[2].x+t[1].x*r[2].y+t[2].x*r[2].z+t[3].x*r[2].w,t[0].y*r[2].x+t[1].y*r[2].y+t[2].y*r[2].z+t[3].y*r[2].w,t[0].z*r[2].x+t[1].z*r[2].y+t[2].z*r[2].z+t[3].z*r[2].w,t[0].w*r[2].x+t[1].w*r[2].y+t[2].w*r[2].z+t[3].w*r[2].w,t[0].x*r[3].x+t[1].x*r[3].y+t[2].x*r[3].z+t[3].x*r[3].w,t[0].y*r[3].x+t[1].y*r[3].y+t[2].y*r[3].z+t[3].y*r[3].w,t[0].z*r[3].x+t[1].z*r[3].y+t[2].z*r[3].z+t[3].z*r[3].w,t[0].w*r[3].x+t[1].w*r[3].y+t[2].w*r[3].z+t[3].w*r[3].w)}},mulMxV:{mat2x2f:(n,e)=>{let t=n.columns;return o(t[0].x*e.x+t[1].x*e.y,t[0].y*e.x+t[1].y*e.y)},mat3x3f:(n,e)=>{let t=n.columns;return w(t[0].x*e.x+t[1].x*e.y+t[2].x*e.z,t[0].y*e.x+t[1].y*e.y+t[2].y*e.z,t[0].z*e.x+t[1].z*e.y+t[2].z*e.z)},mat4x4f:(n,e)=>{let t=n.columns;return u(t[0].x*e.x+t[1].x*e.y+t[2].x*e.z+t[3].x*e.w,t[0].y*e.x+t[1].y*e.y+t[2].y*e.z+t[3].y*e.w,t[0].z*e.x+t[1].z*e.y+t[2].z*e.z+t[3].z*e.w,t[0].w*e.x+t[1].w*e.y+t[2].w*e.z+t[3].w*e.w)}},mulVxM:{mat2x2f:(n,e)=>{let t=e.columns;return o(n.x*t[0].x+n.y*t[0].y,n.x*t[1].x+n.y*t[1].y)},mat3x3f:(n,e)=>{let t=e.columns;return w(n.x*t[0].x+n.y*t[0].y+n.z*t[0].z,n.x*t[1].x+n.y*t[1].y+n.z*t[1].z,n.x*t[2].x+n.y*t[2].y+n.z*t[2].z)},mat4x4f:(n,e)=>{let t=e.columns;return u(n.x*t[0].x+n.y*t[0].y+n.z*t[0].z+n.w*t[0].w,n.x*t[1].x+n.y*t[1].y+n.z*t[1].z+n.w*t[1].w,n.x*t[2].x+n.y*t[2].y+n.z*t[2].z+n.w*t[2].w,n.x*t[3].x+n.y*t[3].y+n.z*t[3].z+n.w*t[3].w)}},dot:{vec2f:M,vec2h:M,vec2i:M,vec2u:M,vec3f:p,vec3h:p,vec3i:p,vec3u:p,vec4f:B,vec4h:B,vec4i:B,vec4u:B},normalize:{vec2f:n=>{let e=d(n);return o(n.x/e,n.y/e)},vec2h:n=>{let e=d(n);return v(n.x/e,n.y/e)},vec2i:n=>{let e=d(n);return l(n.x/e,n.y/e)},vec2u:n=>{let e=d(n);return m(n.x/e,n.y/e)},vec3f:n=>{let e=T(n);return w(n.x/e,n.y/e,n.z/e)},vec3h:n=>{let e=T(n);return y(n.x/e,n.y/e,n.z/e)},vec3i:n=>{let e=T(n);return f(n.x/e,n.y/e,n.z/e)},vec3u:n=>{let e=T(n);return a(n.x/e,n.y/e,n.z/e)},vec4f:n=>{let e=h(n);return u(n.x/e,n.y/e,n.z/e,n.w/e)},vec4h:n=>{let e=h(n);return i(n.x/e,n.y/e,n.z/e,n.w/e)},vec4i:n=>{let e=h(n);return g(n.x/e,n.y/e,n.z/e,n.w/e)},vec4u:n=>{let e=h(n);return z(n.x/e,n.y/e,n.z/e,n.w/e)}},cross:{vec3f:(n,e)=>w(n.y*e.z-n.z*e.y,n.z*e.x-n.x*e.z,n.x*e.y-n.y*e.x),vec3h:(n,e)=>y(n.y*e.z-n.z*e.y,n.z*e.x-n.x*e.z,n.x*e.y-n.y*e.x),vec3i:(n,e)=>f(n.y*e.z-n.z*e.y,n.z*e.x-n.x*e.z,n.x*e.y-n.y*e.x),vec3u:(n,e)=>a(n.y*e.z-n.z*e.y,n.z*e.x-n.x*e.z,n.x*e.y-n.y*e.x)},floor:{vec2f:b(Math.floor),vec2h:V(Math.floor),vec2i:O(Math.floor),vec2u:U(Math.floor),vec3f:I(Math.floor),vec3h:K(Math.floor),vec3i:R(Math.floor),vec3u:G(Math.floor),vec4f:P(Math.floor),vec4h:W(Math.floor),vec4i:_(Math.floor),vec4u:E(Math.floor)},max:{vec2f:C(Math.max),vec2h:F(Math.max),vec2i:S(Math.max),vec2u:j(Math.max),vec3f:q(Math.max),vec3h:L(Math.max),vec3i:X(Math.max),vec3u:D(Math.max),vec4f:H(Math.max),vec4h:J(Math.max),vec4i:N(Math.max),vec4u:Q(Math.max)},min:{vec2f:C(Math.min),vec2h:F(Math.min),vec2i:S(Math.min),vec2u:j(Math.min),vec3f:q(Math.min),vec3h:L(Math.min),vec3i:X(Math.min),vec3u:D(Math.min),vec4f:H(Math.min),vec4h:J(Math.min),vec4i:N(Math.min),vec4u:Q(Math.min)},pow:{vec2f:(n,e)=>o(n.x**e.x,n.y**e.y),vec2h:(n,e)=>v(n.x**e.x,n.y**e.y),vec3f:(n,e)=>w(n.x**e.x,n.y**e.y,n.z**e.z),vec3h:(n,e)=>y(n.x**e.x,n.y**e.y,n.z**e.z),vec4f:(n,e)=>u(n.x**e.x,n.y**e.y,n.z**e.z,n.w**e.w),vec4h:(n,e)=>i(n.x**e.x,n.y**e.y,n.z**e.z,n.w**e.w)},mix:{vec2f:(n,e,t)=>typeof t=="number"?o(n.x*(1-t)+e.x*t,n.y*(1-t)+e.y*t):o(n.x*(1-t.x)+e.x*t.x,n.y*(1-t.y)+e.y*t.y),vec2h:(n,e,t)=>typeof t=="number"?v(n.x*(1-t)+e.x*t,n.y*(1-t)+e.y*t):v(n.x*(1-t.x)+e.x*t.x,n.y*(1-t.y)+e.y*t.y),vec3f:(n,e,t)=>typeof t=="number"?w(n.x*(1-t)+e.x*t,n.y*(1-t)+e.y*t,n.z*(1-t)+e.z*t):w(n.x*(1-t.x)+e.x*t.x,n.y*(1-t.y)+e.y*t.y,n.z*(1-t.z)+e.z*t.z),vec3h:(n,e,t)=>typeof t=="number"?y(n.x*(1-t)+e.x*t,n.y*(1-t)+e.y*t,n.z*(1-t)+e.z*t):y(n.x*(1-t.x)+e.x*t.x,n.y*(1-t.y)+e.y*t.y,n.z*(1-t.z)+e.z*t.z),vec4f:(n,e,t)=>typeof t=="number"?u(n.x*(1-t)+e.x*t,n.y*(1-t)+e.y*t,n.z*(1-t)+e.z*t,n.w*(1-t)+e.w*t):u(n.x*(1-t.x)+e.x*t.x,n.y*(1-t.y)+e.y*t.y,n.z*(1-t.z)+e.z*t.z,n.w*(1-t.w)+e.w*t.w),vec4h:(n,e,t)=>typeof t=="number"?i(n.x*(1-t)+e.x*t,n.y*(1-t)+e.y*t,n.z*(1-t)+e.z*t,n.w*(1-t)+e.w*t):i(n.x*(1-t.x)+e.x*t.x,n.y*(1-t.y)+e.y*t.y,n.z*(1-t.z)+e.z*t.z,n.w*(1-t.w)+e.w*t.w)}};function tn(n,e){return s()?`(${n} + ${e})`:x.add[n.kind](n,e)}function Y(n,e){return s()?`(${n} - ${e})`:x.sub[n.kind](n,e)}function Z(n,e){if(s())return`(${n} * ${e})`;if(typeof n=="number")return x.mulSxV[e.kind](n,e);if(typeof n=="object"&&typeof e=="object"&&"kind"in n&&"kind"in e){let t=!n.kind.startsWith("mat"),r=!e.kind.startsWith("mat");if(!t&&r)return x.mulMxV[n.kind](n,e);if(t&&!r)return x.mulVxM[e.kind](n,e)}return x.mulVxV[e.kind](n,e)}function rn(n){return s()?`abs(${n})`:typeof n=="number"?Math.abs(n):x.abs[n.kind](n)}function sn(n,e){return s()?`atan2(${n}, ${e})`:typeof n=="number"&&typeof e=="number"?Math.atan2(n,e):x.atan2[n.kind](n,e)}function cn(n){return s()?`ceil(${n})`:typeof n=="number"?Math.ceil(n):x.ceil[n.kind](n)}function xn(n,e,t){return s()?`clamp(${n}, ${e}, ${t})`:typeof n=="number"?Math.min(Math.max(e,n),t):x.clamp[n.kind](n,e,t)}function wn(n){return s()?`cos(${n})`:Math.cos(n)}function on(n,e){return s()?`cross(${n}, ${e})`:x.cross[n.kind](n,e)}function nn(n,e){return s()?`dot(${n}, ${e})`:x.dot[n.kind](n,e)}function un(n){return s()?`normalize(${n})`:x.normalize[n.kind](n)}function yn(n){return s()?`floor(${n})`:typeof n=="number"?Math.floor(n):x.floor[n.kind](n)}function vn(n){return s()?`fract(${n})`:n-Math.floor(n)}function fn(n){return s()?`length(${n})`:typeof n=="number"?Math.abs(n):x.length[n.kind](n)}function an(n,e){return s()?`max(${n}, ${e})`:typeof n=="number"?Math.max(n,e):x.max[n.kind](n,e)}function ln(n,e){return s()?`min(${n}, ${e})`:typeof n=="number"?Math.min(n,e):x.min[n.kind](n,e)}function mn(n){return s()?`sin(${n})`:Math.sin(n)}function gn(n){return s()?`exp(${n})`:Math.exp(n)}function zn(n,e){if(s())return`pow(${n}, ${e})`;if(typeof n=="number"&&typeof e=="number")return n**e;if(typeof n=="object"&&typeof e=="object"&&"kind"in n&&"kind"in e)return x.pow[n.kind](n,e);throw new Error("Invalid arguments to pow()")}function dn(n,e,t){if(s())return`mix(${n}, ${e}, ${t})`;if(typeof n=="number"){if(typeof t!="number"||typeof e!="number")throw new Error("When e1 and e2 are numbers, the blend factor must be a number.");return n*(1-t)+e*t}if(typeof n=="number"||typeof e=="number")throw new Error("e1 and e2 need to both be vectors of the same kind.");return x.mix[n.kind](n,e,t)}function Tn(n,e){return s()?`reflect(${n}, ${e})`:Y(n,Z(2*nn(e,n),e))}function hn(){if(s())return"workgroupBarrier()";console.warn("workgroupBarrier is a no-op outside of GPU mode.")}function Mn(){if(s())return"storageBarrier()";console.warn("storageBarrier is a no-op outside of GPU mode.")}function pn(){if(s())return"textureBarrier()";console.warn("textureBarrier is a no-op outside of GPU mode.")}function Bn(n){if(s())return`atomicLoad(&${n})`;throw new Error("Atomic operations are not supported outside of GPU mode.")}function kn(n,e){if(s())return`atomicStore(&${n}, ${e})`;throw new Error("Atomic operations are not supported outside of GPU mode.")}function An(n,e){if(s())return`atomicAdd(&${n}, ${e})`;throw new Error("Atomic operations are not supported outside of GPU mode.")}function $n(n,e){if(s())return`atomicSub(&${n}, ${e})`;throw new Error("Atomic operations are not supported outside of GPU mode.")}function bn(n,e){if(s())return`atomicMax(&${n}, ${e})`;throw new Error("Atomic operations are not supported outside of GPU mode.")}function Vn(n,e){if(s())return`atomicMin(&${n}, ${e})`;throw new Error("Atomic operations are not supported outside of GPU mode.")}function On(n,e){if(s())return`atomicAnd(&${n}, ${e})`;throw new Error("Atomic operations are not supported outside of GPU mode.")}function Un(n,e){if(s())return`atomicOr(&${n}, ${e})`;throw new Error("Atomic operations are not supported outside of GPU mode.")}function In(n,e){if(s())return`atomicXor(&${n}, ${e})`;throw new Error("Atomic operations are not supported outside of GPU mode.")}export{rn as abs,tn as add,sn as atan2,An as atomicAdd,On as atomicAnd,Bn as atomicLoad,bn as atomicMax,Vn as atomicMin,Un as atomicOr,kn as atomicStore,$n as atomicSub,In as atomicXor,cn as ceil,xn as clamp,wn as cos,on as cross,en as discard,nn as dot,gn as exp,yn as floor,vn as fract,fn as length,an as max,ln as min,dn as mix,Z as mul,un as normalize,zn as pow,Tn as reflect,mn as sin,Mn as storageBarrier,Y as sub,pn as textureBarrier,hn as workgroupBarrier};
|
2
2
|
//# sourceMappingURL=index.js.map
|
package/std/index.js.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"sources":["../../src/data/vectorOps.ts","../../src/std/numeric.ts"],"sourcesContent":["import { mat2x2f, mat3x3f, mat4x4f } from './matrix';\nimport {\n vec2f,\n vec2h,\n vec2i,\n vec2u,\n vec3f,\n vec3h,\n vec3i,\n vec3u,\n vec4f,\n vec4h,\n vec4i,\n vec4u,\n} from './vector';\nimport type * as wgsl from './wgslTypes';\nimport type { VecKind } from './wgslTypes';\n\ntype vBase = { kind: VecKind };\ntype v2 = wgsl.v2f | wgsl.v2h | wgsl.v2i | wgsl.v2u;\ntype v3 = wgsl.v3f | wgsl.v3h | wgsl.v3i | wgsl.v3u;\ntype v4 = wgsl.v4f | wgsl.v4h | wgsl.v4i | wgsl.v4u;\n\ntype MatKind = 'mat2x2f' | 'mat3x3f' | 'mat4x4f';\n\nconst lengthVec2 = (v: v2) => Math.sqrt(v.x ** 2 + v.y ** 2);\nconst lengthVec3 = (v: v3) => Math.sqrt(v.x ** 2 + v.y ** 2 + v.z ** 2);\nconst lengthVec4 = (v: v4) =>\n Math.sqrt(v.x ** 2 + v.y ** 2 + v.z ** 2 + v.w ** 2);\n\nconst dotVec2 = (lhs: v2, rhs: v2) => lhs.x * rhs.x + lhs.y * rhs.y;\nconst dotVec3 = (lhs: v3, rhs: v3) =>\n lhs.x * rhs.x + lhs.y * rhs.y + lhs.z * rhs.z;\nconst dotVec4 = (lhs: v4, rhs: v4) =>\n lhs.x * rhs.x + lhs.y * rhs.y + lhs.z * rhs.z + lhs.w * rhs.w;\n\nconst clamp = (value: number, low: number, high: number) =>\n Math.min(Math.max(low, value), high);\n\nexport const VectorOps = {\n abs: {\n vec2f: (v: wgsl.v2f) => vec2f(Math.abs(v.x), Math.abs(v.y)),\n vec2h: (v: wgsl.v2h) => vec2h(Math.abs(v.x), Math.abs(v.y)),\n vec2i: (v: wgsl.v2i) => vec2i(Math.abs(v.x), Math.abs(v.y)),\n vec2u: (v: wgsl.v2u) => vec2u(Math.abs(v.x), Math.abs(v.y)),\n\n vec3f: (v: wgsl.v3f) => vec3f(Math.abs(v.x), Math.abs(v.y), Math.abs(v.z)),\n vec3h: (v: wgsl.v3h) => vec3h(Math.abs(v.x), Math.abs(v.y), Math.abs(v.z)),\n vec3i: (v: wgsl.v3i) => vec3i(Math.abs(v.x), Math.abs(v.y), Math.abs(v.z)),\n vec3u: (v: wgsl.v3u) => vec3u(Math.abs(v.x), Math.abs(v.y), Math.abs(v.z)),\n\n vec4f: (v: wgsl.v4f) =>\n vec4f(Math.abs(v.x), Math.abs(v.y), Math.abs(v.z), Math.abs(v.w)),\n vec4h: (v: wgsl.v4h) =>\n vec4h(Math.abs(v.x), Math.abs(v.y), Math.abs(v.z), Math.abs(v.w)),\n vec4i: (v: wgsl.v4i) =>\n vec4i(Math.abs(v.x), Math.abs(v.y), Math.abs(v.z), Math.abs(v.w)),\n vec4u: (v: wgsl.v4u) =>\n vec4u(Math.abs(v.x), Math.abs(v.y), Math.abs(v.z), Math.abs(v.w)),\n } as Record<VecKind, <T extends vBase>(v: T) => T>,\n\n ceil: {\n vec2f: (v: wgsl.v2f) => vec2f(Math.ceil(v.x), Math.ceil(v.y)),\n vec2h: (v: wgsl.v2h) => vec2h(Math.ceil(v.x), Math.ceil(v.y)),\n vec2i: (v: wgsl.v2i) => vec2i(Math.ceil(v.x), Math.ceil(v.y)),\n vec2u: (v: wgsl.v2u) => vec2u(Math.ceil(v.x), Math.ceil(v.y)),\n\n vec3f: (v: wgsl.v3f) =>\n vec3f(Math.ceil(v.x), Math.ceil(v.y), Math.ceil(v.z)),\n vec3h: (v: wgsl.v3h) =>\n vec3h(Math.ceil(v.x), Math.ceil(v.y), Math.ceil(v.z)),\n vec3i: (v: wgsl.v3i) =>\n vec3i(Math.ceil(v.x), Math.ceil(v.y), Math.ceil(v.z)),\n vec3u: (v: wgsl.v3u) =>\n vec3u(Math.ceil(v.x), Math.ceil(v.y), Math.ceil(v.z)),\n\n vec4f: (v: wgsl.v4f) =>\n vec4f(Math.ceil(v.x), Math.ceil(v.y), Math.ceil(v.z), Math.ceil(v.w)),\n vec4h: (v: wgsl.v4h) =>\n vec4h(Math.ceil(v.x), Math.ceil(v.y), Math.ceil(v.z), Math.ceil(v.w)),\n vec4i: (v: wgsl.v4i) =>\n vec4i(Math.ceil(v.x), Math.ceil(v.y), Math.ceil(v.z), Math.ceil(v.w)),\n vec4u: (v: wgsl.v4u) =>\n vec4u(Math.ceil(v.x), Math.ceil(v.y), Math.ceil(v.z), Math.ceil(v.w)),\n } as Record<VecKind, <T extends vBase>(v: T) => T>,\n\n clamp: {\n vec2f: (v: wgsl.v2f, low: wgsl.v2f, high: wgsl.v2f) =>\n vec2f(clamp(v.x, low.x, high.x), clamp(v.y, low.y, high.y)),\n vec2h: (v: wgsl.v2h, low: wgsl.v2h, high: wgsl.v2h) =>\n vec2h(clamp(v.x, low.x, high.x), clamp(v.y, low.y, high.y)),\n vec2i: (v: wgsl.v2i, low: wgsl.v2i, high: wgsl.v2i) =>\n vec2i(clamp(v.x, low.x, high.x), clamp(v.y, low.y, high.y)),\n vec2u: (v: wgsl.v2u, low: wgsl.v2u, high: wgsl.v2u) =>\n vec2u(clamp(v.x, low.x, high.x), clamp(v.y, low.y, high.y)),\n\n vec3f: (v: wgsl.v3f, low: wgsl.v3f, high: wgsl.v3f) =>\n vec3f(\n clamp(v.x, low.x, high.x),\n clamp(v.y, low.y, high.y),\n clamp(v.z, low.z, high.z),\n ),\n vec3h: (v: wgsl.v3h, low: wgsl.v3h, high: wgsl.v3h) =>\n vec3h(\n clamp(v.x, low.x, high.x),\n clamp(v.y, low.y, high.y),\n clamp(v.z, low.z, high.z),\n ),\n vec3i: (v: wgsl.v3i, low: wgsl.v3i, high: wgsl.v3f) =>\n vec3i(\n clamp(v.x, low.x, high.x),\n clamp(v.y, low.y, high.y),\n clamp(v.z, low.z, high.z),\n ),\n vec3u: (v: wgsl.v3u, low: wgsl.v3u, high: wgsl.v3f) =>\n vec3u(\n clamp(v.x, low.x, high.x),\n clamp(v.y, low.y, high.y),\n clamp(v.z, low.z, high.z),\n ),\n\n vec4f: (v: wgsl.v4f, low: wgsl.v4f, high: wgsl.v4f) =>\n vec4f(\n clamp(v.x, low.x, high.x),\n clamp(v.y, low.y, high.y),\n clamp(v.z, low.z, high.z),\n clamp(v.w, low.w, high.w),\n ),\n vec4h: (v: wgsl.v4h, low: wgsl.v4h, high: wgsl.v4h) =>\n vec4h(\n clamp(v.x, low.x, high.x),\n clamp(v.y, low.y, high.y),\n clamp(v.z, low.z, high.z),\n clamp(v.w, low.w, high.w),\n ),\n vec4i: (v: wgsl.v4i, low: wgsl.v4i, high: wgsl.v4i) =>\n vec4i(\n clamp(v.x, low.x, high.x),\n clamp(v.y, low.y, high.y),\n clamp(v.z, low.z, high.z),\n clamp(v.w, low.w, high.w),\n ),\n vec4u: (v: wgsl.v4u, low: wgsl.v4u, high: wgsl.v4u) =>\n vec4u(\n clamp(v.x, low.x, high.x),\n clamp(v.y, low.y, high.y),\n clamp(v.z, low.z, high.z),\n clamp(v.w, low.w, high.w),\n ),\n } as Record<VecKind, <T extends vBase>(v: T, low: T, high: T) => T>,\n\n length: {\n vec2f: lengthVec2,\n vec2h: lengthVec2,\n vec2i: lengthVec2,\n vec2u: lengthVec2,\n vec3f: lengthVec3,\n vec3h: lengthVec3,\n vec3i: lengthVec3,\n vec3u: lengthVec3,\n vec4f: lengthVec4,\n vec4h: lengthVec4,\n vec4i: lengthVec4,\n vec4u: lengthVec4,\n } as Record<VecKind, (v: vBase) => number>,\n\n add: {\n vec2f: (a: wgsl.v2f, b: wgsl.v2f) => vec2f(a.x + b.x, a.y + b.y),\n vec2h: (a: wgsl.v2h, b: wgsl.v2h) => vec2h(a.x + b.x, a.y + b.y),\n vec2i: (a: wgsl.v2i, b: wgsl.v2i) => vec2i(a.x + b.x, a.y + b.y),\n vec2u: (a: wgsl.v2u, b: wgsl.v2u) => vec2u(a.x + b.x, a.y + b.y),\n\n vec3f: (a: wgsl.v3f, b: wgsl.v3f) => vec3f(a.x + b.x, a.y + b.y, a.z + b.z),\n vec3h: (a: wgsl.v3h, b: wgsl.v3h) => vec3h(a.x + b.x, a.y + b.y, a.z + b.z),\n vec3i: (a: wgsl.v3i, b: wgsl.v3i) => vec3i(a.x + b.x, a.y + b.y, a.z + b.z),\n vec3u: (a: wgsl.v3u, b: wgsl.v3u) => vec3u(a.x + b.x, a.y + b.y, a.z + b.z),\n\n vec4f: (a: wgsl.v4f, b: wgsl.v4f) =>\n vec4f(a.x + b.x, a.y + b.y, a.z + b.z, a.w + b.w),\n vec4h: (a: wgsl.v4h, b: wgsl.v4h) =>\n vec4h(a.x + b.x, a.y + b.y, a.z + b.z, a.w + b.w),\n vec4i: (a: wgsl.v4i, b: wgsl.v4i) =>\n vec4i(a.x + b.x, a.y + b.y, a.z + b.z, a.w + b.w),\n vec4u: (a: wgsl.v4u, b: wgsl.v4u) =>\n vec4u(a.x + b.x, a.y + b.y, a.z + b.z, a.w + b.w),\n } as Record<VecKind, <T extends vBase>(lhs: T, rhs: T) => T>,\n\n sub: {\n vec2f: (a: wgsl.v2f, b: wgsl.v2f) => vec2f(a.x - b.x, a.y - b.y),\n vec2h: (a: wgsl.v2h, b: wgsl.v2h) => vec2h(a.x - b.x, a.y - b.y),\n vec2i: (a: wgsl.v2i, b: wgsl.v2i) => vec2i(a.x - b.x, a.y - b.y),\n vec2u: (a: wgsl.v2u, b: wgsl.v2u) => vec2u(a.x - b.x, a.y - b.y),\n\n vec3f: (a: wgsl.v3f, b: wgsl.v3f) => vec3f(a.x - b.x, a.y - b.y, a.z - b.z),\n vec3h: (a: wgsl.v3h, b: wgsl.v3h) => vec3h(a.x - b.x, a.y - b.y, a.z - b.z),\n vec3i: (a: wgsl.v3i, b: wgsl.v3i) => vec3i(a.x - b.x, a.y - b.y, a.z - b.z),\n vec3u: (a: wgsl.v3u, b: wgsl.v3u) => vec3u(a.x - b.x, a.y - b.y, a.z - b.z),\n\n vec4f: (a: wgsl.v4f, b: wgsl.v4f) =>\n vec4f(a.x - b.x, a.y - b.y, a.z - b.z, a.w - b.w),\n vec4h: (a: wgsl.v4h, b: wgsl.v4h) =>\n vec4h(a.x - b.x, a.y - b.y, a.z - b.z, a.w - b.w),\n vec4i: (a: wgsl.v4i, b: wgsl.v4i) =>\n vec4i(a.x - b.x, a.y - b.y, a.z - b.z, a.w - b.w),\n vec4u: (a: wgsl.v4u, b: wgsl.v4u) =>\n vec4u(a.x - b.x, a.y - b.y, a.z - b.z, a.w - b.w),\n } as Record<VecKind, <T extends vBase>(lhs: T, rhs: T) => T>,\n\n mulSxV: {\n vec2f: (s: number, v: wgsl.v2f) => vec2f(s * v.x, s * v.y),\n vec2h: (s: number, v: wgsl.v2h) => vec2h(s * v.x, s * v.y),\n vec2i: (s: number, v: wgsl.v2i) => vec2i(s * v.x, s * v.y),\n vec2u: (s: number, v: wgsl.v2u) => vec2u(s * v.x, s * v.y),\n\n vec3f: (s: number, v: wgsl.v3f) => vec3f(s * v.x, s * v.y, s * v.z),\n vec3h: (s: number, v: wgsl.v3h) => vec3h(s * v.x, s * v.y, s * v.z),\n vec3i: (s: number, v: wgsl.v3i) => vec3i(s * v.x, s * v.y, s * v.z),\n vec3u: (s: number, v: wgsl.v3u) => vec3u(s * v.x, s * v.y, s * v.z),\n\n vec4f: (s: number, v: wgsl.v4f) =>\n vec4f(s * v.x, s * v.y, s * v.z, s * v.w),\n vec4h: (s: number, v: wgsl.v4h) =>\n vec4h(s * v.x, s * v.y, s * v.z, s * v.w),\n vec4i: (s: number, v: wgsl.v4i) =>\n vec4i(s * v.x, s * v.y, s * v.z, s * v.w),\n vec4u: (s: number, v: wgsl.v4u) =>\n vec4u(s * v.x, s * v.y, s * v.z, s * v.w),\n\n mat2x2f: (s: number, m: wgsl.m2x2f) => {\n const m_ = m.columns as [wgsl.v2f, wgsl.v2f];\n return mat2x2f(s * m_[0].x, s * m_[0].y, s * m_[1].x, s * m_[1].y);\n },\n\n mat3x3f: (s: number, m: wgsl.m3x3f) => {\n const m_ = m.columns as [wgsl.v3f, wgsl.v3f, wgsl.v3f];\n return mat3x3f(\n s * m_[0].x,\n s * m_[0].y,\n s * m_[0].z,\n\n s * m_[1].x,\n s * m_[1].y,\n s * m_[1].z,\n\n s * m_[2].x,\n s * m_[2].y,\n s * m_[2].z,\n );\n },\n\n mat4x4f: (s: number, m: wgsl.m4x4f) => {\n const m_ = m.columns as [wgsl.v4f, wgsl.v4f, wgsl.v4f, wgsl.v4f];\n return mat4x4f(\n s * m_[0].x,\n s * m_[0].y,\n s * m_[0].z,\n s * m_[0].w,\n\n s * m_[1].x,\n s * m_[1].y,\n s * m_[1].z,\n s * m_[1].w,\n\n s * m_[2].x,\n s * m_[2].y,\n s * m_[2].z,\n s * m_[2].w,\n\n s * m_[3].x,\n s * m_[3].y,\n s * m_[3].z,\n s * m_[3].w,\n );\n },\n } as Record<\n VecKind | MatKind,\n <T extends vBase | wgsl.AnyMatInstance>(s: number, v: T) => T\n >,\n\n mulVxV: {\n vec2f: (a: wgsl.v2f, b: wgsl.v2f) => vec2f(a.x * b.x, a.y * b.y),\n vec2h: (a: wgsl.v2h, b: wgsl.v2h) => vec2h(a.x * b.x, a.y * b.y),\n vec2i: (a: wgsl.v2i, b: wgsl.v2i) => vec2i(a.x * b.x, a.y * b.y),\n vec2u: (a: wgsl.v2u, b: wgsl.v2u) => vec2u(a.x * b.x, a.y * b.y),\n\n vec3f: (a: wgsl.v3f, b: wgsl.v3f) => vec3f(a.x * b.x, a.y * b.y, a.z * b.z),\n vec3h: (a: wgsl.v3h, b: wgsl.v3h) => vec3h(a.x * b.x, a.y * b.y, a.z * b.z),\n vec3i: (a: wgsl.v3i, b: wgsl.v3i) => vec3i(a.x * b.x, a.y * b.y, a.z * b.z),\n vec3u: (a: wgsl.v3u, b: wgsl.v3u) => vec3u(a.x * b.x, a.y * b.y, a.z * b.z),\n\n vec4f: (a: wgsl.v4f, b: wgsl.v4f) =>\n vec4f(a.x * b.x, a.y * b.y, a.z * b.z, a.w * b.w),\n vec4h: (a: wgsl.v4h, b: wgsl.v4h) =>\n vec4h(a.x * b.x, a.y * b.y, a.z * b.z, a.w * b.w),\n vec4i: (a: wgsl.v4i, b: wgsl.v4i) =>\n vec4i(a.x * b.x, a.y * b.y, a.z * b.z, a.w * b.w),\n vec4u: (a: wgsl.v4u, b: wgsl.v4u) =>\n vec4u(a.x * b.x, a.y * b.y, a.z * b.z, a.w * b.w),\n\n mat2x2f: (a: wgsl.m2x2f, b: wgsl.m2x2f) => {\n const a_ = a.columns as [wgsl.v2f, wgsl.v2f];\n const b_ = b.columns as [wgsl.v2f, wgsl.v2f];\n\n return mat2x2f(\n a_[0].x * b_[0].x + a_[1].x * b_[0].y,\n a_[0].y * b_[0].x + a_[1].y * b_[0].y,\n\n a_[0].x * b_[1].x + a_[1].x * b_[1].y,\n a_[0].y * b_[1].x + a_[1].y * b_[1].y,\n );\n },\n\n mat3x3f: (a: wgsl.m3x3f, b: wgsl.m3x3f) => {\n const a_ = a.columns as [wgsl.v3f, wgsl.v3f, wgsl.v3f];\n const b_ = b.columns as [wgsl.v3f, wgsl.v3f, wgsl.v3f];\n\n return mat3x3f(\n a_[0].x * b_[0].x + a_[1].x * b_[0].y + a_[2].x * b_[0].z,\n a_[0].y * b_[0].x + a_[1].y * b_[0].y + a_[2].y * b_[0].z,\n a_[0].z * b_[0].x + a_[1].z * b_[0].y + a_[2].z * b_[0].z,\n\n a_[0].x * b_[1].x + a_[1].x * b_[1].y + a_[2].x * b_[1].z,\n a_[0].y * b_[1].x + a_[1].y * b_[1].y + a_[2].y * b_[1].z,\n a_[0].z * b_[1].x + a_[1].z * b_[1].y + a_[2].z * b_[1].z,\n\n a_[0].x * b_[2].x + a_[1].x * b_[2].y + a_[2].x * b_[2].z,\n a_[0].y * b_[2].x + a_[1].y * b_[2].y + a_[2].y * b_[2].z,\n a_[0].z * b_[2].x + a_[1].z * b_[2].y + a_[2].z * b_[2].z,\n );\n },\n\n mat4x4f: (a: wgsl.m4x4f, b: wgsl.m4x4f) => {\n const a_ = a.columns as [wgsl.v4f, wgsl.v4f, wgsl.v4f, wgsl.v4f];\n const b_ = b.columns as [wgsl.v4f, wgsl.v4f, wgsl.v4f, wgsl.v4f];\n\n return mat4x4f(\n a_[0].x * b_[0].x +\n a_[1].x * b_[0].y +\n a_[2].x * b_[0].z +\n a_[3].x * b_[0].w,\n a_[0].y * b_[0].x +\n a_[1].y * b_[0].y +\n a_[2].y * b_[0].z +\n a_[3].y * b_[0].w,\n a_[0].z * b_[0].x +\n a_[1].z * b_[0].y +\n a_[2].z * b_[0].z +\n a_[3].z * b_[0].w,\n a_[0].w * b_[0].x +\n a_[1].w * b_[0].y +\n a_[2].w * b_[0].z +\n a_[3].w * b_[0].w,\n\n a_[0].x * b_[1].x +\n a_[1].x * b_[1].y +\n a_[2].x * b_[1].z +\n a_[3].x * b_[1].w,\n a_[0].y * b_[1].x +\n a_[1].y * b_[1].y +\n a_[2].y * b_[1].z +\n a_[3].y * b_[1].w,\n a_[0].z * b_[1].x +\n a_[1].z * b_[1].y +\n a_[2].z * b_[1].z +\n a_[3].z * b_[1].w,\n a_[0].w * b_[1].x +\n a_[1].w * b_[1].y +\n a_[2].w * b_[1].z +\n a_[3].w * b_[1].w,\n\n a_[0].x * b_[2].x +\n a_[1].x * b_[2].y +\n a_[2].x * b_[2].z +\n a_[3].x * b_[2].w,\n a_[0].y * b_[2].x +\n a_[1].y * b_[2].y +\n a_[2].y * b_[2].z +\n a_[3].y * b_[2].w,\n a_[0].z * b_[2].x +\n a_[1].z * b_[2].y +\n a_[2].z * b_[2].z +\n a_[3].z * b_[2].w,\n a_[0].w * b_[2].x +\n a_[1].w * b_[2].y +\n a_[2].w * b_[2].z +\n a_[3].w * b_[2].w,\n\n a_[0].x * b_[3].x +\n a_[1].x * b_[3].y +\n a_[2].x * b_[3].z +\n a_[3].x * b_[3].w,\n a_[0].y * b_[3].x +\n a_[1].y * b_[3].y +\n a_[2].y * b_[3].z +\n a_[3].y * b_[3].w,\n a_[0].z * b_[3].x +\n a_[1].z * b_[3].y +\n a_[2].z * b_[3].z +\n a_[3].z * b_[3].w,\n a_[0].w * b_[3].x +\n a_[1].w * b_[3].y +\n a_[2].w * b_[3].z +\n a_[3].w * b_[3].w,\n );\n },\n } as Record<\n VecKind | MatKind,\n <T extends vBase | wgsl.AnyMatInstance>(lhs: T, rhs: T) => T\n >,\n\n mulMxV: {\n mat2x2f: (m: wgsl.m2x2f, v: wgsl.v2f) => {\n const m_ = m.columns as [wgsl.v2f, wgsl.v2f];\n return vec2f(\n m_[0].x * v.x + m_[1].x * v.y,\n m_[0].y * v.x + m_[1].y * v.y,\n );\n },\n\n mat3x3f: (m: wgsl.m3x3f, v: wgsl.v3f) => {\n const m_ = m.columns as [wgsl.v3f, wgsl.v3f, wgsl.v3f];\n return vec3f(\n m_[0].x * v.x + m_[1].x * v.y + m_[2].x * v.z,\n m_[0].y * v.x + m_[1].y * v.y + m_[2].y * v.z,\n m_[0].z * v.x + m_[1].z * v.y + m_[2].z * v.z,\n );\n },\n\n mat4x4f: (m: wgsl.m4x4f, v: wgsl.v4f) => {\n const m_ = m.columns as [wgsl.v4f, wgsl.v4f, wgsl.v4f, wgsl.v4f];\n return vec4f(\n m_[0].x * v.x + m_[1].x * v.y + m_[2].x * v.z + m_[3].x * v.w,\n m_[0].y * v.x + m_[1].y * v.y + m_[2].y * v.z + m_[3].y * v.w,\n m_[0].z * v.x + m_[1].z * v.y + m_[2].z * v.z + m_[3].z * v.w,\n m_[0].w * v.x + m_[1].w * v.y + m_[2].w * v.z + m_[3].w * v.w,\n );\n },\n } as Record<\n MatKind,\n <T extends wgsl.AnyMatInstance>(\n m: T,\n v: wgsl.vBaseForMat<T>,\n ) => wgsl.vBaseForMat<T>\n >,\n\n mulVxM: {\n mat2x2f: (v: wgsl.v2f, m: wgsl.m2x2f) => {\n const m_ = m.columns as [wgsl.v2f, wgsl.v2f];\n return vec2f(\n v.x * m_[0].x + v.y * m_[0].y,\n v.x * m_[1].x + v.y * m_[1].y,\n );\n },\n\n mat3x3f: (v: wgsl.v3f, m: wgsl.m3x3f) => {\n const m_ = m.columns as [wgsl.v3f, wgsl.v3f, wgsl.v3f];\n return vec3f(\n v.x * m_[0].x + v.y * m_[0].y + v.z * m_[0].z,\n v.x * m_[1].x + v.y * m_[1].y + v.z * m_[1].z,\n v.x * m_[2].x + v.y * m_[2].y + v.z * m_[2].z,\n );\n },\n\n mat4x4f: (v: wgsl.v4f, m: wgsl.m4x4f) => {\n const m_ = m.columns as [wgsl.v4f, wgsl.v4f, wgsl.v4f, wgsl.v4f];\n return vec4f(\n v.x * m_[0].x + v.y * m_[0].y + v.z * m_[0].z + v.w * m_[0].w,\n v.x * m_[1].x + v.y * m_[1].y + v.z * m_[1].z + v.w * m_[1].w,\n v.x * m_[2].x + v.y * m_[2].y + v.z * m_[2].z + v.w * m_[2].w,\n v.x * m_[3].x + v.y * m_[3].y + v.z * m_[3].z + v.w * m_[3].w,\n );\n },\n } as Record<\n MatKind,\n <T extends wgsl.AnyMatInstance>(\n v: wgsl.vBaseForMat<T>,\n m: T,\n ) => wgsl.vBaseForMat<T>\n >,\n\n dot: {\n vec2f: dotVec2,\n vec2h: dotVec2,\n vec2i: dotVec2,\n vec2u: dotVec2,\n vec3f: dotVec3,\n vec3h: dotVec3,\n vec3i: dotVec3,\n vec3u: dotVec3,\n vec4f: dotVec4,\n vec4h: dotVec4,\n vec4i: dotVec4,\n vec4u: dotVec4,\n } as Record<VecKind, <T extends vBase>(lhs: T, rhs: T) => number>,\n\n normalize: {\n vec2f: (v: wgsl.v2f) => {\n const len = lengthVec2(v);\n return vec2f(v.x / len, v.y / len);\n },\n vec2h: (v: wgsl.v2h) => {\n const len = lengthVec2(v);\n return vec2h(v.x / len, v.y / len);\n },\n vec2i: (v: wgsl.v2i) => {\n const len = lengthVec2(v);\n return vec2i(v.x / len, v.y / len);\n },\n vec2u: (v: wgsl.v2u) => {\n const len = lengthVec2(v);\n return vec2u(v.x / len, v.y / len);\n },\n\n vec3f: (v: wgsl.v3f) => {\n const len = lengthVec3(v);\n return vec3f(v.x / len, v.y / len, v.z / len);\n },\n vec3h: (v: wgsl.v3h) => {\n const len = lengthVec3(v);\n return vec3h(v.x / len, v.y / len, v.z / len);\n },\n vec3i: (v: wgsl.v3i) => {\n const len = lengthVec3(v);\n return vec3i(v.x / len, v.y / len, v.z / len);\n },\n vec3u: (v: wgsl.v3u) => {\n const len = lengthVec3(v);\n return vec3u(v.x / len, v.y / len, v.z / len);\n },\n\n vec4f: (v: wgsl.v4f) => {\n const len = lengthVec4(v);\n return vec4f(v.x / len, v.y / len, v.z / len, v.w / len);\n },\n vec4h: (v: wgsl.v4h) => {\n const len = lengthVec4(v);\n return vec4h(v.x / len, v.y / len, v.z / len, v.w / len);\n },\n vec4i: (v: wgsl.v4i) => {\n const len = lengthVec4(v);\n return vec4i(v.x / len, v.y / len, v.z / len, v.w / len);\n },\n vec4u: (v: wgsl.v4u) => {\n const len = lengthVec4(v);\n return vec4u(v.x / len, v.y / len, v.z / len, v.w / len);\n },\n } as Record<VecKind, <T extends vBase>(v: T) => T>,\n\n cross: {\n vec3f: (a: wgsl.v3f, b: wgsl.v3f) => {\n return vec3f(\n a.y * b.z - a.z * b.y,\n a.z * b.x - a.x * b.z,\n a.x * b.y - a.y * b.x,\n );\n },\n vec3h: (a: wgsl.v3h, b: wgsl.v3h) => {\n return vec3h(\n a.y * b.z - a.z * b.y,\n a.z * b.x - a.x * b.z,\n a.x * b.y - a.y * b.x,\n );\n },\n vec3i: (a: wgsl.v3i, b: wgsl.v3i) => {\n return vec3i(\n a.y * b.z - a.z * b.y,\n a.z * b.x - a.x * b.z,\n a.x * b.y - a.y * b.x,\n );\n },\n vec3u: (a: wgsl.v3u, b: wgsl.v3u) => {\n return vec3u(\n a.y * b.z - a.z * b.y,\n a.z * b.x - a.x * b.z,\n a.x * b.y - a.y * b.x,\n );\n },\n } as Record<\n 'vec3f' | 'vec3i' | 'vec3u',\n <T extends wgsl.v3f | wgsl.v3i | wgsl.v3u>(a: T, b: T) => T\n >,\n\n floor: {\n vec2f: (v: wgsl.v2f) => vec2f(Math.floor(v.x), Math.floor(v.y)),\n vec2h: (v: wgsl.v2h) => vec2h(Math.floor(v.x), Math.floor(v.y)),\n vec2i: (v: wgsl.v2i) => vec2i(Math.floor(v.x), Math.floor(v.y)),\n vec2u: (v: wgsl.v2u) => vec2u(Math.floor(v.x), Math.floor(v.y)),\n\n vec3f: (v: wgsl.v3f) =>\n vec3f(Math.floor(v.x), Math.floor(v.y), Math.floor(v.z)),\n vec3h: (v: wgsl.v3h) =>\n vec3h(Math.floor(v.x), Math.floor(v.y), Math.floor(v.z)),\n vec3i: (v: wgsl.v3i) =>\n vec3i(Math.floor(v.x), Math.floor(v.y), Math.floor(v.z)),\n vec3u: (v: wgsl.v3u) =>\n vec3u(Math.floor(v.x), Math.floor(v.y), Math.floor(v.z)),\n\n vec4f: (v: wgsl.v4f) =>\n vec4f(Math.floor(v.x), Math.floor(v.y), Math.floor(v.z), Math.floor(v.w)),\n vec4h: (v: wgsl.v4h) =>\n vec4h(Math.floor(v.x), Math.floor(v.y), Math.floor(v.z), Math.floor(v.w)),\n vec4i: (v: wgsl.v4i) =>\n vec4i(Math.floor(v.x), Math.floor(v.y), Math.floor(v.z), Math.floor(v.w)),\n vec4u: (v: wgsl.v4u) =>\n vec4u(Math.floor(v.x), Math.floor(v.y), Math.floor(v.z), Math.floor(v.w)),\n } as Record<VecKind, <T extends vBase>(v: T) => T>,\n\n max: {\n vec2f: (a: wgsl.v2f, b: wgsl.v2f) =>\n vec2f(Math.max(a.x, b.x), Math.max(a.y, b.y)),\n vec2h: (a: wgsl.v2h, b: wgsl.v2h) =>\n vec2h(Math.max(a.x, b.x), Math.max(a.y, b.y)),\n vec2i: (a: wgsl.v2i, b: wgsl.v2i) =>\n vec2i(Math.max(a.x, b.x), Math.max(a.y, b.y)),\n vec2u: (a: wgsl.v2u, b: wgsl.v2u) =>\n vec2u(Math.max(a.x, b.x), Math.max(a.y, b.y)),\n\n vec3f: (a: wgsl.v3f, b: wgsl.v3f) =>\n vec3f(Math.max(a.x, b.x), Math.max(a.y, b.y), Math.max(a.z, b.z)),\n vec3h: (a: wgsl.v3h, b: wgsl.v3h) =>\n vec3h(Math.max(a.x, b.x), Math.max(a.y, b.y), Math.max(a.z, b.z)),\n vec3i: (a: wgsl.v3i, b: wgsl.v3i) =>\n vec3i(Math.max(a.x, b.x), Math.max(a.y, b.y), Math.max(a.z, b.z)),\n vec3u: (a: wgsl.v3u, b: wgsl.v3u) =>\n vec3u(Math.max(a.x, b.x), Math.max(a.y, b.y), Math.max(a.z, b.z)),\n\n vec4f: (a: wgsl.v4f, b: wgsl.v4f) =>\n vec4f(\n Math.max(a.x, b.x),\n Math.max(a.y, b.y),\n Math.max(a.z, b.z),\n Math.max(a.w, b.w),\n ),\n vec4h: (a: wgsl.v4h, b: wgsl.v4h) =>\n vec4h(\n Math.max(a.x, b.x),\n Math.max(a.y, b.y),\n Math.max(a.z, b.z),\n Math.max(a.w, b.w),\n ),\n vec4i: (a: wgsl.v4i, b: wgsl.v4i) =>\n vec4i(\n Math.max(a.x, b.x),\n Math.max(a.y, b.y),\n Math.max(a.z, b.z),\n Math.max(a.w, b.w),\n ),\n vec4u: (a: wgsl.v4u, b: wgsl.v4u) =>\n vec4u(\n Math.max(a.x, b.x),\n Math.max(a.y, b.y),\n Math.max(a.z, b.z),\n Math.max(a.w, b.w),\n ),\n } as Record<VecKind, <T extends vBase>(a: T, b: T) => T>,\n\n min: {\n vec2f: (a: wgsl.v2f, b: wgsl.v2f) =>\n vec2f(Math.min(a.x, b.x), Math.min(a.y, b.y)),\n vec2h: (a: wgsl.v2h, b: wgsl.v2h) =>\n vec2h(Math.min(a.x, b.x), Math.min(a.y, b.y)),\n vec2i: (a: wgsl.v2i, b: wgsl.v2i) =>\n vec2i(Math.min(a.x, b.x), Math.min(a.y, b.y)),\n vec2u: (a: wgsl.v2u, b: wgsl.v2u) =>\n vec2u(Math.min(a.x, b.x), Math.min(a.y, b.y)),\n\n vec3f: (a: wgsl.v3f, b: wgsl.v3f) =>\n vec3f(Math.min(a.x, b.x), Math.min(a.y, b.y), Math.min(a.z, b.z)),\n vec3h: (a: wgsl.v3h, b: wgsl.v3h) =>\n vec3h(Math.min(a.x, b.x), Math.min(a.y, b.y), Math.min(a.z, b.z)),\n vec3i: (a: wgsl.v3i, b: wgsl.v3i) =>\n vec3i(Math.min(a.x, b.x), Math.min(a.y, b.y), Math.min(a.z, b.z)),\n vec3u: (a: wgsl.v3u, b: wgsl.v3u) =>\n vec3u(Math.min(a.x, b.x), Math.min(a.y, b.y), Math.min(a.z, b.z)),\n\n vec4f: (a: wgsl.v4f, b: wgsl.v4f) =>\n vec4f(\n Math.min(a.x, b.x),\n Math.min(a.y, b.y),\n Math.min(a.z, b.z),\n Math.min(a.w, b.w),\n ),\n vec4h: (a: wgsl.v4h, b: wgsl.v4h) =>\n vec4h(\n Math.min(a.x, b.x),\n Math.min(a.y, b.y),\n Math.min(a.z, b.z),\n Math.min(a.w, b.w),\n ),\n vec4i: (a: wgsl.v4i, b: wgsl.v4i) =>\n vec4i(\n Math.min(a.x, b.x),\n Math.min(a.y, b.y),\n Math.min(a.z, b.z),\n Math.min(a.w, b.w),\n ),\n vec4u: (a: wgsl.v4u, b: wgsl.v4u) =>\n vec4u(\n Math.min(a.x, b.x),\n Math.min(a.y, b.y),\n Math.min(a.z, b.z),\n Math.min(a.w, b.w),\n ),\n } as Record<VecKind, <T extends vBase>(a: T, b: T) => T>,\n\n pow: {\n vec2f: (base: wgsl.v2f, exponent: wgsl.v2f) =>\n vec2f(base.x ** exponent.x, base.y ** exponent.y),\n vec2h: (base: wgsl.v2h, exponent: wgsl.v2h) =>\n vec2h(base.x ** exponent.x, base.y ** exponent.y),\n\n vec3f: (base: wgsl.v3f, exponent: wgsl.v3f) =>\n vec3f(base.x ** exponent.x, base.y ** exponent.y, base.z ** exponent.z),\n vec3h: (base: wgsl.v3h, exponent: wgsl.v3h) =>\n vec3h(base.x ** exponent.x, base.y ** exponent.y, base.z ** exponent.z),\n\n vec4f: (base: wgsl.v4f, exponent: wgsl.v4f) =>\n vec4f(\n base.x ** exponent.x,\n base.y ** exponent.y,\n base.z ** exponent.z,\n base.w ** exponent.w,\n ),\n vec4h: (base: wgsl.v4h, exponent: wgsl.v4h) =>\n vec4h(\n base.x ** exponent.x,\n base.y ** exponent.y,\n base.z ** exponent.z,\n base.w ** exponent.w,\n ),\n } as Record<\n 'vec2f' | 'vec3f' | 'vec4f' | 'vec2h' | 'vec3h' | 'vec4h' | 'number',\n <\n T extends\n | wgsl.v2f\n | wgsl.v3f\n | wgsl.v4f\n | wgsl.v2h\n | wgsl.v3h\n | wgsl.v4h\n | number,\n >(\n a: T,\n b: T,\n ) => T\n >,\n\n mix: {\n vec2f: (e1: wgsl.v2f, e2: wgsl.v2f, e3: wgsl.v2f | number) => {\n if (typeof e3 === 'number') {\n return vec2f(e1.x * (1 - e3) + e2.x * e3, e1.y * (1 - e3) + e2.y * e3);\n }\n return vec2f(\n e1.x * (1 - e3.x) + e2.x * e3.x,\n e1.y * (1 - e3.y) + e2.y * e3.y,\n );\n },\n vec2h: (e1: wgsl.v2h, e2: wgsl.v2h, e3: wgsl.v2h | number) => {\n if (typeof e3 === 'number') {\n return vec2h(e1.x * (1 - e3) + e2.x * e3, e1.y * (1 - e3) + e2.y * e3);\n }\n return vec2h(\n e1.x * (1 - e3.x) + e2.x * e3.x,\n e1.y * (1 - e3.y) + e2.y * e3.y,\n );\n },\n\n vec3f: (e1: wgsl.v3f, e2: wgsl.v3f, e3: wgsl.v3f | number) => {\n if (typeof e3 === 'number') {\n return vec3f(\n e1.x * (1 - e3) + e2.x * e3,\n e1.y * (1 - e3) + e2.y * e3,\n e1.z * (1 - e3) + e2.z * e3,\n );\n }\n return vec3f(\n e1.x * (1 - e3.x) + e2.x * e3.x,\n e1.y * (1 - e3.y) + e2.y * e3.y,\n e1.z * (1 - e3.z) + e2.z * e3.z,\n );\n },\n vec3h: (e1: wgsl.v3h, e2: wgsl.v3h, e3: wgsl.v3h | number) => {\n if (typeof e3 === 'number') {\n return vec3h(\n e1.x * (1 - e3) + e2.x * e3,\n e1.y * (1 - e3) + e2.y * e3,\n e1.z * (1 - e3) + e2.z * e3,\n );\n }\n return vec3h(\n e1.x * (1 - e3.x) + e2.x * e3.x,\n e1.y * (1 - e3.y) + e2.y * e3.y,\n e1.z * (1 - e3.z) + e2.z * e3.z,\n );\n },\n\n vec4f: (e1: wgsl.v4f, e2: wgsl.v4f, e3: wgsl.v4f | number) => {\n if (typeof e3 === 'number') {\n return vec4f(\n e1.x * (1 - e3) + e2.x * e3,\n e1.y * (1 - e3) + e2.y * e3,\n e1.z * (1 - e3) + e2.z * e3,\n e1.w * (1 - e3) + e2.w * e3,\n );\n }\n return vec4f(\n e1.x * (1 - e3.x) + e2.x * e3.x,\n e1.y * (1 - e3.y) + e2.y * e3.y,\n e1.z * (1 - e3.z) + e2.z * e3.z,\n e1.w * (1 - e3.w) + e2.w * e3.w,\n );\n },\n vec4h: (e1: wgsl.v4h, e2: wgsl.v4h, e3: wgsl.v4h | number) => {\n if (typeof e3 === 'number') {\n return vec4h(\n e1.x * (1 - e3) + e2.x * e3,\n e1.y * (1 - e3) + e2.y * e3,\n e1.z * (1 - e3) + e2.z * e3,\n e1.w * (1 - e3) + e2.w * e3,\n );\n }\n return vec4h(\n e1.x * (1 - e3.x) + e2.x * e3.x,\n e1.y * (1 - e3.y) + e2.y * e3.y,\n e1.z * (1 - e3.z) + e2.z * e3.z,\n e1.w * (1 - e3.w) + e2.w * e3.w,\n );\n },\n } as Record<\n 'vec2f' | 'vec3f' | 'vec4f' | 'vec2h' | 'vec3h' | 'vec4h',\n <T extends wgsl.v2f | wgsl.v3f | wgsl.v4f | wgsl.v2h | wgsl.v3h | wgsl.v4h>(\n a: T,\n b: T,\n c: T | number,\n ) => T\n >,\n};\n","import { VectorOps } from '../data/vectorOps';\nimport type {\n AnyMatInstance,\n VecKind,\n v2f,\n v2h,\n v3f,\n v3h,\n v3i,\n v3u,\n v4f,\n v4h,\n vBaseForMat,\n} from '../data/wgslTypes';\nimport { inGPUMode } from '../gpuMode';\n\ntype vBase = { kind: VecKind };\n\nexport function add<T extends vBase>(lhs: T, rhs: T): T {\n if (inGPUMode()) {\n return `(${lhs} + ${rhs})` as unknown as T;\n }\n return VectorOps.add[lhs.kind](lhs, rhs);\n}\n\nexport function sub<T extends vBase>(lhs: T, rhs: T): T {\n if (inGPUMode()) {\n return `(${lhs} - ${rhs})` as unknown as T;\n }\n return VectorOps.sub[lhs.kind](lhs, rhs);\n}\n\nexport function mul<T extends AnyMatInstance, TVec extends vBaseForMat<T>>(\n s: T,\n v: TVec,\n): TVec;\nexport function mul<T extends AnyMatInstance, TVec extends vBaseForMat<T>>(\n s: TVec,\n v: T,\n): TVec;\nexport function mul<T extends vBase | AnyMatInstance>(s: number | T, v: T): T;\nexport function mul(\n s: vBase | AnyMatInstance | number,\n v: vBase | AnyMatInstance,\n): vBase | AnyMatInstance {\n if (inGPUMode()) {\n return `(${s} * ${v})` as unknown as vBase | AnyMatInstance;\n }\n if (typeof s === 'number') {\n // Scalar * Vector/Matrix case\n return VectorOps.mulSxV[v.kind](s, v);\n }\n if (\n typeof s === 'object' &&\n typeof v === 'object' &&\n 'kind' in s &&\n 'kind' in v\n ) {\n const sIsVector = !s.kind.startsWith('mat');\n const vIsVector = !v.kind.startsWith('mat');\n if (!sIsVector && vIsVector) {\n // Matrix * Vector case\n return VectorOps.mulMxV[(s as AnyMatInstance).kind](\n s as AnyMatInstance,\n v as vBaseForMat<AnyMatInstance>,\n );\n }\n if (sIsVector && !vIsVector) {\n // Vector * Matrix case\n return VectorOps.mulVxM[(v as AnyMatInstance).kind](\n s as vBaseForMat<AnyMatInstance>,\n v as AnyMatInstance,\n );\n }\n }\n // Vector * Vector or Matrix * Matrix case\n return VectorOps.mulVxV[v.kind](s, v);\n}\n\nexport function abs<T extends vBase | number>(value: T): T {\n if (inGPUMode()) {\n return `abs(${value})` as unknown as T;\n }\n if (typeof value === 'number') {\n return Math.abs(value) as T;\n }\n return VectorOps.abs[value.kind](value) as T;\n}\n\n/**\n * @privateRemarks\n * https://www.w3.org/TR/WGSL/#ceil-builtin\n */\nexport function ceil<T extends vBase | number>(value: T): T {\n if (inGPUMode()) {\n return `ceil(${value})` as unknown as T;\n }\n if (typeof value === 'number') {\n return Math.ceil(value) as T;\n }\n return VectorOps.ceil[value.kind](value) as T;\n}\n\n/**\n * @privateRemarks\n * https://www.w3.org/TR/WGSL/#clamp\n */\nexport function clamp<T extends vBase | number>(value: T, low: T, high: T): T {\n if (inGPUMode()) {\n return `clamp(${value}, ${low}, ${high})` as unknown as T;\n }\n if (typeof value === 'number') {\n return Math.min(Math.max(low as number, value), high as number) as T;\n }\n return VectorOps.clamp[value.kind](value, low as vBase, high as vBase) as T;\n}\n\n// TODO: Accept vectors into `cos`\n/**\n * @privateRemarks\n * https://www.w3.org/TR/WGSL/#cos-builtin\n */\nexport function cos(radians: number): number {\n if (inGPUMode()) {\n return `cos(${radians})` as unknown as number;\n }\n return Math.cos(radians);\n}\n\n/**\n * @privateRemarks\n * https://www.w3.org/TR/WGSL/#cross-builtin\n */\nexport function cross<T extends v3f | v3i | v3u>(a: T, b: T): T {\n if (inGPUMode()) {\n return `cross(${a}, ${b})` as unknown as T;\n }\n return VectorOps.cross[a.kind](a, b);\n}\n\n/**\n * @privateRemarks\n * https://www.w3.org/TR/WGSL/#dot-builtin\n */\nexport function dot<T extends vBase>(lhs: T, rhs: T): number {\n if (inGPUMode()) {\n return `dot(${lhs}, ${rhs})` as unknown as number;\n }\n return VectorOps.dot[lhs.kind](lhs, rhs);\n}\n\nexport function normalize<T extends vBase>(v: T): T {\n if (inGPUMode()) {\n return `normalize(${v})` as unknown as T;\n }\n return VectorOps.normalize[v.kind](v);\n}\n\n/**\n * @privateRemarks\n * https://www.w3.org/TR/WGSL/#floor-builtin\n */\nexport function floor<T extends vBase | number>(value: T): T {\n if (inGPUMode()) {\n return `floor(${value})` as unknown as T;\n }\n if (typeof value === 'number') {\n return Math.floor(value) as T;\n }\n return VectorOps.floor[value.kind](value) as T;\n}\n\nexport function fract(a: number): number {\n if (inGPUMode()) {\n return `fract(${a})` as unknown as number;\n }\n return a - Math.floor(a);\n}\n\n/**\n * @privateRemarks\n * https://www.w3.org/TR/WGSL/#length-builtin\n */\nexport function length<T extends vBase | number>(value: T): number {\n if (inGPUMode()) {\n return `length(${value})` as unknown as number;\n }\n if (typeof value === 'number') {\n return Math.abs(value);\n }\n return VectorOps.length[value.kind](value);\n}\n\n/**\n * @privateRemarks\n * https://www.w3.org/TR/WGSL/#max-float-builtin\n */\nexport function max<T extends vBase | number>(a: T, b: T): T {\n if (inGPUMode()) {\n return `max(${a}, ${b})` as unknown as T;\n }\n if (typeof a === 'number') {\n return Math.max(a, b as number) as T;\n }\n return VectorOps.max[a.kind](a, b as vBase) as T;\n}\n\n/**\n * @privateRemarks\n * https://www.w3.org/TR/WGSL/#min-float-builtin\n */\nexport function min<T extends vBase | number>(a: T, b: T): T {\n if (inGPUMode()) {\n return `min(${a}, ${b})` as unknown as T;\n }\n if (typeof a === 'number') {\n return Math.min(a, b as number) as T;\n }\n return VectorOps.min[a.kind](a, b as vBase) as T;\n}\n\nexport function sin(radians: number): number {\n if (inGPUMode()) {\n return `sin(${radians})` as unknown as number;\n }\n return Math.sin(radians);\n}\n\nexport function exp(value: number): number {\n if (inGPUMode()) {\n return `exp(${value})` as unknown as number;\n }\n return Math.exp(value);\n}\n\nexport function pow(base: number, exponent: number): number;\nexport function pow<T extends v2f | v3f | v4f | v2h | v3h | v4h>(\n base: T,\n exponent: T,\n): T;\nexport function pow<T extends v2f | v3f | v4f | v2h | v3h | v4h | number>(\n base: T,\n exponent: T,\n): T {\n if (inGPUMode()) {\n return `pow(${base}, ${exponent})` as unknown as T;\n }\n if (typeof base === 'number' && typeof exponent === 'number') {\n return (base ** exponent) as T;\n }\n if (\n typeof base === 'object' &&\n typeof exponent === 'object' &&\n 'kind' in base &&\n 'kind' in exponent\n ) {\n return VectorOps.pow[base.kind](base, exponent) as T;\n }\n throw new Error('Invalid arguments to pow()');\n}\n\nexport function mix(e1: number, e2: number, e3: number): number;\nexport function mix<T extends v2f | v3f | v4f | v2h | v3h | v4h>(\n e1: T,\n e2: T,\n e3: number,\n): T;\nexport function mix<T extends v2f | v3f | v4f | v2h | v3h | v4h>(\n e1: T,\n e2: T,\n e3: T,\n): T;\n\nexport function mix<T extends v2f | v3f | v4f | v2h | v3h | v4h | number>(\n e1: T,\n e2: T,\n e3: T | number,\n): T {\n if (inGPUMode()) {\n return `mix(${e1}, ${e2}, ${e3})` as unknown as T;\n }\n\n if (typeof e1 === 'number') {\n if (typeof e3 !== 'number' || typeof e2 !== 'number') {\n throw new Error(\n 'When e1 and e2 are numbers, the blend factor must be a number.',\n );\n }\n return (e1 * (1 - e3) + e2 * e3) as T;\n }\n\n if (typeof e1 === 'number' || typeof e2 === 'number') {\n throw new Error('e1 and e2 need to both be vectors of the same kind.');\n }\n\n return VectorOps.mix[e1.kind](e1, e2, e3) as T;\n}\n"],"mappings":"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G,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAChBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAClBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EACdD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAChBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAChBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAElBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EACdD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAChBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAChBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAClBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EACdD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAChBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAChBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAClBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EACdD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAChBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAChBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAClBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EACdD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAChBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAChBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAElBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EACdD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAChBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAChBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAClBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EACdD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAChBD,EAAG,C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","names":["lengthVec2","v","lengthVec3","lengthVec4","dotVec2","lhs","rhs","dotVec3","dotVec4","clamp","value","low","high","VectorOps","vec2f","vec2h","vec2i","vec2u","vec3f","vec3h","vec3i","vec3u","vec4f","vec4h","vec4i","vec4u","a","b","m","m_","mat2x2f","mat3x3f","mat4x4f","a_","b_","len","base","exponent","e1","e2","e3","add","lhs","rhs","inGPUMode","VectorOps","sub","mul","v","sIsVector","vIsVector","abs","value","ceil","clamp","low","high","cos","radians","cross","a","b","dot","normalize","floor","fract","length","max","min","sin","exp","pow","base","exponent","mix","e1","e2","e3"]}
|
1
|
+
{"version":3,"sources":["../../src/std/discard.ts","../../src/data/vectorOps.ts","../../src/std/numeric.ts","../../src/std/atomic.ts"],"sourcesContent":["import { inGPUMode } from '../gpuMode.js';\n\nexport function discard(): never {\n if (!inGPUMode()) {\n throw new Error('discard() can only be used on the GPU.');\n }\n return 'discard;' as never;\n}\n","import { mat2x2f, mat3x3f, mat4x4f } from './matrix';\nimport {\n vec2f,\n vec2h,\n vec2i,\n vec2u,\n vec3f,\n vec3h,\n vec3i,\n vec3u,\n vec4f,\n vec4h,\n vec4i,\n vec4u,\n} from './vector';\nimport type * as wgsl from './wgslTypes';\nimport type { VecKind } from './wgslTypes';\n\ntype vBase = { kind: VecKind };\ntype v2 = wgsl.v2f | wgsl.v2h | wgsl.v2i | wgsl.v2u;\ntype v3 = wgsl.v3f | wgsl.v3h | wgsl.v3i | wgsl.v3u;\ntype v4 = wgsl.v4f | wgsl.v4h | wgsl.v4i | wgsl.v4u;\n\ntype MatKind = 'mat2x2f' | 'mat3x3f' | 'mat4x4f';\n\nconst lengthVec2 = (v: v2) => Math.sqrt(v.x ** 2 + v.y ** 2);\nconst lengthVec3 = (v: v3) => Math.sqrt(v.x ** 2 + v.y ** 2 + v.z ** 2);\nconst lengthVec4 = (v: v4) =>\n Math.sqrt(v.x ** 2 + v.y ** 2 + v.z ** 2 + v.w ** 2);\n\nconst dotVec2 = (lhs: v2, rhs: v2) => lhs.x * rhs.x + lhs.y * rhs.y;\nconst dotVec3 = (lhs: v3, rhs: v3) =>\n lhs.x * rhs.x + lhs.y * rhs.y + lhs.z * rhs.z;\nconst dotVec4 = (lhs: v4, rhs: v4) =>\n lhs.x * rhs.x + lhs.y * rhs.y + lhs.z * rhs.z + lhs.w * rhs.w;\n\nconst clamp = (value: number, low: number, high: number) =>\n Math.min(Math.max(low, value), high);\n\ntype UnaryOp = (a: number) => number;\ntype BinaryOp = (a: number, b: number) => number;\n\nconst unary2f = (op: UnaryOp) => (a: wgsl.v2f) => vec2f(op(a.x), op(a.y));\nconst unary2h = (op: UnaryOp) => (a: wgsl.v2h) => vec2h(op(a.x), op(a.y));\nconst unary2i = (op: UnaryOp) => (a: wgsl.v2i) => vec2i(op(a.x), op(a.y));\nconst unary2u = (op: UnaryOp) => (a: wgsl.v2u) => vec2u(op(a.x), op(a.y));\n\nconst unary3f = (op: UnaryOp) => (a: wgsl.v3f) =>\n vec3f(op(a.x), op(a.y), op(a.z));\n\nconst unary3h = (op: UnaryOp) => (a: wgsl.v3h) =>\n vec3h(op(a.x), op(a.y), op(a.z));\n\nconst unary3i = (op: UnaryOp) => (a: wgsl.v3i) =>\n vec3i(op(a.x), op(a.y), op(a.z));\n\nconst unary3u = (op: UnaryOp) => (a: wgsl.v3u) =>\n vec3u(op(a.x), op(a.y), op(a.z));\n\nconst unary4f = (op: UnaryOp) => (a: wgsl.v4f) =>\n vec4f(op(a.x), op(a.y), op(a.z), op(a.w));\n\nconst unary4h = (op: UnaryOp) => (a: wgsl.v4h) =>\n vec4h(op(a.x), op(a.y), op(a.z), op(a.w));\n\nconst unary4i = (op: UnaryOp) => (a: wgsl.v4i) =>\n vec4i(op(a.x), op(a.y), op(a.z), op(a.w));\n\nconst unary4u = (op: UnaryOp) => (a: wgsl.v4u) =>\n vec4u(op(a.x), op(a.y), op(a.z), op(a.w));\n\nconst binaryComponentWise2f = (op: BinaryOp) => (a: wgsl.v2f, b: wgsl.v2f) =>\n vec2f(op(a.x, b.x), op(a.y, b.y));\n\nconst binaryComponentWise2h = (op: BinaryOp) => (a: wgsl.v2h, b: wgsl.v2h) =>\n vec2h(op(a.x, b.x), op(a.y, b.y));\n\nconst binaryComponentWise2i = (op: BinaryOp) => (a: wgsl.v2i, b: wgsl.v2i) =>\n vec2i(op(a.x, b.x), op(a.y, b.y));\n\nconst binaryComponentWise2u = (op: BinaryOp) => (a: wgsl.v2u, b: wgsl.v2u) =>\n vec2u(op(a.x, b.x), op(a.y, b.y));\n\nconst binaryComponentWise3f = (op: BinaryOp) => (a: wgsl.v3f, b: wgsl.v3f) =>\n vec3f(op(a.x, b.x), op(a.y, b.y), op(a.z, b.z));\n\nconst binaryComponentWise3h = (op: BinaryOp) => (a: wgsl.v3h, b: wgsl.v3h) =>\n vec3h(op(a.x, b.x), op(a.y, b.y), op(a.z, b.z));\n\nconst binaryComponentWise3i = (op: BinaryOp) => (a: wgsl.v3i, b: wgsl.v3i) =>\n vec3i(op(a.x, b.x), op(a.y, b.y), op(a.z, b.z));\n\nconst binaryComponentWise3u = (op: BinaryOp) => (a: wgsl.v3u, b: wgsl.v3u) =>\n vec3u(op(a.x, b.x), op(a.y, b.y), op(a.z, b.z));\n\nconst binaryComponentWise4f = (op: BinaryOp) => (a: wgsl.v4f, b: wgsl.v4f) =>\n vec4f(op(a.x, b.x), op(a.y, b.y), op(a.z, b.z), op(a.w, b.w));\n\nconst binaryComponentWise4h = (op: BinaryOp) => (a: wgsl.v4h, b: wgsl.v4h) =>\n vec4h(op(a.x, b.x), op(a.y, b.y), op(a.z, b.z), op(a.w, b.w));\n\nconst binaryComponentWise4i = (op: BinaryOp) => (a: wgsl.v4i, b: wgsl.v4i) =>\n vec4i(op(a.x, b.x), op(a.y, b.y), op(a.z, b.z), op(a.w, b.w));\n\nconst binaryComponentWise4u = (op: BinaryOp) => (a: wgsl.v4u, b: wgsl.v4u) =>\n vec4u(op(a.x, b.x), op(a.y, b.y), op(a.z, b.z), op(a.w, b.w));\n\nexport const VectorOps = {\n abs: {\n vec2f: unary2f(Math.abs),\n vec2h: unary2h(Math.abs),\n vec2i: unary2i(Math.abs),\n vec2u: unary2u(Math.abs),\n\n vec3f: unary3f(Math.abs),\n vec3h: unary3h(Math.abs),\n vec3i: unary3i(Math.abs),\n vec3u: unary3u(Math.abs),\n\n vec4f: unary4f(Math.abs),\n vec4h: unary4h(Math.abs),\n vec4i: unary4i(Math.abs),\n vec4u: unary4u(Math.abs),\n } as Record<VecKind, <T extends vBase>(v: T) => T>,\n\n atan2: {\n vec2f: binaryComponentWise2f(Math.atan2),\n vec2h: binaryComponentWise2h(Math.atan2),\n vec2i: binaryComponentWise2i(Math.atan2),\n vec2u: binaryComponentWise2u(Math.atan2),\n\n vec3f: binaryComponentWise3f(Math.atan2),\n vec3h: binaryComponentWise3h(Math.atan2),\n vec3i: binaryComponentWise3i(Math.atan2),\n vec3u: binaryComponentWise3u(Math.atan2),\n\n vec4f: binaryComponentWise4f(Math.atan2),\n vec4h: binaryComponentWise4h(Math.atan2),\n vec4i: binaryComponentWise4i(Math.atan2),\n vec4u: binaryComponentWise4u(Math.atan2),\n } as Record<VecKind, <T extends vBase>(a: T, b: T) => T>,\n\n ceil: {\n vec2f: unary2f(Math.ceil),\n vec2h: unary2h(Math.ceil),\n vec2i: unary2i(Math.ceil),\n vec2u: unary2u(Math.ceil),\n\n vec3f: unary3f(Math.ceil),\n vec3h: unary3h(Math.ceil),\n vec3i: unary3i(Math.ceil),\n vec3u: unary3u(Math.ceil),\n\n vec4f: unary4f(Math.ceil),\n vec4h: unary4h(Math.ceil),\n vec4i: unary4i(Math.ceil),\n vec4u: unary4u(Math.ceil),\n } as Record<VecKind, <T extends vBase>(v: T) => T>,\n\n clamp: {\n vec2f: (v: wgsl.v2f, low: wgsl.v2f, high: wgsl.v2f) =>\n vec2f(clamp(v.x, low.x, high.x), clamp(v.y, low.y, high.y)),\n vec2h: (v: wgsl.v2h, low: wgsl.v2h, high: wgsl.v2h) =>\n vec2h(clamp(v.x, low.x, high.x), clamp(v.y, low.y, high.y)),\n vec2i: (v: wgsl.v2i, low: wgsl.v2i, high: wgsl.v2i) =>\n vec2i(clamp(v.x, low.x, high.x), clamp(v.y, low.y, high.y)),\n vec2u: (v: wgsl.v2u, low: wgsl.v2u, high: wgsl.v2u) =>\n vec2u(clamp(v.x, low.x, high.x), clamp(v.y, low.y, high.y)),\n\n vec3f: (v: wgsl.v3f, low: wgsl.v3f, high: wgsl.v3f) =>\n vec3f(\n clamp(v.x, low.x, high.x),\n clamp(v.y, low.y, high.y),\n clamp(v.z, low.z, high.z),\n ),\n vec3h: (v: wgsl.v3h, low: wgsl.v3h, high: wgsl.v3h) =>\n vec3h(\n clamp(v.x, low.x, high.x),\n clamp(v.y, low.y, high.y),\n clamp(v.z, low.z, high.z),\n ),\n vec3i: (v: wgsl.v3i, low: wgsl.v3i, high: wgsl.v3f) =>\n vec3i(\n clamp(v.x, low.x, high.x),\n clamp(v.y, low.y, high.y),\n clamp(v.z, low.z, high.z),\n ),\n vec3u: (v: wgsl.v3u, low: wgsl.v3u, high: wgsl.v3f) =>\n vec3u(\n clamp(v.x, low.x, high.x),\n clamp(v.y, low.y, high.y),\n clamp(v.z, low.z, high.z),\n ),\n\n vec4f: (v: wgsl.v4f, low: wgsl.v4f, high: wgsl.v4f) =>\n vec4f(\n clamp(v.x, low.x, high.x),\n clamp(v.y, low.y, high.y),\n clamp(v.z, low.z, high.z),\n clamp(v.w, low.w, high.w),\n ),\n vec4h: (v: wgsl.v4h, low: wgsl.v4h, high: wgsl.v4h) =>\n vec4h(\n clamp(v.x, low.x, high.x),\n clamp(v.y, low.y, high.y),\n clamp(v.z, low.z, high.z),\n clamp(v.w, low.w, high.w),\n ),\n vec4i: (v: wgsl.v4i, low: wgsl.v4i, high: wgsl.v4i) =>\n vec4i(\n clamp(v.x, low.x, high.x),\n clamp(v.y, low.y, high.y),\n clamp(v.z, low.z, high.z),\n clamp(v.w, low.w, high.w),\n ),\n vec4u: (v: wgsl.v4u, low: wgsl.v4u, high: wgsl.v4u) =>\n vec4u(\n clamp(v.x, low.x, high.x),\n clamp(v.y, low.y, high.y),\n clamp(v.z, low.z, high.z),\n clamp(v.w, low.w, high.w),\n ),\n } as Record<VecKind, <T extends vBase>(v: T, low: T, high: T) => T>,\n\n length: {\n vec2f: lengthVec2,\n vec2h: lengthVec2,\n vec2i: lengthVec2,\n vec2u: lengthVec2,\n vec3f: lengthVec3,\n vec3h: lengthVec3,\n vec3i: lengthVec3,\n vec3u: lengthVec3,\n vec4f: lengthVec4,\n vec4h: lengthVec4,\n vec4i: lengthVec4,\n vec4u: lengthVec4,\n } as Record<VecKind, (v: vBase) => number>,\n\n add: {\n vec2f: (a: wgsl.v2f, b: wgsl.v2f) => vec2f(a.x + b.x, a.y + b.y),\n vec2h: (a: wgsl.v2h, b: wgsl.v2h) => vec2h(a.x + b.x, a.y + b.y),\n vec2i: (a: wgsl.v2i, b: wgsl.v2i) => vec2i(a.x + b.x, a.y + b.y),\n vec2u: (a: wgsl.v2u, b: wgsl.v2u) => vec2u(a.x + b.x, a.y + b.y),\n\n vec3f: (a: wgsl.v3f, b: wgsl.v3f) => vec3f(a.x + b.x, a.y + b.y, a.z + b.z),\n vec3h: (a: wgsl.v3h, b: wgsl.v3h) => vec3h(a.x + b.x, a.y + b.y, a.z + b.z),\n vec3i: (a: wgsl.v3i, b: wgsl.v3i) => vec3i(a.x + b.x, a.y + b.y, a.z + b.z),\n vec3u: (a: wgsl.v3u, b: wgsl.v3u) => vec3u(a.x + b.x, a.y + b.y, a.z + b.z),\n\n vec4f: (a: wgsl.v4f, b: wgsl.v4f) =>\n vec4f(a.x + b.x, a.y + b.y, a.z + b.z, a.w + b.w),\n vec4h: (a: wgsl.v4h, b: wgsl.v4h) =>\n vec4h(a.x + b.x, a.y + b.y, a.z + b.z, a.w + b.w),\n vec4i: (a: wgsl.v4i, b: wgsl.v4i) =>\n vec4i(a.x + b.x, a.y + b.y, a.z + b.z, a.w + b.w),\n vec4u: (a: wgsl.v4u, b: wgsl.v4u) =>\n vec4u(a.x + b.x, a.y + b.y, a.z + b.z, a.w + b.w),\n } as Record<VecKind, <T extends vBase>(lhs: T, rhs: T) => T>,\n\n sub: {\n vec2f: (a: wgsl.v2f, b: wgsl.v2f) => vec2f(a.x - b.x, a.y - b.y),\n vec2h: (a: wgsl.v2h, b: wgsl.v2h) => vec2h(a.x - b.x, a.y - b.y),\n vec2i: (a: wgsl.v2i, b: wgsl.v2i) => vec2i(a.x - b.x, a.y - b.y),\n vec2u: (a: wgsl.v2u, b: wgsl.v2u) => vec2u(a.x - b.x, a.y - b.y),\n\n vec3f: (a: wgsl.v3f, b: wgsl.v3f) => vec3f(a.x - b.x, a.y - b.y, a.z - b.z),\n vec3h: (a: wgsl.v3h, b: wgsl.v3h) => vec3h(a.x - b.x, a.y - b.y, a.z - b.z),\n vec3i: (a: wgsl.v3i, b: wgsl.v3i) => vec3i(a.x - b.x, a.y - b.y, a.z - b.z),\n vec3u: (a: wgsl.v3u, b: wgsl.v3u) => vec3u(a.x - b.x, a.y - b.y, a.z - b.z),\n\n vec4f: (a: wgsl.v4f, b: wgsl.v4f) =>\n vec4f(a.x - b.x, a.y - b.y, a.z - b.z, a.w - b.w),\n vec4h: (a: wgsl.v4h, b: wgsl.v4h) =>\n vec4h(a.x - b.x, a.y - b.y, a.z - b.z, a.w - b.w),\n vec4i: (a: wgsl.v4i, b: wgsl.v4i) =>\n vec4i(a.x - b.x, a.y - b.y, a.z - b.z, a.w - b.w),\n vec4u: (a: wgsl.v4u, b: wgsl.v4u) =>\n vec4u(a.x - b.x, a.y - b.y, a.z - b.z, a.w - b.w),\n } as Record<VecKind, <T extends vBase>(lhs: T, rhs: T) => T>,\n\n mulSxV: {\n vec2f: (s: number, v: wgsl.v2f) => vec2f(s * v.x, s * v.y),\n vec2h: (s: number, v: wgsl.v2h) => vec2h(s * v.x, s * v.y),\n vec2i: (s: number, v: wgsl.v2i) => vec2i(s * v.x, s * v.y),\n vec2u: (s: number, v: wgsl.v2u) => vec2u(s * v.x, s * v.y),\n\n vec3f: (s: number, v: wgsl.v3f) => vec3f(s * v.x, s * v.y, s * v.z),\n vec3h: (s: number, v: wgsl.v3h) => vec3h(s * v.x, s * v.y, s * v.z),\n vec3i: (s: number, v: wgsl.v3i) => vec3i(s * v.x, s * v.y, s * v.z),\n vec3u: (s: number, v: wgsl.v3u) => vec3u(s * v.x, s * v.y, s * v.z),\n\n vec4f: (s: number, v: wgsl.v4f) =>\n vec4f(s * v.x, s * v.y, s * v.z, s * v.w),\n vec4h: (s: number, v: wgsl.v4h) =>\n vec4h(s * v.x, s * v.y, s * v.z, s * v.w),\n vec4i: (s: number, v: wgsl.v4i) =>\n vec4i(s * v.x, s * v.y, s * v.z, s * v.w),\n vec4u: (s: number, v: wgsl.v4u) =>\n vec4u(s * v.x, s * v.y, s * v.z, s * v.w),\n\n mat2x2f: (s: number, m: wgsl.m2x2f) => {\n const m_ = m.columns as [wgsl.v2f, wgsl.v2f];\n return mat2x2f(s * m_[0].x, s * m_[0].y, s * m_[1].x, s * m_[1].y);\n },\n\n mat3x3f: (s: number, m: wgsl.m3x3f) => {\n const m_ = m.columns as [wgsl.v3f, wgsl.v3f, wgsl.v3f];\n return mat3x3f(\n s * m_[0].x,\n s * m_[0].y,\n s * m_[0].z,\n\n s * m_[1].x,\n s * m_[1].y,\n s * m_[1].z,\n\n s * m_[2].x,\n s * m_[2].y,\n s * m_[2].z,\n );\n },\n\n mat4x4f: (s: number, m: wgsl.m4x4f) => {\n const m_ = m.columns as [wgsl.v4f, wgsl.v4f, wgsl.v4f, wgsl.v4f];\n return mat4x4f(\n s * m_[0].x,\n s * m_[0].y,\n s * m_[0].z,\n s * m_[0].w,\n\n s * m_[1].x,\n s * m_[1].y,\n s * m_[1].z,\n s * m_[1].w,\n\n s * m_[2].x,\n s * m_[2].y,\n s * m_[2].z,\n s * m_[2].w,\n\n s * m_[3].x,\n s * m_[3].y,\n s * m_[3].z,\n s * m_[3].w,\n );\n },\n } as Record<\n VecKind | MatKind,\n <T extends vBase | wgsl.AnyMatInstance>(s: number, v: T) => T\n >,\n\n mulVxV: {\n vec2f: (a: wgsl.v2f, b: wgsl.v2f) => vec2f(a.x * b.x, a.y * b.y),\n vec2h: (a: wgsl.v2h, b: wgsl.v2h) => vec2h(a.x * b.x, a.y * b.y),\n vec2i: (a: wgsl.v2i, b: wgsl.v2i) => vec2i(a.x * b.x, a.y * b.y),\n vec2u: (a: wgsl.v2u, b: wgsl.v2u) => vec2u(a.x * b.x, a.y * b.y),\n\n vec3f: (a: wgsl.v3f, b: wgsl.v3f) => vec3f(a.x * b.x, a.y * b.y, a.z * b.z),\n vec3h: (a: wgsl.v3h, b: wgsl.v3h) => vec3h(a.x * b.x, a.y * b.y, a.z * b.z),\n vec3i: (a: wgsl.v3i, b: wgsl.v3i) => vec3i(a.x * b.x, a.y * b.y, a.z * b.z),\n vec3u: (a: wgsl.v3u, b: wgsl.v3u) => vec3u(a.x * b.x, a.y * b.y, a.z * b.z),\n\n vec4f: (a: wgsl.v4f, b: wgsl.v4f) =>\n vec4f(a.x * b.x, a.y * b.y, a.z * b.z, a.w * b.w),\n vec4h: (a: wgsl.v4h, b: wgsl.v4h) =>\n vec4h(a.x * b.x, a.y * b.y, a.z * b.z, a.w * b.w),\n vec4i: (a: wgsl.v4i, b: wgsl.v4i) =>\n vec4i(a.x * b.x, a.y * b.y, a.z * b.z, a.w * b.w),\n vec4u: (a: wgsl.v4u, b: wgsl.v4u) =>\n vec4u(a.x * b.x, a.y * b.y, a.z * b.z, a.w * b.w),\n\n mat2x2f: (a: wgsl.m2x2f, b: wgsl.m2x2f) => {\n const a_ = a.columns as [wgsl.v2f, wgsl.v2f];\n const b_ = b.columns as [wgsl.v2f, wgsl.v2f];\n\n return mat2x2f(\n a_[0].x * b_[0].x + a_[1].x * b_[0].y,\n a_[0].y * b_[0].x + a_[1].y * b_[0].y,\n\n a_[0].x * b_[1].x + a_[1].x * b_[1].y,\n a_[0].y * b_[1].x + a_[1].y * b_[1].y,\n );\n },\n\n mat3x3f: (a: wgsl.m3x3f, b: wgsl.m3x3f) => {\n const a_ = a.columns as [wgsl.v3f, wgsl.v3f, wgsl.v3f];\n const b_ = b.columns as [wgsl.v3f, wgsl.v3f, wgsl.v3f];\n\n return mat3x3f(\n a_[0].x * b_[0].x + a_[1].x * b_[0].y + a_[2].x * b_[0].z,\n a_[0].y * b_[0].x + a_[1].y * b_[0].y + a_[2].y * b_[0].z,\n a_[0].z * b_[0].x + a_[1].z * b_[0].y + a_[2].z * b_[0].z,\n\n a_[0].x * b_[1].x + a_[1].x * b_[1].y + a_[2].x * b_[1].z,\n a_[0].y * b_[1].x + a_[1].y * b_[1].y + a_[2].y * b_[1].z,\n a_[0].z * b_[1].x + a_[1].z * b_[1].y + a_[2].z * b_[1].z,\n\n a_[0].x * b_[2].x + a_[1].x * b_[2].y + a_[2].x * b_[2].z,\n a_[0].y * b_[2].x + a_[1].y * b_[2].y + a_[2].y * b_[2].z,\n a_[0].z * b_[2].x + a_[1].z * b_[2].y + a_[2].z * b_[2].z,\n );\n },\n\n mat4x4f: (a: wgsl.m4x4f, b: wgsl.m4x4f) => {\n const a_ = a.columns as [wgsl.v4f, wgsl.v4f, wgsl.v4f, wgsl.v4f];\n const b_ = b.columns as [wgsl.v4f, wgsl.v4f, wgsl.v4f, wgsl.v4f];\n\n return mat4x4f(\n a_[0].x * b_[0].x +\n a_[1].x * b_[0].y +\n a_[2].x * b_[0].z +\n a_[3].x * b_[0].w,\n a_[0].y * b_[0].x +\n a_[1].y * b_[0].y +\n a_[2].y * b_[0].z +\n a_[3].y * b_[0].w,\n a_[0].z * b_[0].x +\n a_[1].z * b_[0].y +\n a_[2].z * b_[0].z +\n a_[3].z * b_[0].w,\n a_[0].w * b_[0].x +\n a_[1].w * b_[0].y +\n a_[2].w * b_[0].z +\n a_[3].w * b_[0].w,\n\n a_[0].x * b_[1].x +\n a_[1].x * b_[1].y +\n a_[2].x * b_[1].z +\n a_[3].x * b_[1].w,\n a_[0].y * b_[1].x +\n a_[1].y * b_[1].y +\n a_[2].y * b_[1].z +\n a_[3].y * b_[1].w,\n a_[0].z * b_[1].x +\n a_[1].z * b_[1].y +\n a_[2].z * b_[1].z +\n a_[3].z * b_[1].w,\n a_[0].w * b_[1].x +\n a_[1].w * b_[1].y +\n a_[2].w * b_[1].z +\n a_[3].w * b_[1].w,\n\n a_[0].x * b_[2].x +\n a_[1].x * b_[2].y +\n a_[2].x * b_[2].z +\n a_[3].x * b_[2].w,\n a_[0].y * b_[2].x +\n a_[1].y * b_[2].y +\n a_[2].y * b_[2].z +\n a_[3].y * b_[2].w,\n a_[0].z * b_[2].x +\n a_[1].z * b_[2].y +\n a_[2].z * b_[2].z +\n a_[3].z * b_[2].w,\n a_[0].w * b_[2].x +\n a_[1].w * b_[2].y +\n a_[2].w * b_[2].z +\n a_[3].w * b_[2].w,\n\n a_[0].x * b_[3].x +\n a_[1].x * b_[3].y +\n a_[2].x * b_[3].z +\n a_[3].x * b_[3].w,\n a_[0].y * b_[3].x +\n a_[1].y * b_[3].y +\n a_[2].y * b_[3].z +\n a_[3].y * b_[3].w,\n a_[0].z * b_[3].x +\n a_[1].z * b_[3].y +\n a_[2].z * b_[3].z +\n a_[3].z * b_[3].w,\n a_[0].w * b_[3].x +\n a_[1].w * b_[3].y +\n a_[2].w * b_[3].z +\n a_[3].w * b_[3].w,\n );\n },\n } as Record<\n VecKind | MatKind,\n <T extends vBase | wgsl.AnyMatInstance>(lhs: T, rhs: T) => T\n >,\n\n mulMxV: {\n mat2x2f: (m: wgsl.m2x2f, v: wgsl.v2f) => {\n const m_ = m.columns as [wgsl.v2f, wgsl.v2f];\n return vec2f(\n m_[0].x * v.x + m_[1].x * v.y,\n m_[0].y * v.x + m_[1].y * v.y,\n );\n },\n\n mat3x3f: (m: wgsl.m3x3f, v: wgsl.v3f) => {\n const m_ = m.columns as [wgsl.v3f, wgsl.v3f, wgsl.v3f];\n return vec3f(\n m_[0].x * v.x + m_[1].x * v.y + m_[2].x * v.z,\n m_[0].y * v.x + m_[1].y * v.y + m_[2].y * v.z,\n m_[0].z * v.x + m_[1].z * v.y + m_[2].z * v.z,\n );\n },\n\n mat4x4f: (m: wgsl.m4x4f, v: wgsl.v4f) => {\n const m_ = m.columns as [wgsl.v4f, wgsl.v4f, wgsl.v4f, wgsl.v4f];\n return vec4f(\n m_[0].x * v.x + m_[1].x * v.y + m_[2].x * v.z + m_[3].x * v.w,\n m_[0].y * v.x + m_[1].y * v.y + m_[2].y * v.z + m_[3].y * v.w,\n m_[0].z * v.x + m_[1].z * v.y + m_[2].z * v.z + m_[3].z * v.w,\n m_[0].w * v.x + m_[1].w * v.y + m_[2].w * v.z + m_[3].w * v.w,\n );\n },\n } as Record<\n MatKind,\n <T extends wgsl.AnyMatInstance>(\n m: T,\n v: wgsl.vBaseForMat<T>,\n ) => wgsl.vBaseForMat<T>\n >,\n\n mulVxM: {\n mat2x2f: (v: wgsl.v2f, m: wgsl.m2x2f) => {\n const m_ = m.columns as [wgsl.v2f, wgsl.v2f];\n return vec2f(\n v.x * m_[0].x + v.y * m_[0].y,\n v.x * m_[1].x + v.y * m_[1].y,\n );\n },\n\n mat3x3f: (v: wgsl.v3f, m: wgsl.m3x3f) => {\n const m_ = m.columns as [wgsl.v3f, wgsl.v3f, wgsl.v3f];\n return vec3f(\n v.x * m_[0].x + v.y * m_[0].y + v.z * m_[0].z,\n v.x * m_[1].x + v.y * m_[1].y + v.z * m_[1].z,\n v.x * m_[2].x + v.y * m_[2].y + v.z * m_[2].z,\n );\n },\n\n mat4x4f: (v: wgsl.v4f, m: wgsl.m4x4f) => {\n const m_ = m.columns as [wgsl.v4f, wgsl.v4f, wgsl.v4f, wgsl.v4f];\n return vec4f(\n v.x * m_[0].x + v.y * m_[0].y + v.z * m_[0].z + v.w * m_[0].w,\n v.x * m_[1].x + v.y * m_[1].y + v.z * m_[1].z + v.w * m_[1].w,\n v.x * m_[2].x + v.y * m_[2].y + v.z * m_[2].z + v.w * m_[2].w,\n v.x * m_[3].x + v.y * m_[3].y + v.z * m_[3].z + v.w * m_[3].w,\n );\n },\n } as Record<\n MatKind,\n <T extends wgsl.AnyMatInstance>(\n v: wgsl.vBaseForMat<T>,\n m: T,\n ) => wgsl.vBaseForMat<T>\n >,\n\n dot: {\n vec2f: dotVec2,\n vec2h: dotVec2,\n vec2i: dotVec2,\n vec2u: dotVec2,\n vec3f: dotVec3,\n vec3h: dotVec3,\n vec3i: dotVec3,\n vec3u: dotVec3,\n vec4f: dotVec4,\n vec4h: dotVec4,\n vec4i: dotVec4,\n vec4u: dotVec4,\n } as Record<VecKind, <T extends vBase>(lhs: T, rhs: T) => number>,\n\n normalize: {\n vec2f: (v: wgsl.v2f) => {\n const len = lengthVec2(v);\n return vec2f(v.x / len, v.y / len);\n },\n vec2h: (v: wgsl.v2h) => {\n const len = lengthVec2(v);\n return vec2h(v.x / len, v.y / len);\n },\n vec2i: (v: wgsl.v2i) => {\n const len = lengthVec2(v);\n return vec2i(v.x / len, v.y / len);\n },\n vec2u: (v: wgsl.v2u) => {\n const len = lengthVec2(v);\n return vec2u(v.x / len, v.y / len);\n },\n\n vec3f: (v: wgsl.v3f) => {\n const len = lengthVec3(v);\n return vec3f(v.x / len, v.y / len, v.z / len);\n },\n vec3h: (v: wgsl.v3h) => {\n const len = lengthVec3(v);\n return vec3h(v.x / len, v.y / len, v.z / len);\n },\n vec3i: (v: wgsl.v3i) => {\n const len = lengthVec3(v);\n return vec3i(v.x / len, v.y / len, v.z / len);\n },\n vec3u: (v: wgsl.v3u) => {\n const len = lengthVec3(v);\n return vec3u(v.x / len, v.y / len, v.z / len);\n },\n\n vec4f: (v: wgsl.v4f) => {\n const len = lengthVec4(v);\n return vec4f(v.x / len, v.y / len, v.z / len, v.w / len);\n },\n vec4h: (v: wgsl.v4h) => {\n const len = lengthVec4(v);\n return vec4h(v.x / len, v.y / len, v.z / len, v.w / len);\n },\n vec4i: (v: wgsl.v4i) => {\n const len = lengthVec4(v);\n return vec4i(v.x / len, v.y / len, v.z / len, v.w / len);\n },\n vec4u: (v: wgsl.v4u) => {\n const len = lengthVec4(v);\n return vec4u(v.x / len, v.y / len, v.z / len, v.w / len);\n },\n } as Record<VecKind, <T extends vBase>(v: T) => T>,\n\n cross: {\n vec3f: (a: wgsl.v3f, b: wgsl.v3f) => {\n return vec3f(\n a.y * b.z - a.z * b.y,\n a.z * b.x - a.x * b.z,\n a.x * b.y - a.y * b.x,\n );\n },\n vec3h: (a: wgsl.v3h, b: wgsl.v3h) => {\n return vec3h(\n a.y * b.z - a.z * b.y,\n a.z * b.x - a.x * b.z,\n a.x * b.y - a.y * b.x,\n );\n },\n vec3i: (a: wgsl.v3i, b: wgsl.v3i) => {\n return vec3i(\n a.y * b.z - a.z * b.y,\n a.z * b.x - a.x * b.z,\n a.x * b.y - a.y * b.x,\n );\n },\n vec3u: (a: wgsl.v3u, b: wgsl.v3u) => {\n return vec3u(\n a.y * b.z - a.z * b.y,\n a.z * b.x - a.x * b.z,\n a.x * b.y - a.y * b.x,\n );\n },\n } as Record<\n 'vec3f' | 'vec3i' | 'vec3u',\n <T extends wgsl.v3f | wgsl.v3i | wgsl.v3u>(a: T, b: T) => T\n >,\n\n floor: {\n vec2f: unary2f(Math.floor),\n vec2h: unary2h(Math.floor),\n vec2i: unary2i(Math.floor),\n vec2u: unary2u(Math.floor),\n\n vec3f: unary3f(Math.floor),\n vec3h: unary3h(Math.floor),\n vec3i: unary3i(Math.floor),\n vec3u: unary3u(Math.floor),\n\n vec4f: unary4f(Math.floor),\n vec4h: unary4h(Math.floor),\n vec4i: unary4i(Math.floor),\n vec4u: unary4u(Math.floor),\n } as Record<VecKind, <T extends vBase>(v: T) => T>,\n\n max: {\n vec2f: binaryComponentWise2f(Math.max),\n vec2h: binaryComponentWise2h(Math.max),\n vec2i: binaryComponentWise2i(Math.max),\n vec2u: binaryComponentWise2u(Math.max),\n\n vec3f: binaryComponentWise3f(Math.max),\n vec3h: binaryComponentWise3h(Math.max),\n vec3i: binaryComponentWise3i(Math.max),\n vec3u: binaryComponentWise3u(Math.max),\n\n vec4f: binaryComponentWise4f(Math.max),\n vec4h: binaryComponentWise4h(Math.max),\n vec4i: binaryComponentWise4i(Math.max),\n vec4u: binaryComponentWise4u(Math.max),\n } as Record<VecKind, <T extends vBase>(a: T, b: T) => T>,\n\n min: {\n vec2f: binaryComponentWise2f(Math.min),\n vec2h: binaryComponentWise2h(Math.min),\n vec2i: binaryComponentWise2i(Math.min),\n vec2u: binaryComponentWise2u(Math.min),\n\n vec3f: binaryComponentWise3f(Math.min),\n vec3h: binaryComponentWise3h(Math.min),\n vec3i: binaryComponentWise3i(Math.min),\n vec3u: binaryComponentWise3u(Math.min),\n\n vec4f: binaryComponentWise4f(Math.min),\n vec4h: binaryComponentWise4h(Math.min),\n vec4i: binaryComponentWise4i(Math.min),\n vec4u: binaryComponentWise4u(Math.min),\n } as Record<VecKind, <T extends vBase>(a: T, b: T) => T>,\n\n pow: {\n vec2f: (base: wgsl.v2f, exponent: wgsl.v2f) =>\n vec2f(base.x ** exponent.x, base.y ** exponent.y),\n vec2h: (base: wgsl.v2h, exponent: wgsl.v2h) =>\n vec2h(base.x ** exponent.x, base.y ** exponent.y),\n\n vec3f: (base: wgsl.v3f, exponent: wgsl.v3f) =>\n vec3f(base.x ** exponent.x, base.y ** exponent.y, base.z ** exponent.z),\n vec3h: (base: wgsl.v3h, exponent: wgsl.v3h) =>\n vec3h(base.x ** exponent.x, base.y ** exponent.y, base.z ** exponent.z),\n\n vec4f: (base: wgsl.v4f, exponent: wgsl.v4f) =>\n vec4f(\n base.x ** exponent.x,\n base.y ** exponent.y,\n base.z ** exponent.z,\n base.w ** exponent.w,\n ),\n vec4h: (base: wgsl.v4h, exponent: wgsl.v4h) =>\n vec4h(\n base.x ** exponent.x,\n base.y ** exponent.y,\n base.z ** exponent.z,\n base.w ** exponent.w,\n ),\n } as Record<\n 'vec2f' | 'vec3f' | 'vec4f' | 'vec2h' | 'vec3h' | 'vec4h' | 'number',\n <\n T extends\n | wgsl.v2f\n | wgsl.v3f\n | wgsl.v4f\n | wgsl.v2h\n | wgsl.v3h\n | wgsl.v4h\n | number,\n >(\n a: T,\n b: T,\n ) => T\n >,\n\n mix: {\n vec2f: (e1: wgsl.v2f, e2: wgsl.v2f, e3: wgsl.v2f | number) => {\n if (typeof e3 === 'number') {\n return vec2f(e1.x * (1 - e3) + e2.x * e3, e1.y * (1 - e3) + e2.y * e3);\n }\n return vec2f(\n e1.x * (1 - e3.x) + e2.x * e3.x,\n e1.y * (1 - e3.y) + e2.y * e3.y,\n );\n },\n vec2h: (e1: wgsl.v2h, e2: wgsl.v2h, e3: wgsl.v2h | number) => {\n if (typeof e3 === 'number') {\n return vec2h(e1.x * (1 - e3) + e2.x * e3, e1.y * (1 - e3) + e2.y * e3);\n }\n return vec2h(\n e1.x * (1 - e3.x) + e2.x * e3.x,\n e1.y * (1 - e3.y) + e2.y * e3.y,\n );\n },\n\n vec3f: (e1: wgsl.v3f, e2: wgsl.v3f, e3: wgsl.v3f | number) => {\n if (typeof e3 === 'number') {\n return vec3f(\n e1.x * (1 - e3) + e2.x * e3,\n e1.y * (1 - e3) + e2.y * e3,\n e1.z * (1 - e3) + e2.z * e3,\n );\n }\n return vec3f(\n e1.x * (1 - e3.x) + e2.x * e3.x,\n e1.y * (1 - e3.y) + e2.y * e3.y,\n e1.z * (1 - e3.z) + e2.z * e3.z,\n );\n },\n vec3h: (e1: wgsl.v3h, e2: wgsl.v3h, e3: wgsl.v3h | number) => {\n if (typeof e3 === 'number') {\n return vec3h(\n e1.x * (1 - e3) + e2.x * e3,\n e1.y * (1 - e3) + e2.y * e3,\n e1.z * (1 - e3) + e2.z * e3,\n );\n }\n return vec3h(\n e1.x * (1 - e3.x) + e2.x * e3.x,\n e1.y * (1 - e3.y) + e2.y * e3.y,\n e1.z * (1 - e3.z) + e2.z * e3.z,\n );\n },\n\n vec4f: (e1: wgsl.v4f, e2: wgsl.v4f, e3: wgsl.v4f | number) => {\n if (typeof e3 === 'number') {\n return vec4f(\n e1.x * (1 - e3) + e2.x * e3,\n e1.y * (1 - e3) + e2.y * e3,\n e1.z * (1 - e3) + e2.z * e3,\n e1.w * (1 - e3) + e2.w * e3,\n );\n }\n return vec4f(\n e1.x * (1 - e3.x) + e2.x * e3.x,\n e1.y * (1 - e3.y) + e2.y * e3.y,\n e1.z * (1 - e3.z) + e2.z * e3.z,\n e1.w * (1 - e3.w) + e2.w * e3.w,\n );\n },\n vec4h: (e1: wgsl.v4h, e2: wgsl.v4h, e3: wgsl.v4h | number) => {\n if (typeof e3 === 'number') {\n return vec4h(\n e1.x * (1 - e3) + e2.x * e3,\n e1.y * (1 - e3) + e2.y * e3,\n e1.z * (1 - e3) + e2.z * e3,\n e1.w * (1 - e3) + e2.w * e3,\n );\n }\n return vec4h(\n e1.x * (1 - e3.x) + e2.x * e3.x,\n e1.y * (1 - e3.y) + e2.y * e3.y,\n e1.z * (1 - e3.z) + e2.z * e3.z,\n e1.w * (1 - e3.w) + e2.w * e3.w,\n );\n },\n } as Record<\n 'vec2f' | 'vec3f' | 'vec4f' | 'vec2h' | 'vec3h' | 'vec4h',\n <T extends wgsl.v2f | wgsl.v3f | wgsl.v4f | wgsl.v2h | wgsl.v3h | wgsl.v4h>(\n a: T,\n b: T,\n c: T | number,\n ) => T\n >,\n};\n","import { VectorOps } from '../data/vectorOps';\nimport type {\n AnyMatInstance,\n VecKind,\n v2f,\n v2h,\n v3f,\n v3h,\n v3i,\n v3u,\n v4f,\n v4h,\n vBaseForMat,\n} from '../data/wgslTypes';\nimport { inGPUMode } from '../gpuMode';\n\ntype vBase = { kind: VecKind };\n\nexport function add<T extends vBase>(lhs: T, rhs: T): T {\n if (inGPUMode()) {\n return `(${lhs} + ${rhs})` as unknown as T;\n }\n return VectorOps.add[lhs.kind](lhs, rhs);\n}\n\nexport function sub<T extends vBase>(lhs: T, rhs: T): T {\n if (inGPUMode()) {\n return `(${lhs} - ${rhs})` as unknown as T;\n }\n return VectorOps.sub[lhs.kind](lhs, rhs);\n}\n\nexport function mul<T extends AnyMatInstance, TVec extends vBaseForMat<T>>(\n s: T,\n v: TVec,\n): TVec;\nexport function mul<T extends AnyMatInstance, TVec extends vBaseForMat<T>>(\n s: TVec,\n v: T,\n): TVec;\nexport function mul<T extends vBase | AnyMatInstance>(s: number | T, v: T): T;\nexport function mul(\n s: vBase | AnyMatInstance | number,\n v: vBase | AnyMatInstance,\n): vBase | AnyMatInstance {\n if (inGPUMode()) {\n return `(${s} * ${v})` as unknown as vBase | AnyMatInstance;\n }\n if (typeof s === 'number') {\n // Scalar * Vector/Matrix case\n return VectorOps.mulSxV[v.kind](s, v);\n }\n if (\n typeof s === 'object' &&\n typeof v === 'object' &&\n 'kind' in s &&\n 'kind' in v\n ) {\n const sIsVector = !s.kind.startsWith('mat');\n const vIsVector = !v.kind.startsWith('mat');\n if (!sIsVector && vIsVector) {\n // Matrix * Vector case\n return VectorOps.mulMxV[(s as AnyMatInstance).kind](\n s as AnyMatInstance,\n v as vBaseForMat<AnyMatInstance>,\n );\n }\n if (sIsVector && !vIsVector) {\n // Vector * Matrix case\n return VectorOps.mulVxM[(v as AnyMatInstance).kind](\n s as vBaseForMat<AnyMatInstance>,\n v as AnyMatInstance,\n );\n }\n }\n // Vector * Vector or Matrix * Matrix case\n return VectorOps.mulVxV[v.kind](s, v);\n}\n\nexport function abs<T extends vBase | number>(value: T): T {\n if (inGPUMode()) {\n return `abs(${value})` as unknown as T;\n }\n if (typeof value === 'number') {\n return Math.abs(value) as T;\n }\n return VectorOps.abs[value.kind](value) as T;\n}\n\nexport function atan2<T extends vBase | number>(y: T, x: T): T {\n if (inGPUMode()) {\n return `atan2(${y}, ${x})` as unknown as T;\n }\n if (typeof y === 'number' && typeof x === 'number') {\n return Math.atan2(y, x) as T;\n }\n return VectorOps.atan2[(y as vBase).kind](y as never, x as never) as T;\n}\n\n/**\n * @privateRemarks\n * https://www.w3.org/TR/WGSL/#ceil-builtin\n */\nexport function ceil<T extends vBase | number>(value: T): T {\n if (inGPUMode()) {\n return `ceil(${value})` as unknown as T;\n }\n if (typeof value === 'number') {\n return Math.ceil(value) as T;\n }\n return VectorOps.ceil[value.kind](value) as T;\n}\n\n/**\n * @privateRemarks\n * https://www.w3.org/TR/WGSL/#clamp\n */\nexport function clamp<T extends vBase | number>(value: T, low: T, high: T): T {\n if (inGPUMode()) {\n return `clamp(${value}, ${low}, ${high})` as unknown as T;\n }\n if (typeof value === 'number') {\n return Math.min(Math.max(low as number, value), high as number) as T;\n }\n return VectorOps.clamp[value.kind](value, low as vBase, high as vBase) as T;\n}\n\n// TODO: Accept vectors into `cos`\n/**\n * @privateRemarks\n * https://www.w3.org/TR/WGSL/#cos-builtin\n */\nexport function cos(radians: number): number {\n if (inGPUMode()) {\n return `cos(${radians})` as unknown as number;\n }\n return Math.cos(radians);\n}\n\n/**\n * @privateRemarks\n * https://www.w3.org/TR/WGSL/#cross-builtin\n */\nexport function cross<T extends v3f | v3i | v3u>(a: T, b: T): T {\n if (inGPUMode()) {\n return `cross(${a}, ${b})` as unknown as T;\n }\n return VectorOps.cross[a.kind](a, b);\n}\n\n/**\n * @privateRemarks\n * https://www.w3.org/TR/WGSL/#dot-builtin\n */\nexport function dot<T extends vBase>(lhs: T, rhs: T): number {\n if (inGPUMode()) {\n return `dot(${lhs}, ${rhs})` as unknown as number;\n }\n return VectorOps.dot[lhs.kind](lhs, rhs);\n}\n\nexport function normalize<T extends vBase>(v: T): T {\n if (inGPUMode()) {\n return `normalize(${v})` as unknown as T;\n }\n return VectorOps.normalize[v.kind](v);\n}\n\n/**\n * @privateRemarks\n * https://www.w3.org/TR/WGSL/#floor-builtin\n */\nexport function floor<T extends vBase | number>(value: T): T {\n if (inGPUMode()) {\n return `floor(${value})` as unknown as T;\n }\n if (typeof value === 'number') {\n return Math.floor(value) as T;\n }\n return VectorOps.floor[value.kind](value) as T;\n}\n\nexport function fract(a: number): number {\n if (inGPUMode()) {\n return `fract(${a})` as unknown as number;\n }\n return a - Math.floor(a);\n}\n\n/**\n * @privateRemarks\n * https://www.w3.org/TR/WGSL/#length-builtin\n */\nexport function length<T extends vBase | number>(value: T): number {\n if (inGPUMode()) {\n return `length(${value})` as unknown as number;\n }\n if (typeof value === 'number') {\n return Math.abs(value);\n }\n return VectorOps.length[value.kind](value);\n}\n\n/**\n * @privateRemarks\n * https://www.w3.org/TR/WGSL/#max-float-builtin\n */\nexport function max<T extends vBase | number>(a: T, b: T): T {\n if (inGPUMode()) {\n return `max(${a}, ${b})` as unknown as T;\n }\n if (typeof a === 'number') {\n return Math.max(a, b as number) as T;\n }\n return VectorOps.max[a.kind](a, b as vBase) as T;\n}\n\n/**\n * @privateRemarks\n * https://www.w3.org/TR/WGSL/#min-float-builtin\n */\nexport function min<T extends vBase | number>(a: T, b: T): T {\n if (inGPUMode()) {\n return `min(${a}, ${b})` as unknown as T;\n }\n if (typeof a === 'number') {\n return Math.min(a, b as number) as T;\n }\n return VectorOps.min[a.kind](a, b as vBase) as T;\n}\n\nexport function sin(radians: number): number {\n if (inGPUMode()) {\n return `sin(${radians})` as unknown as number;\n }\n return Math.sin(radians);\n}\n\nexport function exp(value: number): number {\n if (inGPUMode()) {\n return `exp(${value})` as unknown as number;\n }\n return Math.exp(value);\n}\n\nexport function pow(base: number, exponent: number): number;\nexport function pow<T extends v2f | v3f | v4f | v2h | v3h | v4h>(\n base: T,\n exponent: T,\n): T;\nexport function pow<T extends v2f | v3f | v4f | v2h | v3h | v4h | number>(\n base: T,\n exponent: T,\n): T {\n if (inGPUMode()) {\n return `pow(${base}, ${exponent})` as unknown as T;\n }\n if (typeof base === 'number' && typeof exponent === 'number') {\n return (base ** exponent) as T;\n }\n if (\n typeof base === 'object' &&\n typeof exponent === 'object' &&\n 'kind' in base &&\n 'kind' in exponent\n ) {\n return VectorOps.pow[base.kind](base, exponent) as T;\n }\n throw new Error('Invalid arguments to pow()');\n}\n\nexport function mix(e1: number, e2: number, e3: number): number;\nexport function mix<T extends v2f | v3f | v4f | v2h | v3h | v4h>(\n e1: T,\n e2: T,\n e3: number,\n): T;\nexport function mix<T extends v2f | v3f | v4f | v2h | v3h | v4h>(\n e1: T,\n e2: T,\n e3: T,\n): T;\n\nexport function mix<T extends v2f | v3f | v4f | v2h | v3h | v4h | number>(\n e1: T,\n e2: T,\n e3: T | number,\n): T {\n if (inGPUMode()) {\n return `mix(${e1}, ${e2}, ${e3})` as unknown as T;\n }\n\n if (typeof e1 === 'number') {\n if (typeof e3 !== 'number' || typeof e2 !== 'number') {\n throw new Error(\n 'When e1 and e2 are numbers, the blend factor must be a number.',\n );\n }\n return (e1 * (1 - e3) + e2 * e3) as T;\n }\n\n if (typeof e1 === 'number' || typeof e2 === 'number') {\n throw new Error('e1 and e2 need to both be vectors of the same kind.');\n }\n\n return VectorOps.mix[e1.kind](e1, e2, e3) as T;\n}\n\nexport function reflect<T extends vBase>(e1: T, e2: T): T {\n if (inGPUMode()) {\n return `reflect(${e1}, ${e2})` as unknown as T;\n }\n\n return sub(e1, mul(2 * dot(e2, e1), e2));\n}\n","import type { atomicI32, atomicU32 } from '../data/wgslTypes';\nimport { inGPUMode } from '../gpuMode';\n\ntype AnyAtomic = atomicI32 | atomicU32;\n\nexport function workgroupBarrier(): void {\n if (inGPUMode()) {\n // biome-ignore lint/correctness/noVoidTypeReturn: <string-void duality>\n return 'workgroupBarrier()' as unknown as undefined;\n }\n console.warn('workgroupBarrier is a no-op outside of GPU mode.');\n}\n\nexport function storageBarrier(): void {\n if (inGPUMode()) {\n // biome-ignore lint/correctness/noVoidTypeReturn: <string-void duality>\n return 'storageBarrier()' as unknown as undefined;\n }\n console.warn('storageBarrier is a no-op outside of GPU mode.');\n}\n\nexport function textureBarrier(): void {\n if (inGPUMode()) {\n // biome-ignore lint/correctness/noVoidTypeReturn: <string-void duality>\n return 'textureBarrier()' as unknown as undefined;\n }\n console.warn('textureBarrier is a no-op outside of GPU mode.');\n}\n\nexport function atomicLoad<T extends AnyAtomic>(a: T): number {\n if (inGPUMode()) {\n return `atomicLoad(&${a})` as unknown as number;\n }\n throw new Error('Atomic operations are not supported outside of GPU mode.');\n}\n\nexport function atomicStore<T extends AnyAtomic>(a: T, value: number): void {\n if (inGPUMode()) {\n // biome-ignore lint/correctness/noVoidTypeReturn: <string-void duality>\n return `atomicStore(&${a}, ${value})` as unknown as undefined;\n }\n throw new Error('Atomic operations are not supported outside of GPU mode.');\n}\n\nexport function atomicAdd<T extends AnyAtomic>(a: T, value: number): number {\n if (inGPUMode()) {\n return `atomicAdd(&${a}, ${value})` as unknown as number;\n }\n throw new Error('Atomic operations are not supported outside of GPU mode.');\n}\n\nexport function atomicSub<T extends AnyAtomic>(a: T, value: number): number {\n if (inGPUMode()) {\n return `atomicSub(&${a}, ${value})` as unknown as number;\n }\n throw new Error('Atomic operations are not supported outside of GPU mode.');\n}\n\nexport function atomicMax<T extends AnyAtomic>(a: T, value: number): number {\n if (inGPUMode()) {\n return `atomicMax(&${a}, ${value})` as unknown as number;\n }\n throw new Error('Atomic operations are not supported outside of GPU mode.');\n}\n\nexport function atomicMin<T extends AnyAtomic>(a: T, value: number): number {\n if (inGPUMode()) {\n return `atomicMin(&${a}, ${value})` as unknown as number;\n }\n throw new Error('Atomic operations are not supported outside of GPU mode.');\n}\n\nexport function atomicAnd<T extends AnyAtomic>(a: T, value: number): number {\n if (inGPUMode()) {\n return `atomicAnd(&${a}, ${value})` as unknown as number;\n }\n throw new Error('Atomic operations are not supported outside of GPU mode.');\n}\n\nexport function atomicOr<T extends AnyAtomic>(a: T, value: number): number {\n if (inGPUMode()) {\n return `atomicOr(&${a}, ${value})` as unknown as number;\n }\n throw new Error('Atomic operations are not supported outside of GPU mode.');\n}\n\nexport function atomicXor<T extends AnyAtomic>(a: T, value: number): number {\n if (inGPUMode()) {\n return `atomicXor(&${a}, ${value})` as unknown as number;\n }\n throw new Error('Atomic operations are not supported outside of GPU mode.');\n}\n"],"mappings":"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AE,EAAIC,EAAG,CAAC,EAAE,EAChBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAChBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAClBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EACdD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAChBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAChBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAClBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EACdD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAChBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAChBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAClBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EACdD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAChBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAChBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAElBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EACdD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAChBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAChBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAClBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EACdD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAChBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAChBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAClBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EACdD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAChBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAChBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EAClBD,EAAG,CAAC,EAAE,EAAIC,EAAG,CAAC,EAAE,EACdD,EAAG,CAAC,EAAE,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","names":["discard","inGPUMode","lengthVec2","v","lengthVec3","lengthVec4","dotVec2","lhs","rhs","dotVec3","dotVec4","clamp","value","low","high","unary2f","op","a","vec2f","unary2h","vec2h","unary2i","vec2i","unary2u","vec2u","unary3f","vec3f","unary3h","vec3h","unary3i","vec3i","unary3u","vec3u","unary4f","vec4f","unary4h","vec4h","unary4i","vec4i","unary4u","vec4u","binaryComponentWise2f","b","binaryComponentWise2h","binaryComponentWise2i","binaryComponentWise2u","binaryComponentWise3f","binaryComponentWise3h","binaryComponentWise3i","binaryComponentWise3u","binaryComponentWise4f","binaryComponentWise4h","binaryComponentWise4i","binaryComponentWise4u","VectorOps","s","m","m_","mat2x2f","mat3x3f","mat4x4f","a_","b_","len","base","exponent","e1","e2","e3","add","lhs","rhs","inGPUMode","VectorOps","sub","mul","s","v","sIsVector","vIsVector","abs","value","atan2","y","x","ceil","clamp","low","high","cos","radians","cross","a","b","dot","normalize","floor","fract","length","max","min","sin","exp","pow","base","exponent","mix","e1","e2","e3","reflect","workgroupBarrier","inGPUMode","storageBarrier","textureBarrier","atomicLoad","a","atomicStore","value","atomicAdd","atomicSub","atomicMax","atomicMin","atomicAnd","atomicOr","atomicXor"]}
|