linearly 0.3.0 → 0.4.1

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 (79) hide show
  1. package/lib/{common.d.ts → cjs/common.d.ts} +1 -0
  2. package/lib/cjs/common.d.ts.map +1 -0
  3. package/lib/cjs/common.js +20 -0
  4. package/lib/{index.d.ts → cjs/index.d.ts} +1 -0
  5. package/lib/cjs/index.d.ts.map +1 -0
  6. package/lib/cjs/index.js +35 -0
  7. package/lib/{mat2.d.ts → cjs/mat2.d.ts} +1 -0
  8. package/lib/cjs/mat2.d.ts.map +1 -0
  9. package/lib/cjs/mat2.js +224 -0
  10. package/lib/{mat2d.d.ts → cjs/mat2d.d.ts} +1 -0
  11. package/lib/cjs/mat2d.d.ts.map +1 -0
  12. package/lib/cjs/mat2d.js +291 -0
  13. package/lib/{mat3.d.ts → cjs/mat3.d.ts} +1 -0
  14. package/lib/cjs/mat3.d.ts.map +1 -0
  15. package/lib/cjs/mat3.js +450 -0
  16. package/lib/{mat4.d.ts → cjs/mat4.d.ts} +1 -0
  17. package/lib/cjs/mat4.d.ts.map +1 -0
  18. package/lib/cjs/mat4.js +1250 -0
  19. package/lib/{quat.d.ts → cjs/quat.d.ts} +1 -0
  20. package/lib/cjs/quat.d.ts.map +1 -0
  21. package/lib/cjs/quat.js +504 -0
  22. package/lib/{vec2.d.ts → cjs/vec2.d.ts} +1 -0
  23. package/lib/cjs/vec2.d.ts.map +1 -0
  24. package/lib/cjs/vec2.js +205 -0
  25. package/lib/{vec3.d.ts → cjs/vec3.d.ts} +1 -0
  26. package/lib/cjs/vec3.d.ts.map +1 -0
  27. package/lib/cjs/vec3.js +409 -0
  28. package/lib/{vec4.d.ts → cjs/vec4.d.ts} +1 -0
  29. package/lib/cjs/vec4.d.ts.map +1 -0
  30. package/lib/cjs/vec4.js +319 -0
  31. package/lib/esm/common.d.ts +12 -0
  32. package/lib/esm/common.d.ts.map +1 -0
  33. package/lib/esm/common.js +16 -0
  34. package/lib/esm/index.d.ts +17 -0
  35. package/lib/esm/index.d.ts.map +1 -0
  36. package/lib/esm/index.js +9 -0
  37. package/lib/esm/mat2.d.ts +91 -0
  38. package/lib/esm/mat2.d.ts.map +1 -0
  39. package/lib/esm/mat2.js +179 -0
  40. package/lib/esm/mat2d.d.ts +102 -0
  41. package/lib/esm/mat2d.d.ts.map +1 -0
  42. package/lib/esm/mat2d.js +246 -0
  43. package/lib/esm/mat3.d.ts +120 -0
  44. package/lib/esm/mat3.d.ts.map +1 -0
  45. package/lib/esm/mat3.js +400 -0
  46. package/lib/esm/mat4.d.ts +313 -0
  47. package/lib/esm/mat4.d.ts.map +1 -0
  48. package/lib/esm/mat4.js +1183 -0
  49. package/lib/esm/quat.d.ts +220 -0
  50. package/lib/esm/quat.d.ts.map +1 -0
  51. package/lib/esm/quat.js +458 -0
  52. package/lib/esm/vec2.d.ts +66 -0
  53. package/lib/esm/vec2.d.ts.map +1 -0
  54. package/lib/esm/vec2.js +149 -0
  55. package/lib/esm/vec3.d.ts +167 -0
  56. package/lib/esm/vec3.d.ts.map +1 -0
  57. package/lib/esm/vec3.js +348 -0
  58. package/lib/esm/vec4.d.ts +116 -0
  59. package/lib/esm/vec4.d.ts.map +1 -0
  60. package/lib/esm/vec4.js +266 -0
  61. package/package.json +6 -4
  62. package/lib/common.js +0 -30
  63. package/lib/index.js +0 -45
  64. package/lib/mat2.js +0 -234
  65. package/lib/mat2d.js +0 -301
  66. package/lib/mat2d.test.d.ts +0 -1
  67. package/lib/mat2d.test.js +0 -123
  68. package/lib/mat3.js +0 -460
  69. package/lib/mat4.js +0 -1260
  70. package/lib/quat.js +0 -514
  71. package/lib/vec2.js +0 -215
  72. package/lib/vec2.test.d.ts +0 -1
  73. package/lib/vec2.test.js +0 -147
  74. package/lib/vec3.js +0 -419
  75. package/lib/vec3.test.d.ts +0 -1
  76. package/lib/vec3.test.js +0 -149
  77. package/lib/vec4.js +0 -329
  78. package/lib/vec4.test.d.ts +0 -1
  79. package/lib/vec4.test.js +0 -45
