typegpu 0.8.1 → 0.8.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (47) hide show
  1. package/{chunk-7S3IK3D4.js → chunk-6U5HPHCJ.js} +2 -2
  2. package/{chunk-7XFSK632.js → chunk-CGQB3SER.js} +2 -2
  3. package/{chunk-4W5Z7BO4.js → chunk-CRZWTZM2.js} +2 -2
  4. package/chunk-CRZWTZM2.js.map +1 -0
  5. package/{chunk-2UXPGML5.js → chunk-ECR2EGZX.js} +2 -2
  6. package/{chunk-VOVQAOVG.js → chunk-PWBIFP67.js} +2 -2
  7. package/common/index.d.ts +1 -1
  8. package/common/index.js +1 -1
  9. package/data/index.d.ts +3 -3
  10. package/data/index.js +1 -1
  11. package/index.d.ts +2 -2
  12. package/index.js +14 -14
  13. package/index.js.map +1 -1
  14. package/{matrix-DLipCOZF.d.ts → matrix-DIfOiRyz.d.ts} +1 -1
  15. package/package.json +5 -13
  16. package/std/index.d.ts +2 -2
  17. package/std/index.js +1 -1
  18. package/{tgpuConstant-BU72w5qs.d.cts → tgpuConstant-BTQFNlQH.d.ts} +9 -0
  19. package/chunk-3246CM7C.cjs +0 -2
  20. package/chunk-3246CM7C.cjs.map +0 -1
  21. package/chunk-4W5Z7BO4.js.map +0 -1
  22. package/chunk-5Y6GTBWR.cjs +0 -3
  23. package/chunk-5Y6GTBWR.cjs.map +0 -1
  24. package/chunk-PRMFGUQT.cjs +0 -2
  25. package/chunk-PRMFGUQT.cjs.map +0 -1
  26. package/chunk-TRE7NUKE.cjs +0 -10
  27. package/chunk-TRE7NUKE.cjs.map +0 -1
  28. package/chunk-ZYGTVBDH.cjs +0 -7
  29. package/chunk-ZYGTVBDH.cjs.map +0 -1
  30. package/common/index.cjs +0 -7
  31. package/common/index.cjs.map +0 -1
  32. package/common/index.d.cts +0 -24
  33. package/data/index.cjs +0 -2
  34. package/data/index.cjs.map +0 -1
  35. package/data/index.d.cts +0 -402
  36. package/index.cjs +0 -192
  37. package/index.cjs.map +0 -1
  38. package/index.d.cts +0 -369
  39. package/matrix-DHFT4O8f.d.cts +0 -122
  40. package/std/index.cjs +0 -2
  41. package/std/index.cjs.map +0 -1
  42. package/std/index.d.cts +0 -639
  43. package/tgpuConstant-BU72w5qs.d.ts +0 -5192
  44. /package/{chunk-7S3IK3D4.js.map → chunk-6U5HPHCJ.js.map} +0 -0
  45. /package/{chunk-7XFSK632.js.map → chunk-CGQB3SER.js.map} +0 -0
  46. /package/{chunk-2UXPGML5.js.map → chunk-ECR2EGZX.js.map} +0 -0
  47. /package/{chunk-VOVQAOVG.js.map → chunk-PWBIFP67.js.map} +0 -0
