linearly 0.36.0 → 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/esm/mat2.d.ts +1 -1
- package/lib/esm/mat2.d.ts.map +1 -1
- package/lib/esm/mat2.js +3 -2
- package/lib/esm/mat2d.d.ts.map +1 -1
- package/lib/esm/mat2d.js +4 -5
- package/lib/esm/mat3.d.ts.map +1 -1
- package/lib/esm/mat3.js +16 -15
- package/lib/esm/mat4.d.ts.map +1 -1
- package/lib/esm/mat4.js +18 -17
- package/lib/esm/quat.js +3 -3
- package/lib/esm/scalar.d.ts +6 -35
- package/lib/esm/scalar.d.ts.map +1 -1
- package/lib/esm/scalar.js +11 -53
- package/package.json +9 -4
- package/lib/cjs/common.d.ts +0 -16
- package/lib/cjs/common.d.ts.map +0 -1
- package/lib/cjs/common.js +0 -70
- package/lib/cjs/index.d.ts +0 -10
- package/lib/cjs/index.d.ts.map +0 -1
- package/lib/cjs/index.js +0 -22
- package/lib/cjs/mat2.d.ts +0 -272
- package/lib/cjs/mat2.d.ts.map +0 -1
- package/lib/cjs/mat2.js +0 -473
- package/lib/cjs/mat2d.d.ts +0 -329
- package/lib/cjs/mat2d.d.ts.map +0 -1
- package/lib/cjs/mat2d.js +0 -641
- package/lib/cjs/mat3.d.ts +0 -295
- package/lib/cjs/mat3.d.ts.map +0 -1
- package/lib/cjs/mat3.js +0 -670
- package/lib/cjs/mat4.d.ts +0 -532
- package/lib/cjs/mat4.d.ts.map +0 -1
- package/lib/cjs/mat4.js +0 -1576
- package/lib/cjs/quat.d.ts +0 -334
- package/lib/cjs/quat.d.ts.map +0 -1
- package/lib/cjs/quat.js +0 -802
- package/lib/cjs/scalar.d.ts +0 -501
- package/lib/cjs/scalar.d.ts.map +0 -1
- package/lib/cjs/scalar.js +0 -728
- package/lib/cjs/vec2.d.ts +0 -664
- package/lib/cjs/vec2.d.ts.map +0 -1
- package/lib/cjs/vec2.js +0 -1247
- package/lib/cjs/vec3.d.ts +0 -660
- package/lib/cjs/vec3.d.ts.map +0 -1
- package/lib/cjs/vec3.js +0 -1329
- package/lib/cjs/vec4.d.ts +0 -552
- package/lib/cjs/vec4.d.ts.map +0 -1
- package/lib/cjs/vec4.js +0 -1200
package/lib/cjs/mat2.js
DELETED
|
@@ -1,473 +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
|
-
return [-ms[0], -ms[1], -ms[2], -ms[3]];
|
|
339
|
-
}
|
|
340
|
-
else if (ms.length > 2) {
|
|
341
|
-
const [a, b, ...rest] = ms;
|
|
342
|
-
return subtract(subtract(a, b), ...rest);
|
|
343
|
-
}
|
|
344
|
-
const [a, b] = ms;
|
|
345
|
-
return [a[0] - b[0], a[1] - b[1], a[2] - b[2], a[3] - b[3]];
|
|
346
|
-
}
|
|
347
|
-
mat2.subtract = subtract;
|
|
348
|
-
/**
|
|
349
|
-
* Alias for {@link subtract}
|
|
350
|
-
* @category Shorthands
|
|
351
|
-
*/
|
|
352
|
-
mat2.sub = subtract;
|
|
353
|
-
/**
|
|
354
|
-
* Subtracts b from a
|
|
355
|
-
*/
|
|
356
|
-
function delta(a, b) {
|
|
357
|
-
return [b[0] - a[0], b[1] - a[1], b[2] - a[2], b[3] - a[3]];
|
|
358
|
-
}
|
|
359
|
-
mat2.delta = delta;
|
|
360
|
-
/**
|
|
361
|
-
* Copies the values from a {@link mat2d}, omitting the translation components
|
|
362
|
-
* @param m The matrix to copy from
|
|
363
|
-
* @returns A newly created matrix
|
|
364
|
-
* @category Generators
|
|
365
|
-
*/
|
|
366
|
-
function fromMat2d(m) {
|
|
367
|
-
return [m[0], m[1], m[2], m[3]];
|
|
368
|
-
}
|
|
369
|
-
mat2.fromMat2d = fromMat2d;
|
|
370
|
-
/**
|
|
371
|
-
* Multiplies each element of a mat2 by a scalar
|
|
372
|
-
*/
|
|
373
|
-
function multiplyScalar(a, s) {
|
|
374
|
-
// prettier-ignore
|
|
375
|
-
return [
|
|
376
|
-
a[0] * s, a[1] * s,
|
|
377
|
-
a[2] * s, a[3] * s,
|
|
378
|
-
];
|
|
379
|
-
}
|
|
380
|
-
mat2.multiplyScalar = multiplyScalar;
|
|
381
|
-
/**
|
|
382
|
-
* Adds given mat2's after multiplying each element of the second operand by a scalar value.
|
|
383
|
-
*/
|
|
384
|
-
function multiplyScalarAndAdd(a, b, scale) {
|
|
385
|
-
return [
|
|
386
|
-
a[0] + b[0] * scale,
|
|
387
|
-
a[1] + b[1] * scale,
|
|
388
|
-
a[2] + b[2] * scale,
|
|
389
|
-
a[3] + b[3] * scale,
|
|
390
|
-
];
|
|
391
|
-
}
|
|
392
|
-
mat2.multiplyScalarAndAdd = multiplyScalarAndAdd;
|
|
393
|
-
/**
|
|
394
|
-
* Constrain each element to lie between min and max
|
|
395
|
-
* @see https://thebookofshaders.com/glossary/?search=clamp
|
|
396
|
-
*/
|
|
397
|
-
function clamp(a, min, max) {
|
|
398
|
-
return [
|
|
399
|
-
Math.max(min, Math.min(max, a[0])),
|
|
400
|
-
Math.max(min, Math.min(max, a[1])),
|
|
401
|
-
Math.max(min, Math.min(max, a[2])),
|
|
402
|
-
Math.max(min, Math.min(max, a[3])),
|
|
403
|
-
];
|
|
404
|
-
}
|
|
405
|
-
mat2.clamp = clamp;
|
|
406
|
-
/**
|
|
407
|
-
* Clamps each element to [0, 1]
|
|
408
|
-
*/
|
|
409
|
-
function clamp01(a) {
|
|
410
|
-
return clamp(a, 0, 1);
|
|
411
|
-
}
|
|
412
|
-
mat2.clamp01 = clamp01;
|
|
413
|
-
/**
|
|
414
|
-
* Clamps each element to [-1, 1]
|
|
415
|
-
*/
|
|
416
|
-
function clamp11(a) {
|
|
417
|
-
return clamp(a, -1, 1);
|
|
418
|
-
}
|
|
419
|
-
mat2.clamp11 = clamp11;
|
|
420
|
-
/**
|
|
421
|
-
* Returns whether or not the matrices have exactly the same elements in the same position (when compared with `===`)
|
|
422
|
-
*
|
|
423
|
-
* @shorthands
|
|
424
|
-
* - {@link eq}
|
|
425
|
-
*/
|
|
426
|
-
function exactEquals(a, b) {
|
|
427
|
-
return a[0] === b[0] && a[1] === b[1] && a[2] === b[2] && a[3] === b[3];
|
|
428
|
-
}
|
|
429
|
-
mat2.exactEquals = exactEquals;
|
|
430
|
-
/**
|
|
431
|
-
* Alias for {@link exactEquals}
|
|
432
|
-
* @category Shorthands
|
|
433
|
-
*/
|
|
434
|
-
mat2.eq = exactEquals;
|
|
435
|
-
/**
|
|
436
|
-
* Returns whether or not the matrices have approximately the same elements in the same position.
|
|
437
|
-
*
|
|
438
|
-
* @shorthands
|
|
439
|
-
* - {@link approx}
|
|
440
|
-
* - {@link equals}
|
|
441
|
-
*/
|
|
442
|
-
function approxEquals(a, b) {
|
|
443
|
-
const [a0, a1, a2, a3] = a;
|
|
444
|
-
const [b0, b1, b2, b3] = b;
|
|
445
|
-
return (Math.abs(a0 - b0) <=
|
|
446
|
-
Common.EPSILON * Math.max(1, Math.abs(a0), Math.abs(b0)) &&
|
|
447
|
-
Math.abs(a1 - b1) <=
|
|
448
|
-
Common.EPSILON * Math.max(1, Math.abs(a1), Math.abs(b1)) &&
|
|
449
|
-
Math.abs(a2 - b2) <=
|
|
450
|
-
Common.EPSILON * Math.max(1, Math.abs(a2), Math.abs(b2)) &&
|
|
451
|
-
Math.abs(a3 - b3) <=
|
|
452
|
-
Common.EPSILON * Math.max(1, Math.abs(a3), Math.abs(b3)));
|
|
453
|
-
}
|
|
454
|
-
mat2.approxEquals = approxEquals;
|
|
455
|
-
/**
|
|
456
|
-
* Alias for {@link approxEquals}
|
|
457
|
-
* @category Shorthands
|
|
458
|
-
*/
|
|
459
|
-
mat2.approx = approxEquals;
|
|
460
|
-
/**
|
|
461
|
-
* Alias for {@link approxEquals}. This is provided for compatibility with gl-matrix.
|
|
462
|
-
* @category Shorthands
|
|
463
|
-
* @deprecated Use {@link approxEquals} instead
|
|
464
|
-
*/
|
|
465
|
-
mat2.equals = approxEquals;
|
|
466
|
-
/**
|
|
467
|
-
* Returns a string representation of a mat2
|
|
468
|
-
* @param m matrix to represent as a string
|
|
469
|
-
* @param fractionDigits number of digits to appear after the decimal point
|
|
470
|
-
*/
|
|
471
|
-
mat2.toString = Common.createMatToStringFunction(2, 2);
|
|
472
|
-
})(mat2 || (exports.mat2 = mat2 = {}));
|
|
473
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mat2.js","sourceRoot":"","sources":["../../src/mat2.ts"],"names":[],"mappings":"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"}
|