@@ -0,0 +1,1183 @@
1
+ import * as Common from './common';
2
+ // prettier-ignore
3
+ export function of(m00, m01, m02, m03, m10, m11, m12, m13, m20, m21, m22, m23, m30, m31, m32, m33) {
4
+ // prettier-ignore
5
+ return [
6
+ m00, m01, m02, m03,
7
+ m10, m11, m12, m13,
8
+ m20, m21, m22, m23,
9
+ m30, m31, m32, m33,
10
+ ];
11
+ }
12
+ /**
13
+ * The identity matrix of mat4
14
+ */
15
+ // prettier-ignore
16
+ export const identity = Object.freeze([
17
+ 1, 0, 0, 0,
18
+ 0, 1, 0, 0,
19
+ 0, 0, 1, 0,
20
+ 0, 0, 0, 1,
21
+ ]);
22
+ export const zero = Object.freeze([
23
+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
24
+ ]);
25
+ /**
26
+ * Transpose the values of a mat4
27
+ */
28
+ export function transpose(a) {
29
+ // prettier-ignore
30
+ return [
31
+ a[0], a[4], a[8], a[12],
32
+ a[1], a[5], a[9], a[13],
33
+ a[2], a[6], a[10], a[14],
34
+ a[3], a[7], a[11], a[15],
35
+ ];
36
+ }
37
+ /**
38
+ * Inverts a mat4
39
+ */
40
+ export function invert(a) {
41
+ // prettier-ignore
42
+ const [a00, a01, a02, a03, a10, a11, a12, a13, a20, a21, a22, a23, a30, a31, a32, a33] = a;
43
+ const b00 = a00 * a11 - a01 * a10;
44
+ const b01 = a00 * a12 - a02 * a10;
45
+ const b02 = a00 * a13 - a03 * a10;
46
+ const b03 = a01 * a12 - a02 * a11;
47
+ const b04 = a01 * a13 - a03 * a11;
48
+ const b05 = a02 * a13 - a03 * a12;
49
+ const b06 = a20 * a31 - a21 * a30;
50
+ const b07 = a20 * a32 - a22 * a30;
51
+ const b08 = a20 * a33 - a23 * a30;
52
+ const b09 = a21 * a32 - a22 * a31;
53
+ const b10 = a21 * a33 - a23 * a31;
54
+ const b11 = a22 * a33 - a23 * a32;
55
+ // Calculate the determinant
56
+ const det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;
57
+ if (!det) {
58
+ return null;
59
+ }
60
+ const detinv = 1 / det;
61
+ return [
62
+ (a11 * b11 - a12 * b10 + a13 * b09) * detinv,
63
+ (a02 * b10 - a01 * b11 - a03 * b09) * detinv,
64
+ (a31 * b05 - a32 * b04 + a33 * b03) * detinv,
65
+ (a22 * b04 - a21 * b05 - a23 * b03) * detinv,
66
+ (a12 * b08 - a10 * b11 - a13 * b07) * detinv,
67
+ (a00 * b11 - a02 * b08 + a03 * b07) * detinv,
68
+ (a32 * b02 - a30 * b05 - a33 * b01) * detinv,
69
+ (a20 * b05 - a22 * b02 + a23 * b01) * detinv,
70
+ (a10 * b10 - a11 * b08 + a13 * b06) * detinv,
71
+ (a01 * b08 - a00 * b10 - a03 * b06) * detinv,
72
+ (a30 * b04 - a31 * b02 + a33 * b00) * detinv,
73
+ (a21 * b02 - a20 * b04 - a23 * b00) * detinv,
74
+ (a11 * b07 - a10 * b09 - a12 * b06) * detinv,
75
+ (a00 * b09 - a01 * b07 + a02 * b06) * detinv,
76
+ (a31 * b01 - a30 * b03 - a32 * b00) * detinv,
77
+ (a20 * b03 - a21 * b01 + a22 * b00) * detinv,
78
+ ];
79
+ }
80
+ /**
81
+ * Calculates the adjugate of a mat4
82
+ */
83
+ export function adjoint(a) {
84
+ // prettier-ignore
85
+ const [a00, a01, a02, a03, a10, a11, a12, a13, a20, a21, a22, a23, a30, a31, a32, a33] = a;
86
+ const b00 = a00 * a11 - a01 * a10;
87
+ const b01 = a00 * a12 - a02 * a10;
88
+ const b02 = a00 * a13 - a03 * a10;
89
+ const b03 = a01 * a12 - a02 * a11;
90
+ const b04 = a01 * a13 - a03 * a11;
91
+ const b05 = a02 * a13 - a03 * a12;
92
+ const b06 = a20 * a31 - a21 * a30;
93
+ const b07 = a20 * a32 - a22 * a30;
94
+ const b08 = a20 * a33 - a23 * a30;
95
+ const b09 = a21 * a32 - a22 * a31;
96
+ const b10 = a21 * a33 - a23 * a31;
97
+ const b11 = a22 * a33 - a23 * a32;
98
+ return [
99
+ a11 * b11 - a12 * b10 + a13 * b09,
100
+ a02 * b10 - a01 * b11 - a03 * b09,
101
+ a31 * b05 - a32 * b04 + a33 * b03,
102
+ a22 * b04 - a21 * b05 - a23 * b03,
103
+ a12 * b08 - a10 * b11 - a13 * b07,
104
+ a00 * b11 - a02 * b08 + a03 * b07,
105
+ a32 * b02 - a30 * b05 - a33 * b01,
106
+ a20 * b05 - a22 * b02 + a23 * b01,
107
+ a10 * b10 - a11 * b08 + a13 * b06,
108
+ a01 * b08 - a00 * b10 - a03 * b06,
109
+ a30 * b04 - a31 * b02 + a33 * b00,
110
+ a21 * b02 - a20 * b04 - a23 * b00,
111
+ a11 * b07 - a10 * b09 - a12 * b06,
112
+ a00 * b09 - a01 * b07 + a02 * b06,
113
+ a31 * b01 - a30 * b03 - a32 * b00,
114
+ a20 * b03 - a21 * b01 + a22 * b00,
115
+ ];
116
+ }
117
+ /**
118
+ * Calculates the determinant of a mat4
119
+ */
120
+ export function determinant(a) {
121
+ // prettier-ignore
122
+ const [a00, a01, a02, a03, a10, a11, a12, a13, a20, a21, a22, a23, a30, a31, a32, a33] = a;
123
+ const b0 = a00 * a11 - a01 * a10;
124
+ const b1 = a00 * a12 - a02 * a10;
125
+ const b2 = a01 * a12 - a02 * a11;
126
+ const b3 = a20 * a31 - a21 * a30;
127
+ const b4 = a20 * a32 - a22 * a30;
128
+ const b5 = a21 * a32 - a22 * a31;
129
+ const b6 = a00 * b5 - a01 * b4 + a02 * b3;
130
+ const b7 = a10 * b5 - a11 * b4 + a12 * b3;
131
+ const b8 = a20 * b2 - a21 * b1 + a22 * b0;
132
+ const b9 = a30 * b2 - a31 * b1 + a32 * b0;
133
+ // Calculate the determinant
134
+ return a13 * b6 - a03 * b7 + a33 * b8 - a23 * b9;
135
+ }
136
+ /**
137
+ * Multiplies two mat4's
138
+ */
139
+ export function multiply(a, b) {
140
+ // prettier-ignore
141
+ const [a00, a01, a02, a03, a10, a11, a12, a13, a20, a21, a22, a23, a30, a31, a32, a33] = a;
142
+ const out = Array(16);
143
+ // Cache only the current line of the second matrix
144
+ let [b0, b1, b2, b3] = b;
145
+ out[0] = b0 * a00 + b1 * a10 + b2 * a20 + b3 * a30;
146
+ out[1] = b0 * a01 + b1 * a11 + b2 * a21 + b3 * a31;
147
+ out[2] = b0 * a02 + b1 * a12 + b2 * a22 + b3 * a32;
148
+ out[3] = b0 * a03 + b1 * a13 + b2 * a23 + b3 * a33;
149
+ b0 = b[4];
150
+ b1 = b[5];
151
+ b2 = b[6];
152
+ b3 = b[7];
153
+ out[4] = b0 * a00 + b1 * a10 + b2 * a20 + b3 * a30;
154
+ out[5] = b0 * a01 + b1 * a11 + b2 * a21 + b3 * a31;
155
+ out[6] = b0 * a02 + b1 * a12 + b2 * a22 + b3 * a32;
156
+ out[7] = b0 * a03 + b1 * a13 + b2 * a23 + b3 * a33;
157
+ b0 = b[8];
158
+ b1 = b[9];
159
+ b2 = b[10];
160
+ b3 = b[11];
161
+ out[8] = b0 * a00 + b1 * a10 + b2 * a20 + b3 * a30;
162
+ out[9] = b0 * a01 + b1 * a11 + b2 * a21 + b3 * a31;
163
+ out[10] = b0 * a02 + b1 * a12 + b2 * a22 + b3 * a32;
164
+ out[11] = b0 * a03 + b1 * a13 + b2 * a23 + b3 * a33;
165
+ b0 = b[12];
166
+ b1 = b[13];
167
+ b2 = b[14];
168
+ b3 = b[15];
169
+ out[12] = b0 * a00 + b1 * a10 + b2 * a20 + b3 * a30;
170
+ out[13] = b0 * a01 + b1 * a11 + b2 * a21 + b3 * a31;
171
+ out[14] = b0 * a02 + b1 * a12 + b2 * a22 + b3 * a32;
172
+ out[15] = b0 * a03 + b1 * a13 + b2 * a23 + b3 * a33;
173
+ return out;
174
+ }
175
+ /**
176
+ * Translate a mat4 by the given vector
177
+ *
178
+ * @param a the matrix to translate
179
+ * @param v vector to translate by
180
+ */
181
+ export function translate(a, v) {
182
+ const [x, y, z] = v;
183
+ // prettier-ignore
184
+ const [a00, a01, a02, a03, a10, a11, a12, a13, a20, a21, a22, a23] = a;
185
+ // prettier-ignore
186
+ return [
187
+ a00, a01, a02, a03,
188
+ a10, a11, a12, a13,
189
+ a20, a21, a22, a23,
190
+ a00 * x + a10 * y + a20 * z + a[12],
191
+ a01 * x + a11 * y + a21 * z + a[13],
192
+ a02 * x + a12 * y + a22 * z + a[14],
193
+ a03 * x + a13 * y + a23 * z + a[15],
194
+ ];
195
+ }
196
+ /**
197
+ * Scales the mat4 by the dimensions in the given vec3 not using vectorization
198
+ **/
199
+ export function scale(a, v) {
200
+ const [x, y, z] = v;
201
+ // prettier-ignore
202
+ return [
203
+ a[0] * x, a[1] * x, a[2] * x, a[3] * x,
204
+ a[4] * y, a[5] * y, a[6] * y, a[7] * y,
205
+ a[8] * z, a[9] * z, a[10] * z, a[11] * z,
206
+ a[12], a[13], a[14], a[15],
207
+ ];
208
+ }
209
+ /**
210
+ * Rotates a mat4 by the given angle around the given axis
211
+ */
212
+ export function rotate(a, rad, axis) {
213
+ let [x, y, z] = axis;
214
+ const len = Math.sqrt(x * x + y * y + z * z);
215
+ if (len < Common.EPSILON) {
216
+ return null;
217
+ }
218
+ x /= len;
219
+ y /= len;
220
+ z /= len;
221
+ const s = Math.sin(rad);
222
+ const c = Math.cos(rad);
223
+ const t = 1 - c;
224
+ // prettier-ignore
225
+ const [a00, a01, a02, a03, a10, a11, a12, a13, a20, a21, a22, a23] = a;
226
+ // Construct the elements of the rotation matrix
227
+ const b00 = x * x * t + c;
228
+ const b01 = y * x * t + z * s;
229
+ const b02 = z * x * t - y * s;
230
+ const b10 = x * y * t - z * s;
231
+ const b11 = y * y * t + c;
232
+ const b12 = z * y * t + x * s;
233
+ const b20 = x * z * t + y * s;
234
+ const b21 = y * z * t - x * s;
235
+ const b22 = z * z * t + c;
236
+ // prettier-ignore
237
+ return [
238
+ a00 * b00 + a10 * b01 + a20 * b02,
239
+ a01 * b00 + a11 * b01 + a21 * b02,
240
+ a02 * b00 + a12 * b01 + a22 * b02,
241
+ a03 * b00 + a13 * b01 + a23 * b02,
242
+ a00 * b10 + a10 * b11 + a20 * b12,
243
+ a01 * b10 + a11 * b11 + a21 * b12,
244
+ a02 * b10 + a12 * b11 + a22 * b12,
245
+ a03 * b10 + a13 * b11 + a23 * b12,
246
+ a00 * b20 + a10 * b21 + a20 * b22,
247
+ a01 * b20 + a11 * b21 + a21 * b22,
248
+ a02 * b20 + a12 * b21 + a22 * b22,
249
+ a03 * b20 + a13 * b21 + a23 * b22,
250
+ a[12], a[13], a[14], a[15],
251
+ ];
252
+ }
253
+ /**
254
+ * Rotates a matrix by the given angle around the X axis
255
+ */
256
+ export function rotateX(a, rad) {
257
+ const s = Math.sin(rad);
258
+ const c = Math.cos(rad);
259
+ const a10 = a[4];
260
+ const a11 = a[5];
261
+ const a12 = a[6];
262
+ const a13 = a[7];
263
+ const a20 = a[8];
264
+ const a21 = a[9];
265
+ const a22 = a[10];
266
+ const a23 = a[11];
267
+ // prettier-ignore
268
+ return [
269
+ a[0], a[1], a[2], a[3],
270
+ a10 * c + a20 * s, a11 * c + a21 * s, a12 * c + a22 * s, a13 * c + a23 * s,
271
+ a20 * c - a10 * s, a21 * c - a11 * s, a22 * c - a12 * s, a23 * c - a13 * s,
272
+ a[12], a[13], a[14], a[15],
273
+ ];
274
+ }
275
+ /**
276
+ * Rotates a matrix by the given angle around the Y axis
277
+ */
278
+ export function rotateY(a, rad) {
279
+ const s = Math.sin(rad);
280
+ const c = Math.cos(rad);
281
+ const a00 = a[0];
282
+ const a01 = a[1];
283
+ const a02 = a[2];
284
+ const a03 = a[3];
285
+ const a20 = a[8];
286
+ const a21 = a[9];
287
+ const a22 = a[10];
288
+ const a23 = a[11];
289
+ // prettier-ignore
290
+ return [
291
+ a00 * c - a20 * s,
292
+ a01 * c - a21 * s,
293
+ a02 * c - a22 * s,
294
+ a03 * c - a23 * s,
295
+ a[4], a[5], a[6], a[7],
296
+ a00 * s + a20 * c,
297
+ a01 * s + a21 * c,
298
+ a02 * s + a22 * c,
299
+ a03 * s + a23 * c,
300
+ a[12], a[13], a[14], a[15],
301
+ ];
302
+ }
303
+ /**
304
+ * Rotates a matrix by the given angle around the Z axis
305
+ */
306
+ export function rotateZ(a, rad) {
307
+ const s = Math.sin(rad);
308
+ const c = Math.cos(rad);
309
+ const a00 = a[0];
310
+ const a01 = a[1];
311
+ const a02 = a[2];
312
+ const a03 = a[3];
313
+ const a10 = a[4];
314
+ const a11 = a[5];
315
+ const a12 = a[6];
316
+ const a13 = a[7];
317
+ // prettier-ignore
318
+ return [
319
+ a00 * c + a10 * s,
320
+ a01 * c + a11 * s,
321
+ a02 * c + a12 * s,
322
+ a03 * c + a13 * s,
323
+ a10 * c - a00 * s,
324
+ a11 * c - a01 * s,
325
+ a12 * c - a02 * s,
326
+ a13 * c - a03 * s,
327
+ a[8], a[9], a[10], a[11],
328
+ a[12], a[13], a[14], a[15],
329
+ ];
330
+ }
331
+ /**
332
+ * Creates a matrix from a vector translation
333
+ */
334
+ export function fromTranslation(v) {
335
+ const [x, y, z] = v;
336
+ // prettier-ignore
337
+ return [
338
+ 1, 0, 0, 0,
339
+ 0, 1, 0, 0,
340
+ 0, 0, 1, 0,
341
+ x, y, z, 1,
342
+ ];
343
+ }
344
+ /**
345
+ * Creates a matrix from a vector scaling
346
+ */
347
+ export function fromScaling(v) {
348
+ const [x, y, z] = v;
349
+ // prettier-ignore
350
+ return [
351
+ x, 0, 0, 0,
352
+ 0, y, 0, 0,
353
+ 0, 0, z, 0,
354
+ 0, 0, 0, 1
355
+ ];
356
+ }
357
+ /**
358
+ * Creates a matrix from a given angle around a given axis
359
+ */
360
+ export function fromRotation(rad, axis) {
361
+ let [x, y, z] = axis;
362
+ const len = Math.sqrt(x * x + y * y + z * z);
363
+ if (len < Common.EPSILON) {
364
+ return null;
365
+ }
366
+ x /= len;
367
+ y /= len;
368
+ z /= len;
369
+ const s = Math.sin(rad);
370
+ const c = Math.cos(rad);
371
+ const t = 1 - c;
372
+ // prettier-ignore
373
+ return [
374
+ x * x * t + c,
375
+ y * x * t + z * s,
376
+ z * x * t - y * s,
377
+ 0,
378
+ x * y * t - z * s,
379
+ y * y * t + c,
380
+ z * y * t + x * s,
381
+ 0,
382
+ x * z * t + y * s,
383
+ y * z * t - x * s,
384
+ z * z * t + c,
385
+ 0,
386
+ 0, 0, 0, 1,
387
+ ];
388
+ }
389
+ /**
390
+ * Creates a matrix from the given angle around the X axis
391
+ */
392
+ export function fromXRotation(rad) {
393
+ const s = Math.sin(rad);
394
+ const c = Math.cos(rad);
395
+ // prettier-ignore
396
+ return [
397
+ 1, 0, 0, 0,
398
+ 0, c, s, 0,
399
+ 0, -s, c, 0,
400
+ 0, 0, 0, 1
401
+ ];
402
+ }
403
+ /**
404
+ * Creates a matrix from the given angle around the Y axis
405
+ */
406
+ export function fromYRotation(rad) {
407
+ const s = Math.sin(rad);
408
+ const c = Math.cos(rad);
409
+ // prettier-ignore
410
+ return [
411
+ c, 0, -s, 0,
412
+ 0, 1, 0, 0,
413
+ s, 0, c, 0,
414
+ 0, 0, 0, 1
415
+ ];
416
+ }
417
+ /**
418
+ * Creates a matrix from the given angle around the Z axis
419
+ */
420
+ export function fromZRotation(rad) {
421
+ const s = Math.sin(rad);
422
+ const c = Math.cos(rad);
423
+ // prettier-ignore
424
+ return [
425
+ c, s, 0, 0,
426
+ -s, c, 0, 0,
427
+ 0, 0, 1, 0,
428
+ 0, 0, 0, 1
429
+ ];
430
+ }
431
+ /**
432
+ * Creates a matrix from a quaternion rotation and vector translation
433
+ */
434
+ export function fromRotationTranslation(q, v) {
435
+ // Quaternion math
436
+ const [x, y, z, w] = q;
437
+ const x2 = x + x;
438
+ const y2 = y + y;
439
+ const z2 = z + z;
440
+ const xx = x * x2;
441
+ const xy = x * y2;
442
+ const xz = x * z2;
443
+ const yy = y * y2;
444
+ const yz = y * z2;
445
+ const zz = z * z2;
446
+ const wx = w * x2;
447
+ const wy = w * y2;
448
+ const wz = w * z2;
449
+ return [
450
+ 1 - (yy + zz),
451
+ xy + wz,
452
+ xz - wy,
453
+ 0,
454
+ xy - wz,
455
+ 1 - (xx + zz),
456
+ yz + wx,
457
+ 0,
458
+ xz + wy,
459
+ yz - wx,
460
+ 1 - (xx + yy),
461
+ 0,
462
+ v[0],
463
+ v[1],
464
+ v[2],
465
+ 1,
466
+ ];
467
+ }
468
+ /**
469
+ * Returns the translation vector component of a transformation
470
+ * matrix. If a matrix is built with fromRotationTranslation,
471
+ * the returned vector will be the same as the translation vector
472
+ * originally supplied.
473
+ */
474
+ export function getTranslation(mat) {
475
+ return [mat[12], mat[13], mat[14]];
476
+ }
477
+ /**
478
+ * Returns the scaling factor component of a transformation
479
+ * matrix. If a matrix is built with fromRotationTranslationScale
480
+ * with a normalized Quaternion paramter, the returned vector will be
481
+ * the same as the scaling vector
482
+ * originally supplied.
483
+ */
484
+ export function getScaling(mat) {
485
+ // prettier-ignore
486
+ const [m11, m12, m13, , m21, m22, m23, , m31, m32, m33,] = mat;
487
+ return [
488
+ Math.sqrt(m11 * m11 + m12 * m12 + m13 * m13),
489
+ Math.sqrt(m21 * m21 + m22 * m22 + m23 * m23),
490
+ Math.sqrt(m31 * m31 + m32 * m32 + m33 * m33),
491
+ ];
492
+ }
493
+ /**
494
+ * Returns a quaternion representing the rotational component
495
+ * of a transformation matrix. If a matrix is built with
496
+ * fromRotationTranslation, the returned quaternion will be the
497
+ * same as the quaternion originally supplied.
498
+ */
499
+ export function getRotation(mat) {
500
+ const scaling = getScaling(mat);
501
+ const is1 = 1 / scaling[0];
502
+ const is2 = 1 / scaling[1];
503
+ const is3 = 1 / scaling[2];
504
+ const sm11 = mat[0] * is1;
505
+ const sm12 = mat[1] * is2;
506
+ const sm13 = mat[2] * is3;
507
+ const sm21 = mat[4] * is1;
508
+ const sm22 = mat[5] * is2;
509
+ const sm23 = mat[6] * is3;
510
+ const sm31 = mat[8] * is1;
511
+ const sm32 = mat[9] * is2;
512
+ const sm33 = mat[10] * is3;
513
+ const trace = sm11 + sm22 + sm33;
514
+ if (trace > 0) {
515
+ const S = Math.sqrt(trace + 1) * 2;
516
+ return [(sm23 - sm32) / S, (sm31 - sm13) / S, (sm12 - sm21) / S, 0.25 * S];
517
+ }
518
+ else if (sm11 > sm22 && sm11 > sm33) {
519
+ const S = Math.sqrt(1 + sm11 - sm22 - sm33) * 2;
520
+ return [0.25 * S, (sm12 + sm21) / S, (sm31 + sm13) / S, (sm23 - sm32) / S];
521
+ }
522
+ else if (sm22 > sm33) {
523
+ const S = Math.sqrt(1 + sm22 - sm11 - sm33) * 2;
524
+ return [(sm12 + sm21) / S, 0.25 * S, (sm23 + sm32) / S, (sm31 - sm13) / S];
525
+ }
526
+ else {
527
+ const S = Math.sqrt(1 + sm33 - sm11 - sm22) * 2;
528
+ return [(sm31 + sm13) / S, (sm23 + sm32) / S, 0.25 * S, (sm12 - sm21) / S];
529
+ }
530
+ }
531
+ /**
532
+ * Decomposes a transformation matrix into its rotation, translation
533
+ * and scale components. Returns only the rotation component
534
+ *
535
+ * @param mat Matrix to be decomposed (input)
536
+ */
537
+ export function decompose(mat) {
538
+ const trans = [mat[12], mat[13], mat[14]];
539
+ // prettier-ignore
540
+ const [m11, m12, m13, , m21, m22, m23, , m31, m32, m33,] = mat;
541
+ const scale = [
542
+ Math.sqrt(m11 * m11 + m12 * m12 + m13 * m13),
543
+ Math.sqrt(m21 * m21 + m22 * m22 + m23 * m23),
544
+ Math.sqrt(m31 * m31 + m32 * m32 + m33 * m33),
545
+ ];
546
+ const is1 = 1 / scale[0];
547
+ const is2 = 1 / scale[1];
548
+ const is3 = 1 / scale[2];
549
+ const sm11 = m11 * is1;
550
+ const sm12 = m12 * is2;
551
+ const sm13 = m13 * is3;
552
+ const sm21 = m21 * is1;
553
+ const sm22 = m22 * is2;
554
+ const sm23 = m23 * is3;
555
+ const sm31 = m31 * is1;
556
+ const sm32 = m32 * is2;
557
+ const sm33 = m33 * is3;
558
+ const trace = sm11 + sm22 + sm33;
559
+ let rot;
560
+ if (trace > 0) {
561
+ const S = Math.sqrt(trace + 1) * 2;
562
+ rot = [(sm23 - sm32) / S, (sm31 - sm13) / S, (sm12 - sm21) / S, 0.25 * S];
563
+ }
564
+ else if (sm11 > sm22 && sm11 > sm33) {
565
+ const S = Math.sqrt(1 + sm11 - sm22 - sm33) * 2;
566
+ rot = [0.25 * S, (sm12 + sm21) / S, (sm31 + sm13) / S, (sm23 - sm32) / S];
567
+ }
568
+ else if (sm22 > sm33) {
569
+ const S = Math.sqrt(1 + sm22 - sm11 - sm33) * 2;
570
+ rot = [(sm12 + sm21) / S, 0.25 * S, (sm23 + sm32) / S, (sm31 - sm13) / S];
571
+ }
572
+ else {
573
+ const S = Math.sqrt(1 + sm33 - sm11 - sm22) * 2;
574
+ rot = [(sm31 + sm13) / S, (sm23 + sm32) / S, 0.25 * S, (sm12 - sm21) / S];
575
+ }
576
+ return {
577
+ trans,
578
+ rot,
579
+ scale,
580
+ };
581
+ }
582
+ /**
583
+ * Creates a matrix from a quaternion rotation, vector translation and vector scale
584
+ * This is equivalent to (but much faster than):
585
+ *
586
+ * mat4.identity(dest);
587
+ * mat4.translate(dest, vec);
588
+ * const quatMat = mat4.create();
589
+ * quat4.toMat4(quat, quatMat);
590
+ * mat4.multiply(dest, quatMat);
591
+ * mat4.scale(dest, scale)
592
+ *
593
+ * @param rot Rotation quaternion
594
+ * @param trans Translation vector
595
+ * @param scale Scaling vector
596
+ */
597
+ export function fromRotationTranslationScale(rot, trans, scale) {
598
+ // Quaternion math
599
+ const [x, y, z, w] = rot;
600
+ const x2 = x + x;
601
+ const y2 = y + y;
602
+ const z2 = z + z;
603
+ const xx = x * x2;
604
+ const xy = x * y2;
605
+ const xz = x * z2;
606
+ const yy = y * y2;
607
+ const yz = y * z2;
608
+ const zz = z * z2;
609
+ const wx = w * x2;
610
+ const wy = w * y2;
611
+ const wz = w * z2;
612
+ const sx = scale[0];
613
+ const sy = scale[1];
614
+ const sz = scale[2];
615
+ return [
616
+ (1 - (yy + zz)) * sx,
617
+ (xy + wz) * sx,
618
+ (xz - wy) * sx,
619
+ 0,
620
+ (xy - wz) * sy,
621
+ (1 - (xx + zz)) * sy,
622
+ (yz + wx) * sy,
623
+ 0,
624
+ (xz + wy) * sz,
625
+ (yz - wx) * sz,
626
+ (1 - (xx + yy)) * sz,
627
+ 0,
628
+ trans[0],
629
+ trans[1],
630
+ trans[2],
631
+ 1,
632
+ ];
633
+ }
634
+ /**
635
+ * Creates a matrix from a quaternion rotation, vector translation and vector scale, rotating and scaling around the given origin
636
+ * This is equivalent to (but much faster than):
637
+ *
638
+ * mat4.identity(dest);
639
+ * mat4.translate(dest, vec);
640
+ * mat4.translate(dest, origin);
641
+ * const quatMat = mat4.create();
642
+ * quat4.toMat4(quat, quatMat);
643
+ * mat4.multiply(dest, quatMat);
644
+ * mat4.scale(dest, scale)
645
+ * mat4.translate(dest, negativeOrigin);
646
+ *
647
+ * @param rot Rotation quaternion
648
+ * @param trans Translation vector
649
+ * @param scale Scaling vector
650
+ * @param origin The origin vector around which to scale and rotate
651
+ */
652
+ export function fromRotationTranslationScaleOrigin(rot, trans, scale, origin) {
653
+ // Quaternion math
654
+ const [x, y, z, w] = rot;
655
+ const x2 = x + x;
656
+ const y2 = y + y;
657
+ const z2 = z + z;
658
+ const xx = x * x2;
659
+ const xy = x * y2;
660
+ const xz = x * z2;
661
+ const yy = y * y2;
662
+ const yz = y * z2;
663
+ const zz = z * z2;
664
+ const wx = w * x2;
665
+ const wy = w * y2;
666
+ const wz = w * z2;
667
+ const sx = scale[0];
668
+ const sy = scale[1];
669
+ const sz = scale[2];
670
+ const ox = origin[0];
671
+ const oy = origin[1];
672
+ const oz = origin[2];
673
+ const out0 = (1 - (yy + zz)) * sx;
674
+ const out1 = (xy + wz) * sx;
675
+ const out2 = (xz - wy) * sx;
676
+ const out4 = (xy - wz) * sy;
677
+ const out5 = (1 - (xx + zz)) * sy;
678
+ const out6 = (yz + wx) * sy;
679
+ const out8 = (xz + wy) * sz;
680
+ const out9 = (yz - wx) * sz;
681
+ const out10 = (1 - (xx + yy)) * sz;
682
+ // prettier-ignore
683
+ return [
684
+ out0, out1, out2, 0,
685
+ out4, out5, out6, 0,
686
+ out8, out9, out10, 0,
687
+ trans[0] + ox - (out0 * ox + out4 * oy + out8 * oz),
688
+ trans[1] + oy - (out1 * ox + out5 * oy + out9 * oz),
689
+ trans[2] + oz - (out2 * ox + out6 * oy + out10 * oz),
690
+ 1,
691
+ ];
692
+ }
693
+ /**
694
+ * Calculates a 4x4 matrix from the given quaternion
695
+ *
696
+ * @param q Quaternion to create matrix from
697
+ */
698
+ export function fromQuat(q) {
699
+ const [x, y, z, w] = q;
700
+ const x2 = x + x;
701
+ const y2 = y + y;
702
+ const z2 = z + z;
703
+ const xx = x * x2;
704
+ const yx = y * x2;
705
+ const yy = y * y2;
706
+ const zx = z * x2;
707
+ const zy = z * y2;
708
+ const zz = z * z2;
709
+ const wx = w * x2;
710
+ const wy = w * y2;
711
+ const wz = w * z2;
712
+ // prettier-ignore
713
+ return [
714
+ 1 - yy - zz,
715
+ yx + wz,
716
+ zx - wy,
717
+ 0,
718
+ yx - wz,
719
+ 1 - xx - zz,
720
+ zy + wx,
721
+ 0,
722
+ zx + wy,
723
+ zy - wx,
724
+ 1 - xx - yy,
725
+ 0,
726
+ 0, 0, 0, 1,
727
+ ];
728
+ }
729
+ /**
730
+ * Generates a frustum matrix with the given bounds
731
+ *
732
+ * @param left Left bound of the frustum
733
+ * @param right Right bound of the frustum
734
+ * @param bottom Bottom bound of the frustum
735
+ * @param top Top bound of the frustum
736
+ * @param near Near bound of the frustum
737
+ * @param far Far bound of the frustum
738
+ */
739
+ export function frustum(left, right, bottom, top, near, far) {
740
+ const rl = 1 / (right - left);
741
+ const tb = 1 / (top - bottom);
742
+ const nf = 1 / (near - far);
743
+ // prettier-ignore
744
+ return [
745
+ near * 2 * rl, 0, 0, 0,
746
+ 0, near * 2 * tb, 0, 0,
747
+ (right + left) * rl, (top + bottom) * tb, (far + near) * nf, -1,
748
+ 0, 0, far * near * 2 * nf, 0,
749
+ ];
750
+ }
751
+ /**
752
+ * Generates a perspective projection matrix with the given bounds.
753
+ * The near/far clip planes correspond to a normalized device coordinate Z range of [-1, 1],
754
+ * which matches WebGL/OpenGL's clip volume.
755
+ * Passing null/undefined/no value for far will generate infinite projection matrix.
756
+ *
757
+ * @param fovy Vertical field of view in radians
758
+ * @param aspect Aspect ratio. typically viewport width/height
759
+ * @param near Near bound of the frustum
760
+ * @param far Far bound of the frustum, can be null or Infinity
761
+ */
762
+ export function perspectiveNO(fovy, aspect, near, far) {
763
+ const f = 1 / Math.tan(fovy / 2);
764
+ let out10, out14;
765
+ if (far !== null && far !== Infinity) {
766
+ const nf = 1 / (near - far);
767
+ out10 = (far + near) * nf;
768
+ out14 = 2 * far * near * nf;
769
+ }
770
+ else {
771
+ out10 = -1;
772
+ out14 = -2 * near;
773
+ }
774
+ // prettier-ignore
775
+ return [
776
+ f / aspect, 0, 0, 0,
777
+ 0, f, 0, 0,
778
+ 0, 0, out10, -1,
779
+ 0, 0, out14, 0,
780
+ ];
781
+ }
782
+ /**
783
+ * Alias for {@link mat4.perspectiveNO}
784
+ * @function
785
+ */
786
+ export const perspective = perspectiveNO;
787
+ /**
788
+ * Generates a perspective projection matrix suitable for WebGPU with the given bounds.
789
+ * The near/far clip planes correspond to a normalized device coordinate Z range of [0, 1],
790
+ * which matches WebGPU/Vulkan/DirectX/Metal's clip volume.
791
+ * Passing null/undefined/no value for far will generate infinite projection matrix.
792
+ *
793
+ * @param fovy Vertical field of view in radians
794
+ * @param aspect Aspect ratio. typically viewport width/height
795
+ * @param near Near bound of the frustum
796
+ * @param far Far bound of the frustum, can be null or Infinity
797
+ */
798
+ export function perspectiveZO(fovy, aspect, near, far) {
799
+ const f = 1 / Math.tan(fovy / 2);
800
+ let out10, out14;
801
+ if (far !== null && far !== Infinity) {
802
+ const nf = 1 / (near - far);
803
+ out10 = far * nf;
804
+ out14 = far * near * nf;
805
+ }
806
+ else {
807
+ out10 = -1;
808
+ out14 = -near;
809
+ }
810
+ return [f / aspect, 0, 0, 0, 0, f, 0, 0, 0, 0, out10, -1, 0, 0, out14, 0];
811
+ }
812
+ /**
813
+ * Generates a perspective projection matrix with the given field of view.
814
+ * This is primarily useful for generating projection matrices to be used
815
+ * with the still experiemental WebVR API.
816
+ *
817
+ * @param fov Object containing the following values: upDegrees, downDegrees, leftDegrees, rightDegrees
818
+ * @param near Near bound of the frustum
819
+ * @param far Far bound of the frustum
820
+ */
821
+ export function perspectiveFromFieldOfView(fov, near, far) {
822
+ const upTan = Math.tan((fov.upDegrees * Math.PI) / 180);
823
+ const downTan = Math.tan((fov.downDegrees * Math.PI) / 180);
824
+ const leftTan = Math.tan((fov.leftDegrees * Math.PI) / 180);
825
+ const rightTan = Math.tan((fov.rightDegrees * Math.PI) / 180);
826
+ const xScale = 2 / (leftTan + rightTan);
827
+ const yScale = 2 / (upTan + downTan);
828
+ // prettier-ignore
829
+ return [
830
+ xScale, 0, 0, 0,
831
+ 0, yScale, 0, 0,
832
+ -((leftTan - rightTan) * xScale * 0.5),
833
+ (upTan - downTan) * yScale * 0.5,
834
+ far / (near - far),
835
+ -1,
836
+ 0,
837
+ 0,
838
+ (far * near) / (near - far),
839
+ 0,
840
+ ];
841
+ }
842
+ /**
843
+ * Generates a orthogonal projection matrix with the given bounds.
844
+ * The near/far clip planes correspond to a normalized device coordinate Z range of [-1, 1],
845
+ * which matches WebGL/OpenGL's clip volume.
846
+ *
847
+ * @param left Left bound of the frustum
848
+ * @param right Right bound of the frustum
849
+ * @param bottom Bottom bound of the frustum
850
+ * @param top Top bound of the frustum
851
+ * @param near Near bound of the frustum
852
+ * @param far Far bound of the frustum
853
+ */
854
+ export function orthoNO(left, right, bottom, top, near, far) {
855
+ const lr = 1 / (left - right);
856
+ const bt = 1 / (bottom - top);
857
+ const nf = 1 / (near - far);
858
+ // prettier-ignore
859
+ return [
860
+ -2 * lr, 0, 0, 0,
861
+ 0, -2 * bt, 0, 0,
862
+ 0, 0, 2 * nf, 0,
863
+ (left + right) * lr,
864
+ (top + bottom) * bt,
865
+ (far + near) * nf,
866
+ 1,
867
+ ];
868
+ }
869
+ /**
870
+ * Alias for {@link mat4.orthoNO}
871
+ * @function
872
+ */
873
+ export const ortho = orthoNO;
874
+ /**
875
+ * Generates a orthogonal projection matrix with the given bounds.
876
+ * The near/far clip planes correspond to a normalized device coordinate Z range of [0, 1],
877
+ * which matches WebGPU/Vulkan/DirectX/Metal's clip volume.
878
+ *
879
+ * @param left Left bound of the frustum
880
+ * @param right Right bound of the frustum
881
+ * @param bottom Bottom bound of the frustum
882
+ * @param top Top bound of the frustum
883
+ * @param near Near bound of the frustum
884
+ * @param far Far bound of the frustum
885
+ */
886
+ export function orthoZO(left, right, bottom, top, near, far) {
887
+ const lr = 1 / (left - right);
888
+ const bt = 1 / (bottom - top);
889
+ const nf = 1 / (near - far);
890
+ // prettier-ignore
891
+ return [
892
+ -2 * lr, 0, 0, 0,
893
+ 0, -2 * bt, 0, 0,
894
+ 0, 0, nf, 0,
895
+ (left + right) * lr,
896
+ (top + bottom) * bt,
897
+ near * nf,
898
+ 1,
899
+ ];
900
+ }
901
+ /**
902
+ * Generates a look-at matrix with the given eye position, focal point, and up axis.
903
+ * If you want a matrix that actually makes an object look at another object, you should use targetTo instead.
904
+ *
905
+ * @param eye Position of the viewer
906
+ * @param center Point the viewer is looking at
907
+ * @param up vec3 pointing up
908
+ */
909
+ export function lookAt(eye, center, up) {
910
+ let x0, x1, x2, y0, y1, y2, z0, z1, z2, len;
911
+ const eyex = eye[0];
912
+ const eyey = eye[1];
913
+ const eyez = eye[2];
914
+ const upx = up[0];
915
+ const upy = up[1];
916
+ const upz = up[2];
917
+ const centerx = center[0];
918
+ const centery = center[1];
919
+ const centerz = center[2];
920
+ if (Math.abs(eyex - centerx) < Common.EPSILON &&
921
+ Math.abs(eyey - centery) < Common.EPSILON &&
922
+ Math.abs(eyez - centerz) < Common.EPSILON) {
923
+ return identity;
924
+ }
925
+ z0 = eyex - centerx;
926
+ z1 = eyey - centery;
927
+ z2 = eyez - centerz;
928
+ len = 1 / Math.sqrt(z0 * z0 + z1 * z1 + z2 * z2);
929
+ z0 *= len;
930
+ z1 *= len;
931
+ z2 *= len;
932
+ x0 = upy * z2 - upz * z1;
933
+ x1 = upz * z0 - upx * z2;
934
+ x2 = upx * z1 - upy * z0;
935
+ len = Math.sqrt(x0 * x0 + x1 * x1 + x2 * x2);
936
+ if (!len) {
937
+ x0 = 0;
938
+ x1 = 0;
939
+ x2 = 0;
940
+ }
941
+ else {
942
+ len = 1 / len;
943
+ x0 *= len;
944
+ x1 *= len;
945
+ x2 *= len;
946
+ }
947
+ y0 = z1 * x2 - z2 * x1;
948
+ y1 = z2 * x0 - z0 * x2;
949
+ y2 = z0 * x1 - z1 * x0;
950
+ len = Math.sqrt(y0 * y0 + y1 * y1 + y2 * y2);
951
+ if (!len) {
952
+ y0 = 0;
953
+ y1 = 0;
954
+ y2 = 0;
955
+ }
956
+ else {
957
+ len = 1 / len;
958
+ y0 *= len;
959
+ y1 *= len;
960
+ y2 *= len;
961
+ }
962
+ // prettier-ignore
963
+ return [
964
+ x0, y0, z0, 0,
965
+ x1, y1, z1, 0,
966
+ x2, y2, z2, 0,
967
+ -(x0 * eyex + x1 * eyey + x2 * eyez),
968
+ -(y0 * eyex + y1 * eyey + y2 * eyez),
969
+ -(z0 * eyex + z1 * eyey + z2 * eyez),
970
+ 1,
971
+ ];
972
+ }
973
+ /**
974
+ * Generates a matrix that makes something look at something else.
975
+ *
976
+ * @param eye Position of the viewer
977
+ * @param center Point the viewer is looking at
978
+ * @param up vec3 pointing up
979
+ */
980
+ export function targetTo(eye, target, up) {
981
+ const [eyex, eyey, eyez] = eye;
982
+ const [upx, upy, upz] = up;
983
+ let z0 = eyex - target[0], z1 = eyey - target[1], z2 = eyez - target[2];
984
+ let len = z0 * z0 + z1 * z1 + z2 * z2;
985
+ if (len > 0) {
986
+ len = 1 / Math.sqrt(len);
987
+ z0 *= len;
988
+ z1 *= len;
989
+ z2 *= len;
990
+ }
991
+ let x0 = upy * z2 - upz * z1, x1 = upz * z0 - upx * z2, x2 = upx * z1 - upy * z0;
992
+ len = x0 * x0 + x1 * x1 + x2 * x2;
993
+ if (len > 0) {
994
+ len = 1 / Math.sqrt(len);
995
+ x0 *= len;
996
+ x1 *= len;
997
+ x2 *= len;
998
+ }
999
+ // prettier-ignore
1000
+ return [
1001
+ x0, x1, x2, 0,
1002
+ z1 * x2 - z2 * x1,
1003
+ z2 * x0 - z0 * x2,
1004
+ z0 * x1 - z1 * x0,
1005
+ 0,
1006
+ z0, z1, z2, 0,
1007
+ eyex, eyey, eyez, 1,
1008
+ ];
1009
+ }
1010
+ /**
1011
+ * Returns Frobenius norm of a mat4
1012
+ */
1013
+ export function frob(a) {
1014
+ return Math.sqrt(a[0] * a[0] +
1015
+ a[1] * a[1] +
1016
+ a[2] * a[2] +
1017
+ a[3] * a[3] +
1018
+ a[4] * a[4] +
1019
+ a[5] * a[5] +
1020
+ a[6] * a[6] +
1021
+ a[7] * a[7] +
1022
+ a[8] * a[8] +
1023
+ a[9] * a[9] +
1024
+ a[10] * a[10] +
1025
+ a[11] * a[11] +
1026
+ a[12] * a[12] +
1027
+ a[13] * a[13] +
1028
+ a[14] * a[14] +
1029
+ a[15] * a[15]);
1030
+ }
1031
+ /**
1032
+ * Adds two mat4's
1033
+ */
1034
+ export function add(a, b) {
1035
+ return [
1036
+ a[0] + b[0],
1037
+ a[1] + b[1],
1038
+ a[2] + b[2],
1039
+ a[3] + b[3],
1040
+ a[4] + b[4],
1041
+ a[5] + b[5],
1042
+ a[6] + b[6],
1043
+ a[7] + b[7],
1044
+ a[8] + b[8],
1045
+ a[9] + b[9],
1046
+ a[10] + b[10],
1047
+ a[11] + b[11],
1048
+ a[12] + b[12],
1049
+ a[13] + b[13],
1050
+ a[14] + b[14],
1051
+ a[15] + b[15],
1052
+ ];
1053
+ }
1054
+ /**
1055
+ * Subtracts matrix b from matrix a
1056
+ */
1057
+ export function subtract(a, b) {
1058
+ return [
1059
+ a[0] - b[0],
1060
+ a[1] - b[1],
1061
+ a[2] - b[2],
1062
+ a[3] - b[3],
1063
+ a[4] - b[4],
1064
+ a[5] - b[5],
1065
+ a[6] - b[6],
1066
+ a[7] - b[7],
1067
+ a[8] - b[8],
1068
+ a[9] - b[9],
1069
+ a[10] - b[10],
1070
+ a[11] - b[11],
1071
+ a[12] - b[12],
1072
+ a[13] - b[13],
1073
+ a[14] - b[14],
1074
+ a[15] - b[15],
1075
+ ];
1076
+ }
1077
+ /**
1078
+ * Multiply each element of the matrix by a scalar.
1079
+ */
1080
+ export function multiplyScalar(a, s) {
1081
+ return [
1082
+ a[0] * s,
1083
+ a[1] * s,
1084
+ a[2] * s,
1085
+ a[3] * s,
1086
+ a[4] * s,
1087
+ a[5] * s,
1088
+ a[6] * s,
1089
+ a[7] * s,
1090
+ a[8] * s,
1091
+ a[9] * s,
1092
+ a[10] * s,
1093
+ a[11] * s,
1094
+ a[12] * s,
1095
+ a[13] * s,
1096
+ a[14] * s,
1097
+ a[15] * s,
1098
+ ];
1099
+ }
1100
+ /**
1101
+ * Adds two mat4's after multiplying each element of the second operand by a scalar value.
1102
+ */
1103
+ export function multiplyScalarAndAdd(a, b, scale) {
1104
+ return [
1105
+ a[0] + b[0] * scale,
1106
+ a[1] + b[1] * scale,
1107
+ a[2] + b[2] * scale,
1108
+ a[3] + b[3] * scale,
1109
+ a[4] + b[4] * scale,
1110
+ a[5] + b[5] * scale,
1111
+ a[6] + b[6] * scale,
1112
+ a[7] + b[7] * scale,
1113
+ a[8] + b[8] * scale,
1114
+ a[9] + b[9] * scale,
1115
+ a[10] + b[10] * scale,
1116
+ a[11] + b[11] * scale,
1117
+ a[12] + b[12] * scale,
1118
+ a[13] + b[13] * scale,
1119
+ a[14] + b[14] * scale,
1120
+ a[15] + b[15] * scale,
1121
+ ];
1122
+ }
1123
+ /**
1124
+ * Returns whether or not the matrices have exactly the same elements in the same position (when compared with ===)
1125
+ */
1126
+ export function exactEquals(a, b) {
1127
+ return (a[0] === b[0] &&
1128
+ a[1] === b[1] &&
1129
+ a[2] === b[2] &&
1130
+ a[3] === b[3] &&
1131
+ a[4] === b[4] &&
1132
+ a[5] === b[5] &&
1133
+ a[6] === b[6] &&
1134
+ a[7] === b[7] &&
1135
+ a[8] === b[8] &&
1136
+ a[9] === b[9] &&
1137
+ a[10] === b[10] &&
1138
+ a[11] === b[11] &&
1139
+ a[12] === b[12] &&
1140
+ a[13] === b[13] &&
1141
+ a[14] === b[14] &&
1142
+ a[15] === b[15]);
1143
+ }
1144
+ /**
1145
+ * Returns whether or not the matrices have approximately the same elements in the same position.
1146
+ */
1147
+ export function equals(a, b) {
1148
+ const [a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, aA, aB, aC, aD, aE, aF] = a;
1149
+ const [b0, b1, b2, b3, b4, b5, b6, b7, b8, b9, bA, bB, bC, bD, bE, bF] = b;
1150
+ return (Math.abs(a0 - b0) <=
1151
+ Common.EPSILON * Math.max(1, Math.abs(a0), Math.abs(b0)) &&
1152
+ Math.abs(a1 - b1) <=
1153
+ Common.EPSILON * Math.max(1, Math.abs(a1), Math.abs(b1)) &&
1154
+ Math.abs(a2 - b2) <=
1155
+ Common.EPSILON * Math.max(1, Math.abs(a2), Math.abs(b2)) &&
1156
+ Math.abs(a3 - b3) <=
1157
+ Common.EPSILON * Math.max(1, Math.abs(a3), Math.abs(b3)) &&
1158
+ Math.abs(a4 - b4) <=
1159
+ Common.EPSILON * Math.max(1, Math.abs(a4), Math.abs(b4)) &&
1160
+ Math.abs(a5 - b5) <=
1161
+ Common.EPSILON * Math.max(1, Math.abs(a5), Math.abs(b5)) &&
1162
+ Math.abs(a6 - b6) <=
1163
+ Common.EPSILON * Math.max(1, Math.abs(a6), Math.abs(b6)) &&
1164
+ Math.abs(a7 - b7) <=
1165
+ Common.EPSILON * Math.max(1, Math.abs(a7), Math.abs(b7)) &&
1166
+ Math.abs(a8 - b8) <=
1167
+ Common.EPSILON * Math.max(1, Math.abs(a8), Math.abs(b8)) &&
1168
+ Math.abs(a9 - b9) <=
1169
+ Common.EPSILON * Math.max(1, Math.abs(a9), Math.abs(b9)) &&
1170
+ Math.abs(aA - bA) <=
1171
+ Common.EPSILON * Math.max(1, Math.abs(aA), Math.abs(bA)) &&
1172
+ Math.abs(aB - bB) <=
1173
+ Common.EPSILON * Math.max(1, Math.abs(aB), Math.abs(bB)) &&
1174
+ Math.abs(aC - bC) <=
1175
+ Common.EPSILON * Math.max(1, Math.abs(aC), Math.abs(bC)) &&
1176
+ Math.abs(aD - bD) <=
1177
+ Common.EPSILON * Math.max(1, Math.abs(aD), Math.abs(bD)) &&
1178
+ Math.abs(aE - bE) <=
1179
+ Common.EPSILON * Math.max(1, Math.abs(aE), Math.abs(bE)) &&
1180
+ Math.abs(aF - bF) <=
1181
+ Common.EPSILON * Math.max(1, Math.abs(aF), Math.abs(bF)));
1182
+ }
1183
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mat4.js","sourceRoot":"","sources":["../../src/mat4.ts"],"names":[],"mappings":"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AC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QACzD,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC;YAChB,MAAM,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QACzD,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC;YAChB,MAAM,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QACzD,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC;YAChB,MAAM,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QACzD,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC;YAChB,MAAM,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QACzD,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC;YAChB,MAAM,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QACzD,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC;YAChB,MAAM,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QACzD,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC;YAChB,MAAM,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QACzD,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC;YAChB,MAAM,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QACzD,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC;YAChB,MAAM,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QACzD,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC;YAChB,MAAM,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QACzD,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC;YAChB,MAAM,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CACzD,CAAA;AACF,CAAC"}