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