package/std/index.d.cts DELETED
@@ -1,639 +0,0 @@
1
- import { b9 as DualFn, dL as AnyNumericVecInstance, dM as AnyFloatVecInstance, dN as AnyIntegerVecInstance, bK as v3f, dO as v3h, dP as AnyMatInstance, I as Infer, b8 as WgslStruct, b4 as F32, b5 as I32, b3 as F16, dQ as AbstractFloat, dR as AbstractInt, aP as Vec2f, aS as Vec2i, aV as Vec3f, aX as Vec3i, a_ as Vec4f, b0 as Vec4i, aR as Vec2h, aW as Vec3h, a$ as Vec4h, bG as v2f, dS as v2h, bH as v2i, bL as v3i, bO as v4f, dT as v4h, bP as v4i, dU as AnyFloat32VecInstance, dV as AnySignedVecInstance, dW as vBaseForMat, dX as mBaseForVec, bA as m4x4f, bs as AnyVecInstance, dY as AnyVec2Instance, bF as v2b, dZ as AnyVec3Instance, bJ as v3b, bN as v4b, d_ as AnyBooleanVecInstance, d$ as atomicI32, e0 as atomicU32, bT as texture1d, c4 as textureStorage1d, bU as texture2d, bV as texture2dArray, bX as textureCube, bY as textureCubeArray, c5 as textureStorage2d, c6 as textureStorage2dArray, c2 as textureExternal, bI as v2u, bW as texture3d, c7 as textureStorage3d, bM as v3u, bQ as v4u, $ as $internal, c3 as textureMultisampled2d, e1 as StorageTextureFormats, e2 as TextureFormats, e3 as $repr, ct as sampler, bZ as textureDepth2d, b_ as textureDepth2dArray, b$ as textureDepthCube, cs as comparisonSampler, d as WgslExtension } from '../tgpuConstant-BU72w5qs.cjs';
2
- export { i as identity2, d as identity3, e as identity4, r as rotationX4, f as rotationY4, g as rotationZ4, s as scaling4, t as translation4 } from '../matrix-DHFT4O8f.cjs';
3
- import 'tinyest';
4
-
5
- declare const discard: DualFn<() => never>;
6
-
7
- type NumVec$1 = AnyNumericVecInstance;
8
- declare function cpuAbs(value: number): number;
9
- declare function cpuAbs<T extends NumVec$1 | number>(value: T): T;
10
- declare const abs: DualFn<typeof cpuAbs>;
11
- declare function cpuAcos(value: number): number;
12
- declare function cpuAcos<T extends AnyFloatVecInstance>(value: T): T;
13
- declare const acos: DualFn<typeof cpuAcos>;
14
- declare function cpuAcosh(value: number): number;
15
- declare function cpuAcosh<T extends AnyFloatVecInstance>(value: T): T;
16
- declare const acosh: DualFn<typeof cpuAcosh>;
17
- declare function cpuAsin(value: number): number;
18
- declare function cpuAsin<T extends AnyFloatVecInstance>(value: T): T;
19
- declare const asin: DualFn<typeof cpuAsin>;
20
- declare function cpuAsinh(value: number): number;
21
- declare function cpuAsinh<T extends AnyFloatVecInstance>(value: T): T;
22
- declare const asinh: DualFn<typeof cpuAsinh>;
23
- declare function cpuAtan(value: number): number;
24
- declare function cpuAtan<T extends AnyFloatVecInstance>(value: T): T;
25
- declare const atan: DualFn<typeof cpuAtan>;
26
- declare function cpuAtanh(value: number): number;
27
- declare function cpuAtanh<T extends AnyFloatVecInstance>(value: T): T;
28
- declare const atanh: DualFn<typeof cpuAtanh>;
29
- declare function cpuAtan2(y: number, x: number): number;
30
- declare function cpuAtan2<T extends AnyFloatVecInstance>(y: T, x: T): T;
31
- declare const atan2: DualFn<typeof cpuAtan2>;
32
- declare function cpuCeil(value: number): number;
33
- declare function cpuCeil<T extends AnyFloatVecInstance>(value: T): T;
34
- declare const ceil: DualFn<typeof cpuCeil>;
35
- declare function cpuClamp(value: number, low: number, high: number): number;
36
- declare function cpuClamp<T extends NumVec$1 | number>(value: T, low: T, high: T): T;
37
- declare const clamp: DualFn<typeof cpuClamp>;
38
- declare function cpuCos(value: number): number;
39
- declare function cpuCos<T extends AnyFloatVecInstance>(value: T): T;
40
- declare const cos: DualFn<typeof cpuCos>;
41
- declare function cpuCosh(value: number): number;
42
- declare function cpuCosh<T extends AnyFloatVecInstance>(value: T): T;
43
- declare const cosh: DualFn<typeof cpuCosh>;
44
- declare function cpuCountLeadingZeros(value: number): number;
45
- declare function cpuCountLeadingZeros<T extends AnyIntegerVecInstance>(value: T): T;
46
- declare const countLeadingZeros: DualFn<typeof cpuCountLeadingZeros>;
47
- declare function cpuCountOneBits(value: number): number;
48
- declare function cpuCountOneBits<T extends AnyIntegerVecInstance>(value: T): T;
49
- declare const countOneBits: DualFn<typeof cpuCountOneBits>;
50
- declare function cpuCountTrailingZeros(value: number): number;
51
- declare function cpuCountTrailingZeros<T extends AnyIntegerVecInstance>(value: T): T;
52
- declare const countTrailingZeros: DualFn<typeof cpuCountTrailingZeros>;
53
- declare const cross: DualFn<(<T extends v3f | v3h>(a: T, b: T) => T)>;
54
- declare function cpuDegrees(value: number): number;
55
- declare function cpuDegrees<T extends AnyFloatVecInstance>(value: T): T;
56
- declare const degrees: DualFn<typeof cpuDegrees>;
57
- declare const determinant: DualFn<(value: AnyMatInstance) => number>;
58
- declare function cpuDistance(a: number, b: number): number;
59
- declare function cpuDistance<T extends AnyFloatVecInstance>(a: T, b: T): number;
60
- declare const distance: DualFn<typeof cpuDistance>;
61
- declare const dot: DualFn<(<T extends NumVec$1>(lhs: T, rhs: T) => number)>;
62
- declare const dot4U8Packed: DualFn<(e1: number, e2: number) => number>;
63
- declare const dot4I8Packed: DualFn<(e1: number, e2: number) => number>;
64
- declare function cpuExp(value: number): number;
65
- declare function cpuExp<T extends AnyFloatVecInstance>(value: T): T;
66
- declare const exp: DualFn<typeof cpuExp>;
67
- declare function cpuExp2(value: number): number;
68
- declare function cpuExp2<T extends AnyFloatVecInstance>(value: T): T;
69
- declare const exp2: DualFn<typeof cpuExp2>;
70
- declare function cpuExtractBits(e: number, offset: number, count: number): number;
71
- declare function cpuExtractBits<T extends AnyIntegerVecInstance>(e: T, offset: number, count: number): T;
72
- declare const extractBits: DualFn<typeof cpuExtractBits>;
73
- declare const faceForward: DualFn<(<T extends AnyFloatVecInstance>(e1: T, e2: T, e3: T) => T)>;
74
- declare function cpuFirstLeadingBit(value: number): number;
75
- declare function cpuFirstLeadingBit<T extends AnyIntegerVecInstance>(value: T): T;
76
- declare const firstLeadingBit: DualFn<typeof cpuFirstLeadingBit>;
77
- declare function cpuFirstTrailingBit(value: number): number;
78
- declare function cpuFirstTrailingBit<T extends AnyIntegerVecInstance>(value: T): T;
79
- declare const firstTrailingBit: DualFn<typeof cpuFirstTrailingBit>;
80
- declare function cpuFloor(value: number): number;
81
- declare function cpuFloor<T extends AnyFloatVecInstance>(value: T): T;
82
- declare const floor: DualFn<typeof cpuFloor>;
83
- declare function cpuFma(e1: number, e2: number, e3: number): number;
84
- declare function cpuFma<T extends AnyFloatVecInstance>(e1: T, e2: T, e3: T): T;
85
- declare const fma: DualFn<typeof cpuFma>;
86
- declare function cpuFract(value: number): number;
87
- declare function cpuFract<T extends AnyFloatVecInstance>(value: T): T;
88
- declare const fract: DualFn<typeof cpuFract>;
89
- declare const FrexpResults: {
90
- readonly f32: WgslStruct<{
91
- fract: F32;
92
- exp: I32;
93
- }>;
94
- readonly f16: WgslStruct<{
95
- fract: F16;
96
- exp: I32;
97
- }>;
98
- readonly abstractFloat: WgslStruct<{
99
- fract: AbstractFloat;
100
- exp: AbstractInt;
101
- }>;
102
- readonly vec2f: WgslStruct<{
103
- fract: Vec2f;
104
- exp: Vec2i;
105
- }>;
106
- readonly vec3f: WgslStruct<{
107
- fract: Vec3f;
108
- exp: Vec3i;
109
- }>;
110
- readonly vec4f: WgslStruct<{
111
- fract: Vec4f;
112
- exp: Vec4i;
113
- }>;
114
- readonly vec2h: WgslStruct<{
115
- fract: Vec2h;
116
- exp: Vec2i;
117
- }>;
118
- readonly vec3h: WgslStruct<{
119
- fract: Vec3h;
120
- exp: Vec3i;
121
- }>;
122
- readonly vec4h: WgslStruct<{
123
- fract: Vec4h;
124
- exp: Vec4i;
125
- }>;
126
- };
127
- type FrexpOverload = {
128
- (value: number): Infer<typeof FrexpResults['f32']>;
129
- <T extends AnyFloatVecInstance>(value: T): Infer<typeof FrexpResults[T['kind']]>;
130
- };
131
- declare const frexp: FrexpOverload;
132
- declare function cpuInsertBits(e: number, newbits: number, offset: number, count: number): number;
133
- declare function cpuInsertBits<T extends AnyIntegerVecInstance>(e: T, newbits: T, offset: number, count: number): T;
134
- declare const insertBits: DualFn<typeof cpuInsertBits>;
135
- declare function cpuInverseSqrt(value: number): number;
136
- declare function cpuInverseSqrt<T extends AnyFloatVecInstance>(value: T): T;
137
- declare const inverseSqrt: DualFn<typeof cpuInverseSqrt>;
138
- declare function cpuLdexp(e1: number, e2: number): number;
139
- declare function cpuLdexp<T extends v2f | v2h>(e1: T, e2: v2i): T;
140
- declare function cpuLdexp<T extends v3f | v3h>(e1: T, e2: v3i): T;
141
- declare function cpuLdexp<T extends v4f | v4h>(e1: T, e2: v4i): T;
142
- declare const ldexp: DualFn<typeof cpuLdexp>;
143
- declare function cpuLength(value: number): number;
144
- declare function cpuLength<T extends AnyFloatVecInstance>(value: T): number;
145
- declare const length: DualFn<typeof cpuLength>;
146
- declare function cpuLog(value: number): number;
147
- declare function cpuLog<T extends AnyFloatVecInstance>(value: T): T;
148
- declare const log: DualFn<typeof cpuLog>;
149
- declare function cpuLog2(value: number): number;
150
- declare function cpuLog2<T extends AnyFloatVecInstance>(value: T): T;
151
- declare const log2: DualFn<typeof cpuLog2>;
152
- declare function cpuMax(a: number, b: number): number;
153
- declare function cpuMax<T extends NumVec$1>(a: T, b: T): T;
154
- declare const max: DualFn<typeof cpuMax>;
155
- declare function cpuMin(a: number, b: number): number;
156
- declare function cpuMin<T extends NumVec$1>(a: T, b: T): T;
157
- declare const min: DualFn<typeof cpuMin>;
158
- declare function cpuMix(e1: number, e2: number, e3: number): number;
159
- declare function cpuMix<T extends AnyFloatVecInstance>(e1: T, e2: T, e3: number): T;
160
- declare function cpuMix<T extends AnyFloatVecInstance>(e1: T, e2: T, e3: T): T;
161
- declare const mix: DualFn<typeof cpuMix>;
162
- declare const ModfResult: {
163
- readonly f32: WgslStruct<{
164
- fract: F32;
165
- whole: F32;
166
- }>;
167
- readonly f16: WgslStruct<{
168
- fract: F16;
169
- whole: F16;
170
- }>;
171
- readonly abstractFloat: WgslStruct<{
172
- fract: AbstractFloat;
173
- whole: AbstractFloat;
174
- }>;
175
- readonly vec2f: WgslStruct<{
176
- fract: Vec2f;
177
- whole: Vec2f;
178
- }>;
179
- readonly vec3f: WgslStruct<{
180
- fract: Vec3f;
181
- whole: Vec3f;
182
- }>;
183
- readonly vec4f: WgslStruct<{
184
- fract: Vec4f;
185
- whole: Vec4f;
186
- }>;
187
- readonly vec2h: WgslStruct<{
188
- fract: Vec2h;
189
- whole: Vec2h;
190
- }>;
191
- readonly vec3h: WgslStruct<{
192
- fract: Vec3h;
193
- whole: Vec3h;
194
- }>;
195
- readonly vec4h: WgslStruct<{
196
- fract: Vec4h;
197
- whole: Vec4h;
198
- }>;
199
- };
200
- type ModfOverload = {
201
- (value: number): Infer<typeof ModfResult['f32']>;
202
- <T extends AnyFloatVecInstance>(value: T): Infer<typeof ModfResult[T['kind']]>;
203
- };
204
- declare const modf: ModfOverload;
205
- declare const normalize: DualFn<(<T extends AnyFloatVecInstance>(v: T) => T)>;
206
- declare function powCpu(base: number, exponent: number): number;
207
- declare function powCpu<T extends AnyFloatVecInstance>(base: T, exponent: T): T;
208
- declare const pow: DualFn<typeof powCpu>;
209
- declare function cpuQuantizeToF16(value: number): number;
210
- declare function cpuQuantizeToF16<T extends AnyFloat32VecInstance>(value: T): T;
211
- declare const quantizeToF16: DualFn<typeof cpuQuantizeToF16>;
212
- declare function cpuRadians(value: number): number;
213
- declare function cpuRadians<T extends AnyFloatVecInstance | number>(value: T): T;
214
- declare const radians: DualFn<typeof cpuRadians>;
215
- declare const reflect: DualFn<(<T extends AnyFloatVecInstance>(e1: T, e2: T) => T)>;
216
- declare const refract: DualFn<(<T extends AnyFloatVecInstance>(e1: T, e2: T, e3: number) => T)>;
217
- declare function cpuReverseBits(value: number): number;
218
- declare function cpuReverseBits<T extends AnyIntegerVecInstance>(value: T): T;
219
- declare const reverseBits: DualFn<typeof cpuReverseBits>;
220
- declare function cpuRound(value: number): number;
221
- declare function cpuRound<T extends AnyFloatVecInstance>(value: T): T;
222
- declare const round: DualFn<typeof cpuRound>;
223
- declare function cpuSaturate(value: number): number;
224
- declare function cpuSaturate<T extends AnyFloatVecInstance>(value: T): T;
225
- declare const saturate: DualFn<typeof cpuSaturate>;
226
- declare function cpuSign(e: number): number;
227
- declare function cpuSign<T extends AnySignedVecInstance>(e: T): T;
228
- declare const sign: DualFn<typeof cpuSign>;
229
- declare function cpuSin(value: number): number;
230
- declare function cpuSin<T extends AnyFloatVecInstance>(value: T): T;
231
- declare const sin: DualFn<typeof cpuSin>;
232
- declare function cpuSinh(value: number): number;
233
- declare function cpuSinh<T extends AnyFloatVecInstance>(value: T): T;
234
- declare const sinh: DualFn<typeof cpuSinh>;
235
- declare function cpuSmoothstep(edge0: number, edge1: number, x: number): number;
236
- declare function cpuSmoothstep<T extends AnyFloatVecInstance>(edge0: T, edge1: T, x: T): T;
237
- declare const smoothstep: DualFn<typeof cpuSmoothstep>;
238
- declare function cpuSqrt(value: number): number;
239
- declare function cpuSqrt<T extends AnyFloatVecInstance>(value: T): T;
240
- declare const sqrt: DualFn<typeof cpuSqrt>;
241
- declare function cpuStep(edge: number, x: number): number;
242
- declare function cpuStep<T extends AnyFloatVecInstance | number>(edge: T, x: T): T;
243
- declare const step: DualFn<typeof cpuStep>;
244
- declare function cpuTan(value: number): number;
245
- declare function cpuTan<T extends AnyFloatVecInstance>(value: T): T;
246
- declare const tan: DualFn<typeof cpuTan>;
247
- declare function cpuTanh(value: number): number;
248
- declare function cpuTanh<T extends AnyFloatVecInstance>(value: T): T;
249
- declare const tanh: DualFn<typeof cpuTanh>;
250
- declare const transpose: DualFn<(<T extends AnyMatInstance>(e: T) => T)>;
251
- declare function cpuTrunc(value: number): number;
252
- declare function cpuTrunc<T extends AnyFloatVecInstance>(value: T): T;
253
- declare const trunc: DualFn<typeof cpuTrunc>;
254
-
255
- type NumVec = AnyNumericVecInstance;
256
- type Mat = AnyMatInstance;
257
- declare function cpuAdd(lhs: number, rhs: number): number;
258
- declare function cpuAdd<T extends NumVec>(lhs: number, rhs: T): T;
259
- declare function cpuAdd<T extends NumVec>(lhs: T, rhs: number): T;
260
- declare function cpuAdd<T extends NumVec | Mat>(lhs: T, rhs: T): T;
261
- declare function cpuAdd<Lhs extends number | NumVec | Mat, Rhs extends Lhs extends number ? number | NumVec : Lhs extends NumVec ? number | Lhs : Lhs extends Mat ? Lhs : never>(lhs: Lhs, rhs: Rhs): Lhs | Rhs;
262
- declare const add: DualFn<typeof cpuAdd>;
263
- declare function cpuSub(lhs: number, rhs: number): number;
264
- declare function cpuSub<T extends NumVec>(lhs: number, rhs: T): T;
265
- declare function cpuSub<T extends NumVec>(lhs: T, rhs: number): T;
266
- declare function cpuSub<T extends NumVec | Mat>(lhs: T, rhs: T): T;
267
- declare function cpuSub<Lhs extends number | NumVec | Mat, Rhs extends Lhs extends number ? number | NumVec : Lhs extends NumVec ? number | Lhs : Lhs extends Mat ? Lhs : never>(lhs: Lhs, rhs: Rhs): Lhs | Rhs;
268
- declare const sub: DualFn<typeof cpuSub>;
269
- declare function cpuMul(lhs: number, rhs: number): number;
270
- declare function cpuMul<MV extends NumVec | Mat>(lhs: number, rhs: MV): MV;
271
- declare function cpuMul<MV extends NumVec | Mat>(lhs: MV, rhs: number): MV;
272
- declare function cpuMul<V extends NumVec>(lhs: V, rhs: V): V;
273
- declare function cpuMul<M extends Mat, V extends vBaseForMat<M>>(lhs: V, rhs: M): V;
274
- declare function cpuMul<M extends Mat, V extends vBaseForMat<M>>(lhs: M, rhs: V): V;
275
- declare function cpuMul<M extends Mat>(lhs: M, rhs: M): M;
276
- declare function cpuMul<Lhs extends number | NumVec | Mat, Rhs extends Lhs extends number ? number | NumVec | Mat : Lhs extends NumVec ? number | Lhs | mBaseForVec<Lhs> : Lhs extends Mat ? number | vBaseForMat<Lhs> | Lhs : never>(lhs: Lhs, rhs: Rhs): Lhs | Rhs;
277
- declare const mul: DualFn<typeof cpuMul>;
278
- declare function cpuDiv(lhs: number, rhs: number): number;
279
- declare function cpuDiv<T extends NumVec>(lhs: T, rhs: T): T;
280
- declare function cpuDiv<T extends NumVec>(lhs: number, rhs: T): T;
281
- declare function cpuDiv<T extends NumVec>(lhs: T, rhs: number): T;
282
- declare const div: DualFn<typeof cpuDiv>;
283
- type ModOverload = {
284
- (a: number, b: number): number;
285
- <T extends NumVec>(a: T, b: T): T;
286
- <T extends NumVec>(a: number, b: T): T;
287
- <T extends NumVec>(a: T, b: number): T;
288
- };
289
- /**
290
- * @privateRemarks
291
- * Both JS and WGSL implementations use truncated definition of modulo
292
- */
293
- declare const mod: ModOverload;
294
- declare function cpuNeg(value: number): number;
295
- declare function cpuNeg<T extends NumVec>(value: T): T;
296
- declare const neg: DualFn<typeof cpuNeg>;
297
-
298
- /**
299
- * Translates the given 4-by-4 matrix by the given vector.
300
- * @param {m4x4f} matrix - The matrix to be modified.
301
- * @param {v3f} vector - The vector by which to translate the matrix.
302
- * @returns {m4x4f} The translated matrix.
303
- */
304
- declare const translate4: DualFn<(matrix: m4x4f, vector: v3f) => m4x4f>;
305
- /**
306
- * Scales the given 4-by-4 matrix in each dimension by an amount given by the corresponding entry in the given vector.
307
- * @param {m4x4f} matrix - The matrix to be modified.
308
- * @param {v3f} vector - A vector of three entries specifying the factor by which to scale in each dimension.
309
- * @returns {m4x4f} The scaled matrix.
310
- */
311
- declare const scale4: DualFn<(matrix: m4x4f, vector: v3f) => m4x4f>;
312
- /**
313
- * Rotates the given 4-by-4 matrix around the x-axis by the given angle.
314
- * @param {m4x4f} matrix - The matrix to be modified.
315
- * @param {number} angle - The angle by which to rotate (in radians).
316
- * @returns {m4x4f} The rotated matrix.
317
- */
318
- declare const rotateX4: DualFn<(matrix: m4x4f, angle: number) => m4x4f>;
319
- /**
320
- * Rotates the given 4-by-4 matrix around the y-axis by the given angle.
321
- * @param {m4x4f} matrix - The matrix to be modified.
322
- * @param {number} angle - The angle by which to rotate (in radians).
323
- * @returns {m4x4f} The rotated matrix.
324
- */
325
- declare const rotateY4: DualFn<(matrix: m4x4f, angle: number) => m4x4f>;
326
- /**
327
- * Rotates the given 4-by-4 matrix around the z-axis by the given angle.
328
- * @param {m4x4f} matrix - The matrix to be modified.
329
- * @param {number} angle - The angle by which to rotate (in radians).
330
- * @returns {m4x4f} The rotated matrix.
331
- */
332
- declare const rotateZ4: DualFn<(matrix: m4x4f, angle: number) => m4x4f>;
333
-
334
- /**
335
- * Checks whether `lhs == rhs` on all components.
336
- * Equivalent to `all(eq(lhs, rhs))`.
337
- * @example
338
- * allEq(vec2f(0.0, 1.0), vec2f(0.0, 2.0)) // returns false
339
- * allEq(vec3u(0, 1, 2), vec3u(0, 1, 2)) // returns true
340
- */
341
- declare const allEq: DualFn<(<T extends AnyVecInstance>(lhs: T, rhs: T) => boolean)>;
342
- /**
343
- * Checks **component-wise** whether `lhs == rhs`.
344
- * This function does **not** return `bool`, for that use-case, wrap the result in `all`, or use `allEq`.
345
- * @example
346
- * eq(vec2f(0.0, 1.0), vec2f(0.0, 2.0)) // returns vec2b(true, false)
347
- * eq(vec3u(0, 1, 2), vec3u(2, 1, 0)) // returns vec3b(false, true, false)
348
- * all(eq(vec4i(4, 3, 2, 1), vec4i(4, 3, 2, 1))) // returns true
349
- * allEq(vec4i(4, 3, 2, 1), vec4i(4, 3, 2, 1)) // returns true
350
- */
351
- declare const eq: DualFn<(<T extends AnyVecInstance>(lhs: T, rhs: T) => T extends AnyVec2Instance ? v2b : T extends AnyVec3Instance ? v3b : v4b)>;
352
- /**
353
- * Checks **component-wise** whether `lhs != rhs`.
354
- * This function does **not** return `bool`, for that use-case, wrap the result in `any`.
355
- * @example
356
- * ne(vec2f(0.0, 1.0), vec2f(0.0, 2.0)) // returns vec2b(false, true)
357
- * ne(vec3u(0, 1, 2), vec3u(2, 1, 0)) // returns vec3b(true, false, true)
358
- * any(ne(vec4i(4, 3, 2, 1), vec4i(4, 2, 2, 1))) // returns true
359
- */
360
- declare const ne: DualFn<(<T extends AnyVecInstance>(lhs: T, rhs: T) => T extends AnyVec2Instance ? v2b : T extends AnyVec3Instance ? v3b : v4b)>;
361
- /**
362
- * Checks **component-wise** whether `lhs < rhs`.
363
- * This function does **not** return `bool`, for that use-case, wrap the result in `all`.
364
- * @example
365
- * lt(vec2f(0.0, 0.0), vec2f(0.0, 1.0)) // returns vec2b(false, true)
366
- * lt(vec3u(0, 1, 2), vec3u(2, 1, 0)) // returns vec3b(true, false, false)
367
- * all(lt(vec4i(1, 2, 3, 4), vec4i(2, 3, 4, 5))) // returns true
368
- */
369
- declare const lt: DualFn<(<T extends AnyNumericVecInstance>(lhs: T, rhs: T) => T extends AnyVec2Instance ? v2b : T extends AnyVec3Instance ? v3b : v4b)>;
370
- /**
371
- * Checks **component-wise** whether `lhs <= rhs`.
372
- * This function does **not** return `bool`, for that use-case, wrap the result in `all`.
373
- * @example
374
- * le(vec2f(0.0, 0.0), vec2f(0.0, 1.0)) // returns vec2b(true, true)
375
- * le(vec3u(0, 1, 2), vec3u(2, 1, 0)) // returns vec3b(true, true, false)
376
- * all(le(vec4i(1, 2, 3, 4), vec4i(2, 3, 3, 5))) // returns true
377
- */
378
- declare const le: DualFn<(<T extends AnyNumericVecInstance>(lhs: T, rhs: T) => T extends AnyVec2Instance ? v2b : T extends AnyVec3Instance ? v3b : v4b)>;
379
- /**
380
- * Checks **component-wise** whether `lhs > rhs`.
381
- * This function does **not** return `bool`, for that use-case, wrap the result in `all`.
382
- * @example
383
- * gt(vec2f(0.0, 0.0), vec2f(0.0, 1.0)) // returns vec2b(false, false)
384
- * gt(vec3u(0, 1, 2), vec3u(2, 1, 0)) // returns vec3b(false, false, true)
385
- * all(gt(vec4i(2, 3, 4, 5), vec4i(1, 2, 3, 4))) // returns true
386
- */
387
- declare const gt: DualFn<(<T extends AnyNumericVecInstance>(lhs: T, rhs: T) => T extends AnyVec2Instance ? v2b : T extends AnyVec3Instance ? v3b : v4b)>;
388
- /**
389
- * Checks **component-wise** whether `lhs >= rhs`.
390
- * This function does **not** return `bool`, for that use-case, wrap the result in `all`.
391
- * @example
392
- * ge(vec2f(0.0, 0.0), vec2f(0.0, 1.0)) // returns vec2b(true, false)
393
- * ge(vec3u(0, 1, 2), vec3u(2, 1, 0)) // returns vec3b(false, true, true)
394
- * all(ge(vec4i(2, 2, 4, 5), vec4i(1, 2, 3, 4))) // returns true
395
- */
396
- declare const ge: DualFn<(<T extends AnyNumericVecInstance>(lhs: T, rhs: T) => T extends AnyVec2Instance ? v2b : T extends AnyVec3Instance ? v3b : v4b)>;
397
- /**
398
- * Returns **component-wise** `!value`.
399
- * @example
400
- * not(vec2b(false, true)) // returns vec2b(true, false)
401
- * not(vec3b(true, true, false)) // returns vec3b(false, false, true)
402
- */
403
- declare const not: DualFn<(<T extends AnyBooleanVecInstance>(value: T) => T)>;
404
- /**
405
- * Returns **component-wise** logical `or` result.
406
- * @example
407
- * or(vec2b(false, true), vec2b(false, false)) // returns vec2b(false, true)
408
- * or(vec3b(true, true, false), vec3b(false, true, false)) // returns vec3b(true, true, false)
409
- */
410
- declare const or: DualFn<(<T extends AnyBooleanVecInstance>(lhs: T, rhs: T) => T)>;
411
- /**
412
- * Returns **component-wise** logical `and` result.
413
- * @example
414
- * and(vec2b(false, true), vec2b(true, true)) // returns vec2b(false, true)
415
- * and(vec3b(true, true, false), vec3b(false, true, false)) // returns vec3b(false, true, false)
416
- */
417
- declare const and: DualFn<(<T extends AnyBooleanVecInstance>(lhs: T, rhs: T) => T)>;
418
- /**
419
- * Returns `true` if each component of `value` is true.
420
- * @example
421
- * all(vec2b(false, true)) // returns false
422
- * all(vec3b(true, true, true)) // returns true
423
- */
424
- declare const all: DualFn<(value: AnyBooleanVecInstance) => boolean>;
425
- /**
426
- * Returns `true` if any component of `value` is true.
427
- * @example
428
- * any(vec2b(false, true)) // returns true
429
- * any(vec3b(false, false, false)) // returns false
430
- */
431
- declare const any: DualFn<(value: AnyBooleanVecInstance) => boolean>;
432
- /**
433
- * Checks whether the given elements differ by at most the `precision` value.
434
- * Checks all elements of `lhs` and `rhs` if arguments are vectors.
435
- * @example
436
- * isCloseTo(0, 0.1) // returns false
437
- * isCloseTo(vec3f(0, 0, 0), vec3f(0.002, -0.009, 0)) // returns true
438
- *
439
- * @param {number} precision argument that specifies the maximum allowed difference, 0.01 by default.
440
- */
441
- declare const isCloseTo: DualFn<(<T extends AnyFloatVecInstance | number>(lhs: T, rhs: T, precision?: number) => boolean)>;
442
- declare function cpuSelect(f: boolean, t: boolean, cond: boolean): boolean;
443
- declare function cpuSelect(f: number, t: number, cond: boolean): number;
444
- declare function cpuSelect<T extends AnyVecInstance>(f: T, t: T, cond: boolean | (T extends AnyVec2Instance ? v2b : T extends AnyVec3Instance ? v3b : v4b)): T;
445
- /**
446
- * Returns `t` if `cond` is `true`, and `f` otherwise.
447
- * Component-wise if `cond` is a vector.
448
- * @example
449
- * select(1, 2, false) // returns 1
450
- * select(1, 2, true) // returns 2
451
- * select(vec2i(1, 2), vec2i(3, 4), true) // returns vec2i(3, 4)
452
- * select(vec2i(1, 2), vec2i(3, 4), vec2b(false, true)) // returns vec2i(1, 4)
453
- */
454
- declare const select: DualFn<typeof cpuSelect>;
455
-
456
- type AnyAtomic = atomicI32 | atomicU32;
457
- declare const workgroupBarrier: DualFn<() => void>;
458
- declare const storageBarrier: DualFn<() => void>;
459
- declare const textureBarrier: DualFn<() => void>;
460
- declare const atomicLoad: DualFn<(<T extends AnyAtomic>(a: T) => number)>;
461
- declare const atomicStore: DualFn<(<T extends AnyAtomic>(a: T, value: number) => void)>;
462
- declare const atomicAdd: DualFn<(<T extends AnyAtomic>(a: T, value: number) => number)>;
463
- declare const atomicSub: DualFn<(<T extends AnyAtomic>(a: T, value: number) => number)>;
464
- declare const atomicMax: DualFn<(<T extends AnyAtomic>(a: T, value: number) => number)>;
465
- declare const atomicMin: DualFn<(<T extends AnyAtomic>(a: T, value: number) => number)>;
466
- declare const atomicAnd: DualFn<(<T extends AnyAtomic>(a: T, value: number) => number)>;
467
- declare const atomicOr: DualFn<(<T extends AnyAtomic>(a: T, value: number) => number)>;
468
- declare const atomicXor: DualFn<(<T extends AnyAtomic>(a: T, value: number) => number)>;
469
-
470
- declare function cpuDpdx(value: number): number;
471
- declare function cpuDpdx<T extends AnyFloat32VecInstance>(value: T): T;
472
- declare const dpdx: DualFn<typeof cpuDpdx>;
473
- declare function cpuDpdxCoarse(value: number): number;
474
- declare function cpuDpdxCoarse<T extends AnyFloat32VecInstance>(value: T): T;
475
- declare const dpdxCoarse: DualFn<typeof cpuDpdxCoarse>;
476
- declare function cpuDpdxFine(value: number): number;
477
- declare function cpuDpdxFine<T extends AnyFloat32VecInstance>(value: T): T;
478
- declare const dpdxFine: DualFn<typeof cpuDpdxFine>;
479
- declare function cpuDpdy(value: number): number;
480
- declare function cpuDpdy<T extends AnyFloat32VecInstance>(value: T): T;
481
- declare const dpdy: DualFn<typeof cpuDpdy>;
482
- declare function cpuDpdyCoarse(value: number): number;
483
- declare function cpuDpdyCoarse<T extends AnyFloat32VecInstance>(value: T): T;
484
- declare const dpdyCoarse: DualFn<typeof cpuDpdyCoarse>;
485
- declare function cpuDpdyFine(value: number): number;
486
- declare function cpuDpdyFine<T extends AnyFloat32VecInstance>(value: T): T;
487
- declare const dpdyFine: DualFn<typeof cpuDpdyFine>;
488
- declare function cpuFwidth(value: number): number;
489
- declare function cpuFwidth<T extends AnyFloat32VecInstance>(value: T): T;
490
- declare const fwidth: DualFn<typeof cpuFwidth>;
491
- declare function cpuFwidthCoarse(value: number): number;
492
- declare function cpuFwidthCoarse<T extends AnyFloat32VecInstance>(value: T): T;
493
- declare const fwidthCoarse: DualFn<typeof cpuFwidthCoarse>;
494
- declare function cpuFwidthFine(value: number): number;
495
- declare function cpuFwidthFine<T extends AnyFloat32VecInstance>(value: T): T;
496
- declare const fwidthFine: DualFn<typeof cpuFwidthFine>;
497
-
498
- declare const arrayLength: DualFn<(a: unknown[]) => number>;
499
-
500
- /**
501
- * @privateRemarks
502
- * https://gpuweb.github.io/gpuweb/wgsl/#unpack2x16float-builtin
503
- */
504
- declare const unpack2x16float: DualFn<(e: number) => v2f>;
505
- /**
506
- * @privateRemarks
507
- * https://gpuweb.github.io/gpuweb/wgsl/#pack2x16float-builtin
508
- */
509
- declare const pack2x16float: DualFn<(e: v2f) => number>;
510
- /**
511
- * @privateRemarks
512
- * https://gpuweb.github.io/gpuweb/wgsl/#unpack4x8unorm-builtin
513
- */
514
- declare const unpack4x8unorm: DualFn<(e: number) => v4f>;
515
- /**
516
- * @privateRemarks
517
- * https://gpuweb.github.io/gpuweb/wgsl/#pack4x8unorm-builtin
518
- */
519
- declare const pack4x8unorm: DualFn<(e: v4f) => number>;
520
-
521
- declare function sampleCpu<T extends texture1d>(texture: T, sampler: sampler, coords: number): v4f;
522
- declare function sampleCpu<T extends texture2d>(texture: T, sampler: sampler, coords: v2f, offset?: v2i): v4f;
523
- declare function sampleCpu<T extends texture2dArray>(texture: T, sampler: sampler, coords: v2f, arrayIndex: number, offset?: v2i): v4f;
524
- declare function sampleCpu<T extends texture3d | textureCube>(texture: T, sampler: sampler, coords: v3f): v4f;
525
- declare function sampleCpu<T extends texture3d>(texture: T, sampler: sampler, coords: v3f, offset: v3i): v4f;
526
- declare function sampleCpu<T extends textureCubeArray>(texture: T, sampler: sampler, coords: v3f, arrayIndex: number): v4f;
527
- declare function sampleCpu<T extends textureDepth2d>(texture: T, sampler: sampler, coords: v2f, offset?: v2i): number;
528
- declare function sampleCpu<T extends textureDepth2dArray>(texture: T, sampler: sampler, coords: v2f, arrayIndex: number, offset?: v2i): number;
529
- declare function sampleCpu<T extends textureDepthCube>(texture: T, sampler: sampler, coords: v3f, arrayIndex?: number): number;
530
- declare const textureSample: DualFn<typeof sampleCpu>;
531
- declare function sampleBiasCpu<T extends texture1d>(texture: T, sampler: sampler, coords: number, bias: number): v4f;
532
- declare function sampleBiasCpu<T extends texture2d>(texture: T, sampler: sampler, coords: v2f, bias: number, offset?: v2i): v4f;
533
- declare function sampleBiasCpu<T extends texture2dArray>(texture: T, sampler: sampler, coords: v2f, arrayIndex: number, bias: number, offset?: v2i): v4f;
534
- declare function sampleBiasCpu<T extends texture3d | textureCube>(texture: T, sampler: sampler, coords: v3f, bias: number, offset?: v3i): v4f;
535
- declare function sampleBiasCpu<T extends textureCubeArray>(texture: T, sampler: sampler, coords: v3f, arrayIndex: number, bias: number): v4f;
536
- declare const textureSampleBias: DualFn<typeof sampleBiasCpu>;
537
- declare function sampleLevelCpu<T extends texture1d>(texture: T, sampler: sampler, coords: number, level: number): v4f;
538
- declare function sampleLevelCpu<T extends texture2d>(texture: T, sampler: sampler, coords: v2f, level: number): v4f;
539
- declare function sampleLevelCpu<T extends texture2d>(texture: T, sampler: sampler, coords: v2f, level: number, offset: v2i): v4f;
540
- declare function sampleLevelCpu<T extends texture2dArray>(texture: T, sampler: sampler, coords: v2f, arrayIndex: number, level: number): v4f;
541
- declare function sampleLevelCpu<T extends texture2dArray>(texture: T, sampler: sampler, coords: v2f, arrayIndex: number, level: number, offset: v2i): v4f;
542
- declare function sampleLevelCpu<T extends texture3d | textureCube>(texture: T, sampler: sampler, coords: v3f, level: number): v4f;
543
- declare function sampleLevelCpu<T extends texture3d>(texture: T, sampler: sampler, coords: v3f, level: number, offset: v3i): v4f;
544
- declare function sampleLevelCpu<T extends textureCubeArray>(texture: T, sampler: sampler, coords: v3f, arrayIndex: number, level: number): v4f;
545
- declare function sampleLevelCpu<T extends textureDepth2d>(texture: T, sampler: sampler, coords: v2f, level: number): number;
546
- declare function sampleLevelCpu<T extends textureDepth2d>(texture: T, sampler: sampler, coords: v2f, level: number, offset: v2i): number;
547
- declare function sampleLevelCpu<T extends textureDepth2dArray>(texture: T, sampler: sampler, coords: v2f, arrayIndex: number, level: number): number;
548
- declare function sampleLevelCpu<T extends textureDepth2dArray>(texture: T, sampler: sampler, coords: v2f, arrayIndex: number, level: number, offset: v2i): number;
549
- declare function sampleLevelCpu<T extends textureDepthCube>(texture: T, sampler: sampler, coords: v3f, level: number): number;
550
- declare function sampleLevelCpu<T extends textureCubeArray>(texture: T, sampler: sampler, coords: v3f, arrayIndex: number, level: number): number;
551
- declare const textureSampleLevel: DualFn<typeof sampleLevelCpu>;
552
- type PrimitiveToLoadedType = {
553
- f32: v4f;
554
- i32: v4i;
555
- u32: v4u;
556
- };
557
- type TexelFormatToInstanceType<T extends StorageTextureFormats> = TextureFormats[T]['vectorType'][typeof $repr];
558
- declare function textureLoadCpu<T extends texture1d>(texture: T, coords: number, level: number): PrimitiveToLoadedType[T[typeof $internal]['type']];
559
- declare function textureLoadCpu<T extends texture2d>(texture: T, coords: v2i | v2u, level: number): PrimitiveToLoadedType[T[typeof $internal]['type']];
560
- declare function textureLoadCpu<T extends texture2dArray>(texture: T, coords: v2i | v2u, arrayIndex: number, level: number): PrimitiveToLoadedType[T[typeof $internal]['type']];
561
- declare function textureLoadCpu<T extends texture3d>(texture: T, coords: v3i | v3u, level: number): PrimitiveToLoadedType[T[typeof $internal]['type']];
562
- declare function textureLoadCpu<T extends textureMultisampled2d>(texture: T, coords: v2i | v2u, sampleIndex: number): PrimitiveToLoadedType[T[typeof $internal]['type']];
563
- declare function textureLoadCpu<T extends textureStorage1d>(texture: T, coords: number): TexelFormatToInstanceType<T[typeof $internal][0]>;
564
- declare function textureLoadCpu<T extends textureStorage2d>(texture: T, coords: v2i | v2u): TexelFormatToInstanceType<T[typeof $internal][0]>;
565
- declare function textureLoadCpu<T extends textureStorage2dArray>(texture: T, coords: v2i | v2u, arrayIndex: number): TexelFormatToInstanceType<T[typeof $internal][0]>;
566
- declare function textureLoadCpu<T extends textureStorage3d>(texture: T, coords: v3i | v3u): TexelFormatToInstanceType<T[typeof $internal][0]>;
567
- declare const textureLoad: DualFn<typeof textureLoadCpu>;
568
- declare function textureStoreCpu<T extends textureStorage1d>(texture: T, coords: number, value: TexelFormatToInstanceType<T[typeof $internal][0]>): void;
569
- declare function textureStoreCpu<T extends textureStorage2d>(texture: T, coords: v2i | v2u, value: TexelFormatToInstanceType<T[typeof $internal][0]>): void;
570
- declare function textureStoreCpu<T extends textureStorage2dArray>(texture: T, coords: v2i | v2u, arrayIndex: number, value: TexelFormatToInstanceType<T[typeof $internal][0]>): void;
571
- declare function textureStoreCpu<T extends textureStorage3d>(texture: T, coords: v3i | v3u, value: TexelFormatToInstanceType<T[typeof $internal][0]>): void;
572
- declare const textureStore: DualFn<typeof textureStoreCpu>;
573
- declare function textureDimensionsCpu<T extends texture1d | textureStorage1d>(texture: T): number;
574
- declare function textureDimensionsCpu<T extends texture1d>(texture: T, level: number): number;
575
- declare function textureDimensionsCpu<T extends texture2d | texture2dArray | textureCube | textureCubeArray | textureStorage2d | textureStorage2dArray | textureExternal>(texture: T): v2u;
576
- declare function textureDimensionsCpu<T extends texture2d | texture2dArray | textureCube | textureCubeArray>(texture: T, level: number): v2u;
577
- declare function textureDimensionsCpu<T extends texture3d | textureStorage3d>(texture: T): v3u;
578
- declare function textureDimensionsCpu<T extends texture3d>(texture: T, level: number): v3u;
579
- declare const textureDimensions: DualFn<typeof textureDimensionsCpu>;
580
- declare function textureSampleCompareCpu<T extends textureDepth2d>(texture: T, sampler: comparisonSampler, coords: v2f, depthRef: number): number;
581
- declare function textureSampleCompareCpu<T extends textureDepth2d>(texture: T, sampler: comparisonSampler, coords: v2f, depthRef: number, offset: v2i): number;
582
- declare function textureSampleCompareCpu<T extends textureDepth2dArray>(texture: T, sampler: comparisonSampler, coords: v2f, arrayIndex: number, depthRef: number): number;
583
- declare function textureSampleCompareCpu<T extends textureDepth2dArray>(texture: T, sampler: comparisonSampler, coords: v2f, arrayIndex: number, depthRef: number, offset: v2i): number;
584
- declare function textureSampleCompareCpu<T extends textureDepthCube>(texture: T, sampler: comparisonSampler, coords: v3f, depthRef: number): number;
585
- declare function textureSampleCompareCpu<T extends textureCubeArray>(texture: T, sampler: comparisonSampler, coords: v3f, arrayIndex: number, depthRef: number): number;
586
- declare const textureSampleCompare: DualFn<typeof textureSampleCompareCpu>;
587
- declare function textureSampleBaseClampToEdgeCpu<T extends texture2d | textureExternal>(texture: T, sampler: sampler, coords: v2f): v4f;
588
- declare const textureSampleBaseClampToEdge: DualFn<typeof textureSampleBaseClampToEdgeCpu>;
589
-
590
- interface IdentityNumOrVec {
591
- (e: number): number;
592
- <T extends AnyNumericVecInstance>(e: T): T;
593
- }
594
- interface IdentityIntNumOrVec {
595
- (e: number): number;
596
- <T extends AnyIntegerVecInstance>(e: T): T;
597
- }
598
- interface IdentityNumOrVecWithIdx {
599
- (e: number, index: number): number;
600
- <T extends AnyNumericVecInstance>(e: T, index: number): T;
601
- }
602
- interface IdentityNumOrVecWithDelta {
603
- (e: number, delta: number): number;
604
- <T extends AnyNumericVecInstance>(e: T, delta: number): T;
605
- }
606
- interface IdentityNumOrVecWithMask {
607
- (e: number, mask: number): number;
608
- <T extends AnyNumericVecInstance>(e: T, mask: number): T;
609
- }
610
- declare const subgroupAdd: DualFn<IdentityNumOrVec>;
611
- declare const subgroupExclusiveAdd: DualFn<IdentityNumOrVec>;
612
- declare const subgroupInclusiveAdd: DualFn<IdentityNumOrVec>;
613
- declare const subgroupAll: DualFn<(e: boolean) => boolean>;
614
- declare const subgroupAnd: DualFn<IdentityIntNumOrVec>;
615
- declare const subgroupAny: DualFn<(e: boolean) => boolean>;
616
- declare const subgroupBallot: DualFn<(e: boolean) => v4u>;
617
- declare const subgroupBroadcast: DualFn<IdentityNumOrVecWithIdx>;
618
- declare const subgroupBroadcastFirst: DualFn<IdentityNumOrVec>;
619
- declare const subgroupElect: DualFn<() => boolean>;
620
- declare const subgroupMax: DualFn<IdentityNumOrVec>;
621
- declare const subgroupMin: DualFn<IdentityNumOrVec>;
622
- declare const subgroupMul: DualFn<IdentityNumOrVec>;
623
- declare const subgroupExclusiveMul: DualFn<IdentityNumOrVec>;
624
- declare const subgroupInclusiveMul: DualFn<IdentityNumOrVec>;
625
- declare const subgroupOr: DualFn<IdentityIntNumOrVec>;
626
- declare const subgroupShuffle: DualFn<IdentityNumOrVecWithIdx>;
627
- declare const subgroupShuffleDown: DualFn<IdentityNumOrVecWithDelta>;
628
- declare const subgroupShuffleUp: DualFn<IdentityNumOrVecWithDelta>;
629
- declare const subgroupShuffleXor: DualFn<IdentityNumOrVecWithMask>;
630
- declare const subgroupXor: DualFn<IdentityIntNumOrVec>;
631
-
632
- declare const extensionEnabled: DualFn<(extensionName: WgslExtension) => boolean>;
633
-
634
- type BitcastU32toF32Overload = ((value: number) => number) & ((value: v2u) => v2f) & ((value: v3u) => v3f) & ((value: v4u) => v4f);
635
- declare const bitcastU32toF32: DualFn<BitcastU32toF32Overload>;
636
- type BitcastU32toI32Overload = ((value: number) => number) & ((value: v2u) => v2i) & ((value: v3u) => v3i) & ((value: v4u) => v4i);
637
- declare const bitcastU32toI32: DualFn<BitcastU32toI32Overload>;
638
-
639
- export { abs, acos, acosh, add, all, allEq, and, any, arrayLength, asin, asinh, atan, atan2, atanh, atomicAdd, atomicAnd, atomicLoad, atomicMax, atomicMin, atomicOr, atomicStore, atomicSub, atomicXor, bitcastU32toF32, bitcastU32toI32, ceil, clamp, cos, cosh, countLeadingZeros, countOneBits, countTrailingZeros, cross, degrees, determinant, discard, distance, div, dot, dot4I8Packed, dot4U8Packed, dpdx, dpdxCoarse, dpdxFine, dpdy, dpdyCoarse, dpdyFine, eq, exp, exp2, extensionEnabled, extractBits, faceForward, firstLeadingBit, firstTrailingBit, floor, fma, fract, frexp, fwidth, fwidthCoarse, fwidthFine, ge, gt, insertBits, inverseSqrt, isCloseTo, ldexp, le, length, log, log2, lt, max, min, mix, mod, modf, mul, ne, neg, normalize, not, or, pack2x16float, pack4x8unorm, pow, quantizeToF16, radians, reflect, refract, reverseBits, rotateX4, rotateY4, rotateZ4, round, saturate, scale4, select, sign, sin, sinh, smoothstep, sqrt, step, storageBarrier, sub, subgroupAdd, subgroupAll, subgroupAnd, subgroupAny, subgroupBallot, subgroupBroadcast, subgroupBroadcastFirst, subgroupElect, subgroupExclusiveAdd, subgroupExclusiveMul, subgroupInclusiveAdd, subgroupInclusiveMul, subgroupMax, subgroupMin, subgroupMul, subgroupOr, subgroupShuffle, subgroupShuffleDown, subgroupShuffleUp, subgroupShuffleXor, subgroupXor, tan, tanh, textureBarrier, textureDimensions, textureLoad, textureSample, textureSampleBaseClampToEdge, textureSampleBias, textureSampleCompare, textureSampleLevel, textureStore, translate4, transpose, trunc, unpack2x16float, unpack4x8unorm, workgroupBarrier };