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