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