linearly 0.36.1 → 0.37.0

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/cjs/mat2.js DELETED
@@ -1,474 +0,0 @@
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 () {
19
- var ownKeys = function(o) {
20
- ownKeys = Object.getOwnPropertyNames || function (o) {
21
- var ar = [];
22
- for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
- return ar;
24
- };
25
- return ownKeys(o);
26
- };
27
- return function (mod) {
28
- if (mod && mod.__esModule) return mod;
29
- var result = {};
30
- if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
- __setModuleDefault(result, mod);
32
- return result;
33
- };
34
- })();
35
- Object.defineProperty(exports, "__esModule", { value: true });
36
- exports.mat2 = void 0;
37
- const Common = __importStar(require("./common"));
38
- const vec2_1 = require("./vec2");
39
- /**
40
- * Functions for {@link mat2}, 2D transformation matrix excluding translation.
41
- * @category Modules
42
- */
43
- var mat2;
44
- (function (mat2) {
45
- /**
46
- * Creates a new matrix from given elements
47
- * @category Generators
48
- */
49
- function of(m00, m01, m10, m11) {
50
- return [m00, m01, m10, m11];
51
- }
52
- mat2.of = of;
53
- /**
54
- * Creates a mutable clone of given mat2
55
- * @category Generators
56
- */
57
- function clone(a) {
58
- return [...a];
59
- }
60
- mat2.clone = clone;
61
- /**
62
- * The identity matrix of mat2.
63
- * ```ts
64
- * [1, 0,
65
- * 0, 1]
66
- * ```
67
- * @category Constants
68
- *
69
- * @shorthands
70
- * - {@link id}
71
- * - {@link ident}
72
- */
73
- mat2.identity = Object.freeze([1, 0, 0, 1]);
74
- /**
75
- * Alias for {@link identity}
76
- * @category Shorthands
77
- */
78
- mat2.I = mat2.identity;
79
- /**
80
- * Alias for {@link identity}
81
- * @category Shorthands
82
- */
83
- mat2.id = mat2.identity;
84
- /**
85
- * Alias for {@link identity}
86
- * @category Shorthands
87
- */
88
- mat2.ident = mat2.identity;
89
- /**
90
- * The mat2 filled with zeros.
91
- * @category Constants
92
- */
93
- mat2.zero = Object.freeze([0, 0, 0, 0]);
94
- /**
95
- * Transpose the values of a mat2
96
- */
97
- function transpose(a) {
98
- // prettier-ignore
99
- return [
100
- a[0], a[2],
101
- a[1], a[3],
102
- ];
103
- }
104
- mat2.transpose = transpose;
105
- /**
106
- * Inverts a mat2
107
- *
108
- * @shorthands
109
- * - {@link inv}
110
- */
111
- function invert(a) {
112
- const [a0, a1, a2, a3] = a;
113
- // Calculate the determinant
114
- const det = a0 * a3 - a2 * a1;
115
- if (!det) {
116
- return null;
117
- }
118
- const detinv = 1 / det;
119
- // prettier-ignore
120
- return [
121
- a3 * detinv, -a1 * detinv,
122
- -a2 * detinv, a0 * detinv
123
- ];
124
- }
125
- mat2.invert = invert;
126
- /**
127
- * Alias for {@link invert}
128
- */
129
- mat2.inv = invert;
130
- /**
131
- * Calculates the adjugate of a mat2
132
- */
133
- function adjoint(a) {
134
- // Caching this value is necessary if out == a
135
- const a0 = a[0];
136
- return [a[3], -a[1], -a[2], a0];
137
- }
138
- mat2.adjoint = adjoint;
139
- /**
140
- * Calculates the determinant of a mat2
141
- * @returns determinant of a
142
- *
143
- * @shorthands
144
- * - {@link det}
145
- */
146
- function determinant(a) {
147
- return a[0] * a[3] - a[2] * a[1];
148
- }
149
- mat2.determinant = determinant;
150
- /**
151
- * Alias for {@link determinant}
152
- * @category Shorthands
153
- */
154
- mat2.det = determinant;
155
- /**
156
- * Multiplies given mat2's
157
- *
158
- * @shorthands
159
- * - {@link mul}
160
- */
161
- function multiply(...ms) {
162
- if (ms.length === 0) {
163
- return mat2.identity;
164
- }
165
- else if (ms.length === 1) {
166
- return ms[0];
167
- }
168
- else if (ms.length > 2) {
169
- const [a, b, ...rest] = ms;
170
- return multiply(multiply(a, b), ...rest);
171
- }
172
- const [a0, a1, a2, a3] = ms[0];
173
- const [b0, b1, b2, b3] = ms[1];
174
- return [
175
- a0 * b0 + a2 * b1,
176
- a1 * b0 + a3 * b1,
177
- a0 * b2 + a2 * b3,
178
- a1 * b2 + a3 * b3,
179
- ];
180
- }
181
- mat2.multiply = multiply;
182
- /**
183
- * Alias for {@link multiply}
184
- * @category Shorthands
185
- */
186
- mat2.mul = multiply;
187
- /**
188
- * Rotates a mat2 by the given angle
189
- *
190
- * @param a the matrix to rotate
191
- * @param deg the angle to rotate the matrix by, in degrees
192
- */
193
- function rotate(a, deg) {
194
- const [a0, a1, a2, a3] = a;
195
- const s = Math.sin(deg * Common.DEG2RAD);
196
- const c = Math.cos(deg * Common.DEG2RAD);
197
- return [
198
- a0 * c + a2 * s,
199
- a1 * c + a3 * s,
200
- a0 * -s + a2 * c,
201
- a1 * -s + a3 * c,
202
- ];
203
- }
204
- mat2.rotate = rotate;
205
- /**
206
- * Scales the mat2 by the dimensions in the given vec2
207
- **/
208
- function scale(a, b) {
209
- const [a0, a1, a2, a3] = a;
210
- const [v0, v1] = typeof b === 'number' ? [b, b] : b;
211
- return [a0 * v0, a1 * v0, a2 * v1, a3 * v1];
212
- }
213
- mat2.scale = scale;
214
- /**
215
- * Apply skew to the mat2d by the given angles
216
- * https://developer.mozilla.org/en-US/docs/Web/CSS/transform-function/skew
217
- * @param m the matrix to skew
218
- * @param deg the angles to skew the matrix by, in degrees
219
- */
220
- function skew(m, deg) {
221
- return multiply(m, fromSkew(deg));
222
- }
223
- mat2.skew = skew;
224
- /**
225
- * Creates a matrix from a given angle.
226
- * @param deg The angle to rotate the matrix by, in degrees
227
- * @category Generators
228
- *
229
- * @shorthands
230
- * - {@link rotation}
231
- */
232
- function fromRotation(deg) {
233
- const s = Math.sin(deg * Common.DEG2RAD);
234
- const c = Math.cos(deg * Common.DEG2RAD);
235
- return [c, s, -s, c];
236
- }
237
- mat2.fromRotation = fromRotation;
238
- /**
239
- * Alias for {@link fromRotation}
240
- * @category Shorthands
241
- */
242
- mat2.rotation = fromRotation;
243
- /**
244
- * Creates a matrix from a vector scaling
245
- * @category Generators
246
- *
247
- * @shorthands
248
- * - {@link scaling}
249
- *
250
- */
251
- function fromScaling(v) {
252
- return [v[0], 0, 0, v[1]];
253
- }
254
- mat2.fromScaling = fromScaling;
255
- /**
256
- * Alias for {@link fromScaling}
257
- * @category Shorthands
258
- */
259
- mat2.scaling = fromScaling;
260
- /**
261
- * Creates a matrix from a vector skew
262
- * https://developer.mozilla.org/en-US/docs/Web/CSS/transform-function/skew
263
- * @category Generators
264
- *
265
- * @shorthands
266
- * - {@link skewing}
267
- */
268
- function fromSkew(deg) {
269
- const x = Math.tan(deg[0] * Common.DEG2RAD);
270
- const y = Math.tan(deg[1] * Common.DEG2RAD);
271
- // prettier-ignore
272
- return [
273
- 1, y,
274
- x, 1,
275
- ];
276
- }
277
- mat2.fromSkew = fromSkew;
278
- /**
279
- * Alias for {@link fromSkew}
280
- * @category Shorthands
281
- */
282
- mat2.skewing = fromSkew;
283
- /**
284
- * Creates a matrix from given rotation, and scaling. The order of the transformations is rotation, and scaling.
285
- * @param r Rotation angle in degrees
286
- * @param s Scaling vector
287
- * @returns The matrix that represents the transformation
288
- */
289
- function fromRotScale(r = null, s = null) {
290
- r ??= 0;
291
- s ??= vec2_1.vec2.one;
292
- const C = Math.cos(r * Common.DEG2RAD);
293
- const S = Math.sin(r * Common.DEG2RAD);
294
- return [s[0] * C, s[0] * S, s[1] * -S, s[1] * C];
295
- }
296
- mat2.fromRotScale = fromRotScale;
297
- /**
298
- * Alias for {@link fromRotScale}
299
- * @category Shorthands
300
- */
301
- mat2.rs = fromRotScale;
302
- /**
303
- * Returns Frobenius norm of a mat2
304
- */
305
- function frob(a) {
306
- return Math.hypot(a[0], a[1], a[2], a[3]);
307
- }
308
- mat2.frob = frob;
309
- /**
310
- * Adds given mat2's
311
- */
312
- function add(...ms) {
313
- if (ms.length === 0) {
314
- return mat2.zero;
315
- }
316
- else if (ms.length === 1) {
317
- return ms[0];
318
- }
319
- else if (ms.length > 2) {
320
- const [a, b, ...rest] = ms;
321
- return add(add(a, b), ...rest);
322
- }
323
- const [a, b] = ms;
324
- return [a[0] + b[0], a[1] + b[1], a[2] + b[2], a[3] + b[3]];
325
- }
326
- mat2.add = add;
327
- /**
328
- * Subtracts matrix b from matrix a
329
- *
330
- * @shorthands
331
- * - {@link sub}
332
- */
333
- function subtract(...ms) {
334
- if (ms.length === 0) {
335
- return mat2.zero;
336
- }
337
- else if (ms.length === 1) {
338
- const m = ms[0];
339
- return [-m[0], -m[1], -m[2], -m[3]];
340
- }
341
- else if (ms.length > 2) {
342
- const [a, b, ...rest] = ms;
343
- return subtract(subtract(a, b), ...rest);
344
- }
345
- const [a, b] = ms;
346
- return [a[0] - b[0], a[1] - b[1], a[2] - b[2], a[3] - b[3]];
347
- }
348
- mat2.subtract = subtract;
349
- /**
350
- * Alias for {@link subtract}
351
- * @category Shorthands
352
- */
353
- mat2.sub = subtract;
354
- /**
355
- * Subtracts b from a
356
- */
357
- function delta(a, b) {
358
- return [b[0] - a[0], b[1] - a[1], b[2] - a[2], b[3] - a[3]];
359
- }
360
- mat2.delta = delta;
361
- /**
362
- * Copies the values from a {@link mat2d}, omitting the translation components
363
- * @param m The matrix to copy from
364
- * @returns A newly created matrix
365
- * @category Generators
366
- */
367
- function fromMat2d(m) {
368
- return [m[0], m[1], m[2], m[3]];
369
- }
370
- mat2.fromMat2d = fromMat2d;
371
- /**
372
- * Multiplies each element of a mat2 by a scalar
373
- */
374
- function multiplyScalar(a, s) {
375
- // prettier-ignore
376
- return [
377
- a[0] * s, a[1] * s,
378
- a[2] * s, a[3] * s,
379
- ];
380
- }
381
- mat2.multiplyScalar = multiplyScalar;
382
- /**
383
- * Adds given mat2's after multiplying each element of the second operand by a scalar value.
384
- */
385
- function multiplyScalarAndAdd(a, b, scale) {
386
- return [
387
- a[0] + b[0] * scale,
388
- a[1] + b[1] * scale,
389
- a[2] + b[2] * scale,
390
- a[3] + b[3] * scale,
391
- ];
392
- }
393
- mat2.multiplyScalarAndAdd = multiplyScalarAndAdd;
394
- /**
395
- * Constrain each element to lie between min and max
396
- * @see https://thebookofshaders.com/glossary/?search=clamp
397
- */
398
- function clamp(a, min, max) {
399
- return [
400
- Math.max(min, Math.min(max, a[0])),
401
- Math.max(min, Math.min(max, a[1])),
402
- Math.max(min, Math.min(max, a[2])),
403
- Math.max(min, Math.min(max, a[3])),
404
- ];
405
- }
406
- mat2.clamp = clamp;
407
- /**
408
- * Clamps each element to [0, 1]
409
- */
410
- function clamp01(a) {
411
- return clamp(a, 0, 1);
412
- }
413
- mat2.clamp01 = clamp01;
414
- /**
415
- * Clamps each element to [-1, 1]
416
- */
417
- function clamp11(a) {
418
- return clamp(a, -1, 1);
419
- }
420
- mat2.clamp11 = clamp11;
421
- /**
422
- * Returns whether or not the matrices have exactly the same elements in the same position (when compared with `===`)
423
- *
424
- * @shorthands
425
- * - {@link eq}
426
- */
427
- function exactEquals(a, b) {
428
- return a[0] === b[0] && a[1] === b[1] && a[2] === b[2] && a[3] === b[3];
429
- }
430
- mat2.exactEquals = exactEquals;
431
- /**
432
- * Alias for {@link exactEquals}
433
- * @category Shorthands
434
- */
435
- mat2.eq = exactEquals;
436
- /**
437
- * Returns whether or not the matrices have approximately the same elements in the same position.
438
- *
439
- * @shorthands
440
- * - {@link approx}
441
- * - {@link equals}
442
- */
443
- function approxEquals(a, b) {
444
- const [a0, a1, a2, a3] = a;
445
- const [b0, b1, b2, b3] = b;
446
- return (Math.abs(a0 - b0) <=
447
- Common.EPSILON * Math.max(1, Math.abs(a0), Math.abs(b0)) &&
448
- Math.abs(a1 - b1) <=
449
- Common.EPSILON * Math.max(1, Math.abs(a1), Math.abs(b1)) &&
450
- Math.abs(a2 - b2) <=
451
- Common.EPSILON * Math.max(1, Math.abs(a2), Math.abs(b2)) &&
452
- Math.abs(a3 - b3) <=
453
- Common.EPSILON * Math.max(1, Math.abs(a3), Math.abs(b3)));
454
- }
455
- mat2.approxEquals = approxEquals;
456
- /**
457
- * Alias for {@link approxEquals}
458
- * @category Shorthands
459
- */
460
- mat2.approx = approxEquals;
461
- /**
462
- * Alias for {@link approxEquals}. This is provided for compatibility with gl-matrix.
463
- * @category Shorthands
464
- * @deprecated Use {@link approxEquals} instead
465
- */
466
- mat2.equals = approxEquals;
467
- /**
468
- * Returns a string representation of a mat2
469
- * @param m matrix to represent as a string
470
- * @param fractionDigits number of digits to appear after the decimal point
471
- */
472
- mat2.toString = Common.createMatToStringFunction(2, 2);
473
- })(mat2 || (exports.mat2 = mat2 = {}));
474
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mat2.js","sourceRoot":"","sources":["../../src/mat2.ts"],"names":[],"mappings":"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"}