linearly 0.20.2 → 0.20.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/lib/mat3.js ADDED
@@ -0,0 +1,450 @@
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.projection = exports.normalFromMat4 = exports.fromQuat = exports.fromMat2d = exports.fromScaling = exports.fromRotation = exports.fromTranslation = exports.scale = exports.rotate = exports.translate = exports.multiply = exports.determinant = exports.adjoint = exports.invert = exports.transpose = exports.zero = exports.identity = exports.fromMat4 = void 0;
36
+ const Common = __importStar(require("./common"));
37
+ /**
38
+ * 3x3 Matrix
39
+ * @module mat3
40
+ */
41
+ /**
42
+ * Copies the upper-left 3x3 values into the given mat3.
43
+ */
44
+ function fromMat4(a) {
45
+ // prettier-ignore
46
+ return [
47
+ a[0], a[1], a[2],
48
+ a[4], a[5], a[6],
49
+ a[8], a[9], a[10]
50
+ ];
51
+ }
52
+ exports.fromMat4 = fromMat4;
53
+ /**
54
+ * The identity matrix of mat3
55
+ */
56
+ // prettier-ignore
57
+ exports.identity = Object.freeze([
58
+ 1, 0, 0,
59
+ 0, 1, 0,
60
+ 0, 0, 1,
61
+ ]);
62
+ exports.zero = Object.freeze([0, 0, 0, 0, 0, 0, 0, 0, 0]);
63
+ /**
64
+ * Transpose the values of a mat3
65
+ */
66
+ function transpose(a) {
67
+ // prettier-ignore
68
+ return [
69
+ a[0], a[3], a[6],
70
+ a[1], a[4], a[7],
71
+ a[2], a[5], a[8]
72
+ ];
73
+ }
74
+ exports.transpose = transpose;
75
+ /**
76
+ * Inverts a mat3
77
+ */
78
+ function invert(a) {
79
+ const [a00, a01, a02, a10, a11, a12, a20, a21, a22] = a;
80
+ const b01 = a22 * a11 - a12 * a21;
81
+ const b11 = -a22 * a10 + a12 * a20;
82
+ const b21 = a21 * a10 - a11 * a20;
83
+ // Calculate the determinant
84
+ const det = a00 * b01 + a01 * b11 + a02 * b21;
85
+ if (!det) {
86
+ return null;
87
+ }
88
+ const detinv = 1 / det;
89
+ return [
90
+ b01 * detinv,
91
+ (-a22 * a01 + a02 * a21) * detinv,
92
+ (a12 * a01 - a02 * a11) * detinv,
93
+ b11 * detinv,
94
+ (a22 * a00 - a02 * a20) * detinv,
95
+ (-a12 * a00 + a02 * a10) * detinv,
96
+ b21 * detinv,
97
+ (-a21 * a00 + a01 * a20) * detinv,
98
+ (a11 * a00 - a01 * a10) * detinv,
99
+ ];
100
+ }
101
+ exports.invert = invert;
102
+ /**
103
+ * Calculates the adjugate of a mat3
104
+ */
105
+ function adjoint(a) {
106
+ const [a00, a01, a02, a10, a11, a12, a20, a21, a22] = a;
107
+ return [
108
+ a11 * a22 - a12 * a21,
109
+ a02 * a21 - a01 * a22,
110
+ a01 * a12 - a02 * a11,
111
+ a12 * a20 - a10 * a22,
112
+ a00 * a22 - a02 * a20,
113
+ a02 * a10 - a00 * a12,
114
+ a10 * a21 - a11 * a20,
115
+ a01 * a20 - a00 * a21,
116
+ a00 * a11 - a01 * a10,
117
+ ];
118
+ }
119
+ exports.adjoint = adjoint;
120
+ /**
121
+ * Calculates the determinant of a mat3
122
+ */
123
+ function determinant(a) {
124
+ const [a00, a01, a02, a10, a11, a12, a20, a21, a22] = a;
125
+ return (a00 * (a22 * a11 - a12 * a21) +
126
+ a01 * (-a22 * a10 + a12 * a20) +
127
+ a02 * (a21 * a10 - a11 * a20));
128
+ }
129
+ exports.determinant = determinant;
130
+ /**
131
+ * Multiplies two mat3's
132
+ */
133
+ function multiply(a, b) {
134
+ const [a00, a01, a02, a10, a11, a12, a20, a21, a22] = a;
135
+ const [b00, b01, b02, b10, b11, b12, b20, b21, b22] = b;
136
+ return [
137
+ b00 * a00 + b01 * a10 + b02 * a20,
138
+ b00 * a01 + b01 * a11 + b02 * a21,
139
+ b00 * a02 + b01 * a12 + b02 * a22,
140
+ b10 * a00 + b11 * a10 + b12 * a20,
141
+ b10 * a01 + b11 * a11 + b12 * a21,
142
+ b10 * a02 + b11 * a12 + b12 * a22,
143
+ b20 * a00 + b21 * a10 + b22 * a20,
144
+ b20 * a01 + b21 * a11 + b22 * a21,
145
+ b20 * a02 + b21 * a12 + b22 * a22,
146
+ ];
147
+ }
148
+ exports.multiply = multiply;
149
+ /**
150
+ * Translate a mat3 by the given vector
151
+ */
152
+ function translate(a, v) {
153
+ const [a00, a01, a02, a10, a11, a12, a20, a21, a22] = a;
154
+ const [x, y] = v;
155
+ // prettier-ignore
156
+ return [
157
+ a00, a01, a02,
158
+ a10, a11, a12,
159
+ x * a00 + y * a10 + a20,
160
+ x * a01 + y * a11 + a21,
161
+ x * a02 + y * a12 + a22,
162
+ ];
163
+ }
164
+ exports.translate = translate;
165
+ /**
166
+ * Rotates a mat3 by the given angle
167
+ */
168
+ function rotate(a, rad) {
169
+ const [a00, a01, a02, a10, a11, a12, a20, a21, a22] = a;
170
+ const s = Math.sin(rad);
171
+ const c = Math.cos(rad);
172
+ // prettier-ignore
173
+ return [
174
+ c * a00 + s * a10,
175
+ c * a01 + s * a11,
176
+ c * a02 + s * a12,
177
+ c * a10 - s * a00,
178
+ c * a11 - s * a01,
179
+ c * a12 - s * a02,
180
+ a20, a21, a22,
181
+ ];
182
+ }
183
+ exports.rotate = rotate;
184
+ /**
185
+ * Scales the mat3 by the dimensions in the given vec2
186
+ **/
187
+ function scale(a, v) {
188
+ const [x, y] = v;
189
+ // prettier-ignore
190
+ return [
191
+ a[0] * x, a[1] * x, a[2] & x,
192
+ a[3] * y, a[4] * y, a[5] * y,
193
+ a[6], a[7], a[8],
194
+ ];
195
+ }
196
+ exports.scale = scale;
197
+ /**
198
+ * Creates a matrix from a vector translation
199
+ */
200
+ function fromTranslation(v) {
201
+ const [x, y] = v;
202
+ // prettier-ignore
203
+ return [
204
+ 1, 0, 0,
205
+ 0, 1, 0,
206
+ x, y, 1,
207
+ ];
208
+ }
209
+ exports.fromTranslation = fromTranslation;
210
+ /**
211
+ * Creates a matrix from a given angle
212
+ */
213
+ function fromRotation(rad) {
214
+ const s = Math.sin(rad);
215
+ const c = Math.cos(rad);
216
+ // prettier-ignore
217
+ return [
218
+ c, s, 0,
219
+ -s, c, 0,
220
+ 0, 0, 1,
221
+ ];
222
+ }
223
+ exports.fromRotation = fromRotation;
224
+ /**
225
+ * Creates a matrix from a vector scaling
226
+ */
227
+ function fromScaling(v) {
228
+ const [x, y] = v;
229
+ // prettier-ignore
230
+ return [
231
+ x, 0, 0,
232
+ 0, y, 0,
233
+ 0, 0, 1
234
+ ];
235
+ }
236
+ exports.fromScaling = fromScaling;
237
+ /**
238
+ * Copies the values from a mat2d into a mat3
239
+ **/
240
+ function fromMat2d(a) {
241
+ // prettier-ignore
242
+ return [
243
+ a[0], a[1], 0,
244
+ a[2], a[3], 0,
245
+ a[4], a[5], 1
246
+ ];
247
+ }
248
+ exports.fromMat2d = fromMat2d;
249
+ /**
250
+ * Calculates a 3x3 matrix from the given quaternion
251
+ *
252
+ */
253
+ function fromQuat(q) {
254
+ const [x, y, z, w] = q;
255
+ const x2 = x + x;
256
+ const y2 = y + y;
257
+ const z2 = z + z;
258
+ const xx = x * x2;
259
+ const yx = y * x2;
260
+ const yy = y * y2;
261
+ const zx = z * x2;
262
+ const zy = z * y2;
263
+ const zz = z * z2;
264
+ const wx = w * x2;
265
+ const wy = w * y2;
266
+ const wz = w * z2;
267
+ return [
268
+ 1 - yy - zz,
269
+ yx - wz,
270
+ zx + wy,
271
+ yx + wz,
272
+ 1 - xx - zz,
273
+ zy - wx,
274
+ zx - wy,
275
+ zy + wx,
276
+ 1 - xx - yy,
277
+ ];
278
+ }
279
+ exports.fromQuat = fromQuat;
280
+ /**
281
+ * Calculates a 3x3 normal matrix (transpose inverse) from the 4x4 matrix
282
+ *
283
+ */
284
+ function normalFromMat4(a) {
285
+ // prettier-ignore
286
+ const [a00, a01, a02, a03, a10, a11, a12, a13, a20, a21, a22, a23, a30, a31, a32, a33] = a;
287
+ const b00 = a00 * a11 - a01 * a10;
288
+ const b01 = a00 * a12 - a02 * a10;
289
+ const b02 = a00 * a13 - a03 * a10;
290
+ const b03 = a01 * a12 - a02 * a11;
291
+ const b04 = a01 * a13 - a03 * a11;
292
+ const b05 = a02 * a13 - a03 * a12;
293
+ const b06 = a20 * a31 - a21 * a30;
294
+ const b07 = a20 * a32 - a22 * a30;
295
+ const b08 = a20 * a33 - a23 * a30;
296
+ const b09 = a21 * a32 - a22 * a31;
297
+ const b10 = a21 * a33 - a23 * a31;
298
+ const b11 = a22 * a33 - a23 * a32;
299
+ // Calculate the determinant
300
+ const det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;
301
+ if (!det) {
302
+ return null;
303
+ }
304
+ const detinv = 1 / det;
305
+ return [
306
+ (a11 * b11 - a12 * b10 + a13 * b09) * detinv,
307
+ (a12 * b08 - a10 * b11 - a13 * b07) * detinv,
308
+ (a10 * b10 - a11 * b08 + a13 * b06) * detinv,
309
+ (a02 * b10 - a01 * b11 - a03 * b09) * detinv,
310
+ (a00 * b11 - a02 * b08 + a03 * b07) * detinv,
311
+ (a01 * b08 - a00 * b10 - a03 * b06) * detinv,
312
+ (a31 * b05 - a32 * b04 + a33 * b03) * detinv,
313
+ (a32 * b02 - a30 * b05 - a33 * b01) * detinv,
314
+ (a30 * b04 - a31 * b02 + a33 * b00) * detinv,
315
+ ];
316
+ }
317
+ exports.normalFromMat4 = normalFromMat4;
318
+ /**
319
+ * Generates a 2D projection matrix with the given bounds
320
+ */
321
+ function projection(width, height) {
322
+ return [2 / width, 0, 0, 0, -2 / height, 0, -1, 1, 1];
323
+ }
324
+ exports.projection = projection;
325
+ /**
326
+ * Returns Frobenius norm of a mat3
327
+ */
328
+ function frob(a) {
329
+ return Math.sqrt(a[0] * a[0] +
330
+ a[1] * a[1] +
331
+ a[2] * a[2] +
332
+ a[3] * a[3] +
333
+ a[4] * a[4] +
334
+ a[5] * a[5] +
335
+ a[6] * a[6] +
336
+ a[7] * a[7] +
337
+ a[8] * a[8]);
338
+ }
339
+ exports.frob = frob;
340
+ /**
341
+ * Adds two mat3's
342
+ */
343
+ function add(a, b) {
344
+ return [
345
+ a[0] + b[0],
346
+ a[1] + b[1],
347
+ a[2] + b[2],
348
+ a[3] + b[3],
349
+ a[4] + b[4],
350
+ a[5] + b[5],
351
+ a[6] + b[6],
352
+ a[7] + b[7],
353
+ a[8] + b[8],
354
+ ];
355
+ }
356
+ exports.add = add;
357
+ /**
358
+ * Subtracts matrix b from matrix a
359
+ */
360
+ function subtract(a, b) {
361
+ return [
362
+ a[0] - b[0],
363
+ a[1] - b[1],
364
+ a[2] - b[2],
365
+ a[3] - b[3],
366
+ a[4] - b[4],
367
+ a[5] - b[5],
368
+ a[6] - b[6],
369
+ a[7] - b[7],
370
+ a[8] - b[8],
371
+ ];
372
+ }
373
+ exports.subtract = subtract;
374
+ /**
375
+ * Multiply each element of the matrix by a scalar.
376
+ */
377
+ function multiplyScalar(a, s) {
378
+ return [
379
+ a[0] * s,
380
+ a[1] * s,
381
+ a[2] * s,
382
+ a[3] * s,
383
+ a[4] * s,
384
+ a[5] * s,
385
+ a[6] * s,
386
+ a[7] * s,
387
+ a[8] * s,
388
+ ];
389
+ }
390
+ exports.multiplyScalar = multiplyScalar;
391
+ /**
392
+ * Adds two mat3's after multiplying each element of the second operand by a scalar value.
393
+ */
394
+ function multiplyScalarAndAdd(a, b, scale) {
395
+ return [
396
+ a[0] + b[0] * scale,
397
+ a[1] + b[1] * scale,
398
+ a[2] + b[2] * scale,
399
+ a[3] + b[3] * scale,
400
+ a[4] + b[4] * scale,
401
+ a[5] + b[5] * scale,
402
+ a[6] + b[6] * scale,
403
+ a[7] + b[7] * scale,
404
+ a[8] + b[8] * scale,
405
+ ];
406
+ }
407
+ exports.multiplyScalarAndAdd = multiplyScalarAndAdd;
408
+ /**
409
+ * Returns whether or not the matrices have exactly the same elements in the same position (when compared with ===)
410
+ */
411
+ function exactEquals(a, b) {
412
+ return (a[0] === b[0] &&
413
+ a[1] === b[1] &&
414
+ a[2] === b[2] &&
415
+ a[3] === b[3] &&
416
+ a[4] === b[4] &&
417
+ a[5] === b[5] &&
418
+ a[6] === b[6] &&
419
+ a[7] === b[7] &&
420
+ a[8] === b[8]);
421
+ }
422
+ exports.exactEquals = exactEquals;
423
+ /**
424
+ * Returns whether or not the matrices have approximately the same elements in the same position.
425
+ */
426
+ function equals(a, b) {
427
+ const a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3], a4 = a[4], a5 = a[5], a6 = a[6], a7 = a[7], a8 = a[8];
428
+ const b0 = b[0], b1 = b[1], b2 = b[2], b3 = b[3], b4 = b[4], b5 = b[5], b6 = b[6], b7 = b[7], b8 = b[8];
429
+ return (Math.abs(a0 - b0) <=
430
+ Common.EPSILON * Math.max(1, Math.abs(a0), Math.abs(b0)) &&
431
+ Math.abs(a1 - b1) <=
432
+ Common.EPSILON * Math.max(1, Math.abs(a1), Math.abs(b1)) &&
433
+ Math.abs(a2 - b2) <=
434
+ Common.EPSILON * Math.max(1, Math.abs(a2), Math.abs(b2)) &&
435
+ Math.abs(a3 - b3) <=
436
+ Common.EPSILON * Math.max(1, Math.abs(a3), Math.abs(b3)) &&
437
+ Math.abs(a4 - b4) <=
438
+ Common.EPSILON * Math.max(1, Math.abs(a4), Math.abs(b4)) &&
439
+ Math.abs(a5 - b5) <=
440
+ Common.EPSILON * Math.max(1, Math.abs(a5), Math.abs(b5)) &&
441
+ Math.abs(a6 - b6) <=
442
+ Common.EPSILON * Math.max(1, Math.abs(a6), Math.abs(b6)) &&
443
+ Math.abs(a7 - b7) <=
444
+ Common.EPSILON * Math.max(1, Math.abs(a7), Math.abs(b7)) &&
445
+ Math.abs(a8 - b8) <=
446
+ Common.EPSILON * Math.max(1, Math.abs(a8), Math.abs(b8)));
447
+ }
448
+ exports.equals = equals;
449
+ });
450
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mat3.js","sourceRoot":"","sources":["../src/mat3.ts"],"names":[],"mappings":"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"}