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.
Files changed (47) hide show
  1. package/lib/esm/mat2.d.ts +1 -1
  2. package/lib/esm/mat2.d.ts.map +1 -1
  3. package/lib/esm/mat2.js +3 -2
  4. package/lib/esm/mat2d.d.ts.map +1 -1
  5. package/lib/esm/mat2d.js +4 -5
  6. package/lib/esm/mat3.d.ts.map +1 -1
  7. package/lib/esm/mat3.js +16 -15
  8. package/lib/esm/mat4.d.ts.map +1 -1
  9. package/lib/esm/mat4.js +18 -17
  10. package/lib/esm/quat.js +3 -3
  11. package/lib/esm/scalar.d.ts +6 -35
  12. package/lib/esm/scalar.d.ts.map +1 -1
  13. package/lib/esm/scalar.js +11 -53
  14. package/package.json +9 -4
  15. package/lib/cjs/common.d.ts +0 -16
  16. package/lib/cjs/common.d.ts.map +0 -1
  17. package/lib/cjs/common.js +0 -70
  18. package/lib/cjs/index.d.ts +0 -10
  19. package/lib/cjs/index.d.ts.map +0 -1
  20. package/lib/cjs/index.js +0 -22
  21. package/lib/cjs/mat2.d.ts +0 -272
  22. package/lib/cjs/mat2.d.ts.map +0 -1
  23. package/lib/cjs/mat2.js +0 -473
  24. package/lib/cjs/mat2d.d.ts +0 -329
  25. package/lib/cjs/mat2d.d.ts.map +0 -1
  26. package/lib/cjs/mat2d.js +0 -641
  27. package/lib/cjs/mat3.d.ts +0 -295
  28. package/lib/cjs/mat3.d.ts.map +0 -1
  29. package/lib/cjs/mat3.js +0 -670
  30. package/lib/cjs/mat4.d.ts +0 -532
  31. package/lib/cjs/mat4.d.ts.map +0 -1
  32. package/lib/cjs/mat4.js +0 -1576
  33. package/lib/cjs/quat.d.ts +0 -334
  34. package/lib/cjs/quat.d.ts.map +0 -1
  35. package/lib/cjs/quat.js +0 -802
  36. package/lib/cjs/scalar.d.ts +0 -501
  37. package/lib/cjs/scalar.d.ts.map +0 -1
  38. package/lib/cjs/scalar.js +0 -728
  39. package/lib/cjs/vec2.d.ts +0 -664
  40. package/lib/cjs/vec2.d.ts.map +0 -1
  41. package/lib/cjs/vec2.js +0 -1247
  42. package/lib/cjs/vec3.d.ts +0 -660
  43. package/lib/cjs/vec3.d.ts.map +0 -1
  44. package/lib/cjs/vec3.js +0 -1329
  45. package/lib/cjs/vec4.d.ts +0 -552
  46. package/lib/cjs/vec4.d.ts.map +0 -1
  47. package/lib/cjs/vec4.js +0 -1200
package/lib/cjs/quat.js DELETED
@@ -1,802 +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.quat = void 0;
37
- const Common = __importStar(require("./common"));
38
- const mat4_1 = require("./mat4");
39
- const vec3_1 = require("./vec3");
40
- const vec4_1 = require("./vec4");
41
- /**
42
- * Functions for {@link quat}, a format for representing rotation in 3D space.
43
- * @category Modules
44
- */
45
- var quat;
46
- (function (quat) {
47
- /**
48
- * Creates a new quaternion from given elements
49
- * @category Generators
50
- */
51
- function of(x, y, z, w) {
52
- return [x, y, z, w];
53
- }
54
- quat.of = of;
55
- /**
56
- * Creates a mutable clone of given quat
57
- * @category Generators
58
- */
59
- function clone(a) {
60
- return [...a];
61
- }
62
- quat.clone = clone;
63
- /**
64
- * Constrain each component to lie between min and max
65
- * @see https://thebookofshaders.com/glossary/?search=clamp
66
- */
67
- function clamp(q, min, max) {
68
- return [
69
- Math.max(min, Math.min(max, q[0])),
70
- Math.max(min, Math.min(max, q[1])),
71
- Math.max(min, Math.min(max, q[2])),
72
- Math.max(min, Math.min(max, q[3])),
73
- ];
74
- }
75
- quat.clamp = clamp;
76
- /**
77
- * Clamps each component to [0, 1]
78
- */
79
- function clamp01(q) {
80
- return clamp(q, 0, 1);
81
- }
82
- quat.clamp01 = clamp01;
83
- /**
84
- * Clamps each component to [-1, 1]
85
- */
86
- function clamp11(q) {
87
- return clamp(q, -1, 1);
88
- }
89
- quat.clamp11 = clamp11;
90
- /**
91
- * The identity quaternion.
92
- * @category Constants
93
- *
94
- * @shorthands
95
- * - {@link id}
96
- * - {@link ident}
97
- */
98
- quat.identity = Object.freeze([0, 0, 0, 1]);
99
- /**
100
- * Alias for {@link identity}
101
- * @category Shorthands
102
- */
103
- quat.I = quat.identity;
104
- /**
105
- * Alias for {@link identity}
106
- * @category Shorthands
107
- */
108
- quat.id = quat.identity;
109
- /**
110
- * Alias for {@link identity}
111
- * @category Shorthands
112
- */
113
- quat.ident = quat.identity;
114
- /**
115
- * The zero quaternion.
116
- * @category Constants
117
- */
118
- quat.zero = Object.freeze([0, 0, 0, 0]);
119
- /**
120
- * Sets a quat from the given angle and rotation axis,
121
- * then returns it.
122
- * @category Generators
123
- * @param axis the axis around which to rotate
124
- * @param deg the angle in degrees
125
- **/
126
- function fromAxisAngle(axis, deg) {
127
- const rad = deg * Common.DEG2RAD * 0.5;
128
- const s = Math.sin(rad);
129
- return [
130
- s * axis[0], //
131
- s * axis[1],
132
- s * axis[2],
133
- Math.cos(rad),
134
- ];
135
- }
136
- quat.fromAxisAngle = fromAxisAngle;
137
- /**
138
- * Gets the rotation axis and angle for a given
139
- * quaternion. If a quaternion is created with
140
- * fromAxisAngle, this method will return the same
141
- * values as provided in the original parameter list
142
- * OR functionally equivalent values.
143
- * Example: The quaternion formed by axis [0, 0, 1] and
144
- * angle -90 is the same as the quaternion formed by
145
- * [0, 0, 1] and 270. This method favors the latter.
146
- *
147
- * @param q Quaternion to be decomposed
148
- */
149
- function axisAngle(q) {
150
- const rad = Math.acos(q[3]) * 2;
151
- const s = Math.sin(rad / 2);
152
- let axis;
153
- if (s > Common.EPSILON) {
154
- axis = [q[0] / s, q[1] / s, q[2] / s];
155
- }
156
- else {
157
- // If s is zero, return any axis (no rotation - axis does not matter)
158
- axis = [1, 0, 0];
159
- }
160
- return { axis, deg: rad * Common.RAD2DEG };
161
- }
162
- quat.axisAngle = axisAngle;
163
- /**
164
- * Gets the angular distance between two unit quaternions
165
- *
166
- * @param a Origin unit quaternion
167
- * @param b Destination unit quaternion
168
- * @return Angle, in degrees, between the two quaternions
169
- */
170
- function angle(a, b) {
171
- const dotproduct = quat.dot(a, b);
172
- return Math.acos(2 * dotproduct * dotproduct - 1);
173
- }
174
- quat.angle = angle;
175
- /**
176
- * Multiplies given quat's
177
- *
178
- * @param a the first operand
179
- * @param b the second operand
180
- *
181
- * @shorthands
182
- * - {@link mul}
183
- */
184
- function multiply(...qs) {
185
- if (qs.length === 0) {
186
- return quat.identity;
187
- }
188
- else if (qs.length === 1) {
189
- return qs[0];
190
- }
191
- else if (qs.length > 2) {
192
- const [a, b, ...rest] = qs;
193
- return multiply(multiply(a, b), ...rest);
194
- }
195
- const [ax, ay, az, aw] = qs[0];
196
- const [bx, by, bz, bw] = qs[1];
197
- return [
198
- ax * bw + aw * bx + ay * bz - az * by,
199
- ay * bw + aw * by + az * bx - ax * bz,
200
- az * bw + aw * bz + ax * by - ay * bx,
201
- aw * bw - ax * bx - ay * by - az * bz,
202
- ];
203
- }
204
- quat.multiply = multiply;
205
- /**
206
- * Alias for {@link multiply}
207
- * @category Shorthands
208
- */
209
- quat.mul = multiply;
210
- /**
211
- * Rotates a quaternion by the given angle about the X axis
212
- *
213
- * @param a quat to rotate
214
- * @param deg angle to rotate, in degrees
215
- */
216
- function rotateX(a, deg) {
217
- deg *= 0.5;
218
- const ax = a[0], ay = a[1], az = a[2], aw = a[3];
219
- const bx = Math.sin(deg * Common.DEG2RAD), bw = Math.cos(deg * Common.DEG2RAD);
220
- return [
221
- ax * bw + aw * bx,
222
- ay * bw + az * bx,
223
- az * bw - ay * bx,
224
- aw * bw - ax * bx,
225
- ];
226
- }
227
- quat.rotateX = rotateX;
228
- /**
229
- * Rotates a quaternion by the given angle about the Y axis
230
- *
231
- * @param a quat to rotate
232
- * @param deg angle to rotate, in degrees
233
- */
234
- function rotateY(a, deg) {
235
- const rad = deg * Common.DEG2RAD * 0.5;
236
- const ax = a[0], ay = a[1], az = a[2], aw = a[3];
237
- const by = Math.sin(rad), bw = Math.cos(rad);
238
- return [
239
- ax * bw - az * by,
240
- ay * bw + aw * by,
241
- az * bw + ax * by,
242
- aw * bw - ay * by,
243
- ];
244
- }
245
- quat.rotateY = rotateY;
246
- /**
247
- * Rotates a quaternion by the given angle about the Z axis
248
- *
249
- * @param a quat to rotate
250
- * @param deg angle (in degrees) to rotate
251
- */
252
- function rotateZ(a, deg) {
253
- const rad = deg * Common.DEG2RAD * 0.5;
254
- const ax = a[0];
255
- const ay = a[1];
256
- const az = a[2];
257
- const aw = a[3];
258
- const bz = Math.sin(rad);
259
- const bw = Math.cos(rad);
260
- return [
261
- ax * bw + ay * bz,
262
- ay * bw - ax * bz,
263
- az * bw + aw * bz,
264
- aw * bw - az * bz,
265
- ];
266
- }
267
- quat.rotateZ = rotateZ;
268
- /**
269
- * Calculates the W component of a quat from the X, Y, and Z components.
270
- * Assumes that quaternion is 1 unit in length.
271
- * Any existing W component will be ignored.
272
- */
273
- function calculateW(q) {
274
- const [x, y, z] = q;
275
- return [x, y, z, Math.sqrt(Math.abs(1 - x * x - y * y - z * z))];
276
- }
277
- quat.calculateW = calculateW;
278
- /**
279
- * Calculate the exponential of a unit quaternion.
280
- */
281
- function exp(q) {
282
- const [x, y, z, w] = q;
283
- const r = Math.hypot(x, y, z);
284
- const et = Math.exp(w);
285
- const s = r > 0 ? (et * Math.sin(r)) / r : 0;
286
- return [x * s, y * s, z * s, et * Math.cos(r)];
287
- }
288
- quat.exp = exp;
289
- /**
290
- * Calculate the natural logarithm of a unit quaternion.
291
- */
292
- function ln(a) {
293
- const [x, y, z, w] = a;
294
- const r = Math.hypot(x, y, z);
295
- const t = r > 0 ? Math.atan2(r, w) / r : 0;
296
- return [x * t, y * t, z * t, 0.5 * Math.log(x * x + y * y + z * z + w * w)];
297
- }
298
- quat.ln = ln;
299
- /**
300
- * Calculate the scalar power of a unit quaternion.
301
- */
302
- function pow(a, b) {
303
- return exp(quat.scale(ln(a), b));
304
- }
305
- quat.pow = pow;
306
- /**
307
- * Performs a spherical linear interpolation between two quat
308
- *
309
- * @param a the first operand
310
- * @param b the second operand
311
- * @param t interpolation amount, in the range [0-1], between the two inputs
312
- */
313
- function slerp(a, b, t) {
314
- // benchmarks:
315
- // http://jsperf.com/quaternion-slerp-implementations
316
- const [ax, ay, az, aw] = a;
317
- let [bx, by, bz, bw] = b;
318
- let omega, cosom, sinom, scale0, scale1;
319
- // calc cosine
320
- cosom = ax * bx + ay * by + az * bz + aw * bw;
321
- // adjust signs (if necessary)
322
- if (cosom < 0) {
323
- cosom *= -1;
324
- bx *= -1;
325
- by *= -1;
326
- bz *= -1;
327
- bw *= -1;
328
- }
329
- // calculate coefficients
330
- if (1 - cosom > Common.EPSILON) {
331
- // standard case (slerp)
332
- omega = Math.acos(cosom);
333
- sinom = Math.sin(omega);
334
- scale0 = Math.sin((1 - t) * omega) / sinom;
335
- scale1 = Math.sin(t * omega) / sinom;
336
- }
337
- else {
338
- // "from" and "to" quaternions are very close
339
- // ... so we can do a linear interpolation
340
- scale0 = 1 - t;
341
- scale1 = t;
342
- }
343
- // calculate final values
344
- return [
345
- scale0 * ax + scale1 * bx,
346
- scale0 * ay + scale1 * by,
347
- scale0 * az + scale1 * bz,
348
- scale0 * aw + scale1 * bw,
349
- ];
350
- }
351
- quat.slerp = slerp;
352
- /**
353
- * Calculates the inverse of a quat
354
- */
355
- function invert(q) {
356
- const [q0, q1, q2, q3] = q;
357
- const dot = q0 * q0 + q1 * q1 + q2 * q2 + q3 * q3;
358
- const invDot = dot ? 1 / dot : 0;
359
- // TODO: Would be faster to return [0,0,0,0] immediately if dot == 0
360
- return [-q0 * invDot, -q1 * invDot, -q2 * invDot, q3 * invDot];
361
- }
362
- quat.invert = invert;
363
- /**
364
- * Calculates the conjugate of a quat
365
- * If the quaternion is normalized, this function is faster than quat.inverse and produces the same result.
366
- */
367
- function conjugate(a) {
368
- return [-a[0], -a[1], -a[2], a[3]];
369
- }
370
- quat.conjugate = conjugate;
371
- /**
372
- * Creates a quaternion from the given 3x3 rotation matrix.
373
- *
374
- * NOTE: The resultant quaternion is not normalized, so you should be sure
375
- * to renormalize the quaternion yourself where necessary.
376
- * @category Generators
377
- */
378
- function fromMat3(m) {
379
- // Algorithm in Ken Shoemake's article in 1987 SIGGRAPH course notes
380
- // article "Quaternion Calculus and Fast Animation".
381
- const fTrace = m[0] + m[4] + m[8];
382
- let fRoot;
383
- const out = [0, 0, 0, 0];
384
- if (fTrace > 0) {
385
- // |w| > 1/2, may as well choose w > 1/2
386
- fRoot = Math.sqrt(fTrace + 1); // 2w
387
- out[3] = 0.5 * fRoot;
388
- fRoot = 0.5 / fRoot; // 1/(4w)
389
- out[0] = (m[5] - m[7]) * fRoot;
390
- out[1] = (m[6] - m[2]) * fRoot;
391
- out[2] = (m[1] - m[3]) * fRoot;
392
- }
393
- else {
394
- // |w| <= 1/2
395
- let i = 0;
396
- if (m[4] > m[0])
397
- i = 1;
398
- if (m[8] > m[i * 3 + i])
399
- i = 2;
400
- const j = (i + 1) % 3;
401
- const k = (i + 2) % 3;
402
- fRoot = Math.sqrt(m[i * 3 + i] - m[j * 3 + j] - m[k * 3 + k] + 1);
403
- out[i] = 0.5 * fRoot;
404
- fRoot = 0.5 / fRoot;
405
- out[3] = (m[j * 3 + k] - m[k * 3 + j]) * fRoot;
406
- out[j] = (m[j * 3 + i] + m[i * 3 + j]) * fRoot;
407
- out[k] = (m[k * 3 + i] + m[i * 3 + k]) * fRoot;
408
- }
409
- return out;
410
- }
411
- quat.fromMat3 = fromMat3;
412
- /**
413
- * Creates a quaternion from the given 4x4 affine matrix. The translation portion of the matrix is ignored. Same as mat4. Alias for {@link mat4.getRotation}.
414
- */
415
- quat.fromMat4 = mat4_1.mat4.getRotation;
416
- /**
417
- * Creates a quaternion from a normalized direction vector and an up vector.
418
- * Equivalent to GLM's `glm::quatLookAt`.
419
- *
420
- * @param direction Normalized direction vector (forward)
421
- * @param up Up vector, default is vec3.unitY
422
- * @category Generators
423
- */
424
- function lookAt(direction, up = vec3_1.vec3.unitY) {
425
- const right = vec3_1.vec3.normalize(vec3_1.vec3.cross(up, direction));
426
- const correctedUp = vec3_1.vec3.cross(direction, right);
427
- const m = [
428
- right[0],
429
- correctedUp[0],
430
- direction[0],
431
- right[1],
432
- correctedUp[1],
433
- direction[1],
434
- right[2],
435
- correctedUp[2],
436
- direction[2],
437
- ];
438
- return quat.normalize(fromMat3(m));
439
- }
440
- quat.lookAt = lookAt;
441
- /**
442
- * Creates a quaternion from the given euler angle x, y, z using the provided intrinsic order for the conversion.
443
- *
444
- * @param deg Angles to rotate around X, Y, Z axes in degree.
445
- * @param order Intrinsic order for conversion, default is zyx.
446
- * @category Generators
447
- */
448
- function fromEuler(deg, order = Common.DEFAULT_ANGLE_ORDER) {
449
- const [xDeg, yDeg, zDeg] = deg;
450
- const halfToRad = Common.DEG2RAD * 0.5;
451
- const xRad = xDeg * halfToRad;
452
- const yRad = yDeg * halfToRad;
453
- const zRad = zDeg * halfToRad;
454
- const sx = Math.sin(xRad);
455
- const cx = Math.cos(xRad);
456
- const sy = Math.sin(yRad);
457
- const cy = Math.cos(yRad);
458
- const sz = Math.sin(zRad);
459
- const cz = Math.cos(zRad);
460
- switch (order) {
461
- case 'xyz':
462
- return [
463
- sx * cy * cz + cx * sy * sz,
464
- cx * sy * cz - sx * cy * sz,
465
- cx * cy * sz + sx * sy * cz,
466
- cx * cy * cz - sx * sy * sz,
467
- ];
468
- case 'xzy':
469
- return [
470
- sx * cy * cz - cx * sy * sz,
471
- cx * sy * cz - sx * cy * sz,
472
- cx * cy * sz + sx * sy * cz,
473
- cx * cy * cz + sx * sy * sz,
474
- ];
475
- case 'yxz':
476
- return [
477
- sx * cy * cz + cx * sy * sz,
478
- cx * sy * cz - sx * cy * sz,
479
- cx * cy * sz - sx * sy * cz,
480
- cx * cy * cz + sx * sy * sz,
481
- ];
482
- case 'yzx':
483
- return [
484
- sx * cy * cz + cx * sy * sz,
485
- cx * sy * cz + sx * cy * sz,
486
- cx * cy * sz - sx * sy * cz,
487
- cx * cy * cz - sx * sy * sz,
488
- ];
489
- case 'zxy':
490
- return [
491
- sx * cy * cz - cx * sy * sz,
492
- cx * sy * cz + sx * cy * sz,
493
- cx * cy * sz + sx * sy * cz,
494
- cx * cy * cz - sx * sy * sz,
495
- ];
496
- case 'zyx':
497
- return [
498
- sx * cy * cz - cx * sy * sz,
499
- cx * sy * cz + sx * cy * sz,
500
- cx * cy * sz - sx * sy * cz,
501
- cx * cy * cz + sx * sy * sz,
502
- ];
503
- }
504
- }
505
- quat.fromEuler = fromEuler;
506
- /**
507
- * Extracts Euler angles from a quaternion. This is the inverse of {@link fromEuler}.
508
- * Equivalent to GLM's `glm::eulerAngles`.
509
- *
510
- * @param q The quaternion to extract Euler angles from
511
- * @param order Intrinsic order for conversion, default is zyx
512
- * @returns Euler angles in degrees as vec3 [x, y, z]
513
- */
514
- function toEuler(q, order = Common.DEFAULT_ANGLE_ORDER) {
515
- const [x, y, z, w] = q;
516
- const x2 = x * x;
517
- const y2 = y * y;
518
- const z2 = z * z;
519
- const w2 = w * w;
520
- // Rotation matrix elements from quaternion
521
- const m00 = w2 + x2 - y2 - z2;
522
- const m01 = 2 * (x * y - w * z);
523
- const m02 = 2 * (x * z + w * y);
524
- const m10 = 2 * (x * y + w * z);
525
- const m11 = w2 - x2 + y2 - z2;
526
- const m12 = 2 * (y * z - w * x);
527
- const m20 = 2 * (x * z - w * y);
528
- const m21 = 2 * (y * z + w * x);
529
- const m22 = w2 - x2 - y2 + z2;
530
- const GIMBAL = 0.9999999;
531
- let ex, ey, ez;
532
- switch (order) {
533
- case 'zyx': {
534
- const sinP = -m20;
535
- if (Math.abs(sinP) >= GIMBAL) {
536
- ex = 0;
537
- ey = Math.sign(sinP) * (Math.PI / 2);
538
- ez = Math.atan2(-m01, m11);
539
- }
540
- else {
541
- ex = Math.atan2(m21, m22);
542
- ey = Math.asin(sinP);
543
- ez = Math.atan2(m10, m00);
544
- }
545
- break;
546
- }
547
- case 'xyz': {
548
- const sinP = m02;
549
- if (Math.abs(sinP) >= GIMBAL) {
550
- ex = Math.atan2(m21, m11);
551
- ey = Math.sign(sinP) * (Math.PI / 2);
552
- ez = 0;
553
- }
554
- else {
555
- ex = Math.atan2(-m12, m22);
556
- ey = Math.asin(sinP);
557
- ez = Math.atan2(-m01, m00);
558
- }
559
- break;
560
- }
561
- case 'yxz': {
562
- const sinP = -m12;
563
- if (Math.abs(sinP) >= GIMBAL) {
564
- ex = Math.sign(sinP) * (Math.PI / 2);
565
- ey = Math.atan2(-m20, m00);
566
- ez = 0;
567
- }
568
- else {
569
- ex = Math.asin(sinP);
570
- ey = Math.atan2(m02, m22);
571
- ez = Math.atan2(m10, m11);
572
- }
573
- break;
574
- }
575
- case 'yzx': {
576
- const sinP = m10;
577
- if (Math.abs(sinP) >= GIMBAL) {
578
- ex = 0;
579
- ey = Math.atan2(m02, m22);
580
- ez = Math.sign(sinP) * (Math.PI / 2);
581
- }
582
- else {
583
- ex = Math.atan2(-m12, m11);
584
- ey = Math.atan2(-m20, m00);
585
- ez = Math.asin(sinP);
586
- }
587
- break;
588
- }
589
- case 'zxy': {
590
- const sinP = m21;
591
- if (Math.abs(sinP) >= GIMBAL) {
592
- ex = Math.sign(sinP) * (Math.PI / 2);
593
- ey = 0;
594
- ez = Math.atan2(m10, m00);
595
- }
596
- else {
597
- ex = Math.asin(sinP);
598
- ey = Math.atan2(-m20, m22);
599
- ez = Math.atan2(-m01, m11);
600
- }
601
- break;
602
- }
603
- case 'xzy': {
604
- const sinP = -m01;
605
- if (Math.abs(sinP) >= GIMBAL) {
606
- ex = Math.atan2(-m12, m22);
607
- ey = 0;
608
- ez = Math.sign(sinP) * (Math.PI / 2);
609
- }
610
- else {
611
- ex = Math.atan2(m21, m11);
612
- ey = Math.atan2(m02, m00);
613
- ez = Math.asin(sinP);
614
- }
615
- break;
616
- }
617
- }
618
- return [
619
- ex * Common.RAD2DEG,
620
- ey * Common.RAD2DEG,
621
- ez * Common.RAD2DEG,
622
- ];
623
- }
624
- quat.toEuler = toEuler;
625
- /**
626
- * Performs a normalized linear interpolation (nlerp) between two quaternions.
627
- * Faster than {@link slerp} and sufficient for small rotation differences.
628
- *
629
- * @param a the first operand
630
- * @param b the second operand
631
- * @param t interpolation amount, in the range [0-1], between the two inputs
632
- */
633
- function lerp(a, b, t) {
634
- let [bx, by, bz, bw] = b;
635
- if (quat.dot(a, b) < 0) {
636
- bx = -bx;
637
- by = -by;
638
- bz = -bz;
639
- bw = -bw;
640
- }
641
- return quat.normalize([
642
- a[0] + (bx - a[0]) * t,
643
- a[1] + (by - a[1]) * t,
644
- a[2] + (bz - a[2]) * t,
645
- a[3] + (bw - a[3]) * t,
646
- ]);
647
- }
648
- quat.lerp = lerp;
649
- /**
650
- * Adds given quat's
651
- */
652
- quat.add = vec4_1.vec4.add;
653
- /**
654
- * Scales a quat by a scalar number
655
- */
656
- quat.scale = vec4_1.vec4.scale;
657
- /**
658
- * Calculates the dot product of two quat's
659
- */
660
- quat.dot = vec4_1.vec4.dot;
661
- /**
662
- * Calculates the length of a quat
663
- *
664
- * @param a vector to calculate length of
665
- * @returns length of a
666
- *
667
- * @shorthands
668
- * - {@link len}
669
- */
670
- quat.length = vec4_1.vec4.length;
671
- /**
672
- * Alias for {@link length}
673
- * @category Shorthands
674
- */
675
- quat.len = quat.length;
676
- /**
677
- * Calculates the squared length of a quat
678
- *
679
- * @param a vector to calculate squared length of
680
- * @returns squared length of a
681
- *
682
- * @shorthands
683
- * - {@link sqrLen}
684
- */
685
- quat.squaredLength = vec4_1.vec4.squaredLength;
686
- /**
687
- * Alias for {@link squaredLength}
688
- * @category Shorthands
689
- */
690
- quat.sqrLen = quat.squaredLength;
691
- /**
692
- * Normalize a quat
693
- *
694
- * @param a quaternion to normalize
695
- */
696
- quat.normalize = vec4_1.vec4.normalize;
697
- /**
698
- * Returns whether or not the quaternions have exactly the same elements in the same position (when compared with `===`)
699
- *
700
- * @shorthands
701
- * - {@link eq}
702
- */
703
- quat.exactEquals = vec4_1.vec4.exactEquals;
704
- /**
705
- * Alias for {@link exactEquals}
706
- * @category Shorthands
707
- */
708
- quat.eq = quat.exactEquals;
709
- /**
710
- * Returns whether or not the quaternions point approximately to the same direction. Both quaternions are assumed to be unit length.
711
- *
712
- * @shorthands
713
- * - {@link approx}
714
- * - {@link equals}
715
- */
716
- function approxEquals(a, b) {
717
- return Math.abs(vec4_1.vec4.dot(a, b)) >= 1 - Common.EPSILON;
718
- }
719
- quat.approxEquals = approxEquals;
720
- /**
721
- * Alias for {@link approxEquals}
722
- * @category Shorthands
723
- */
724
- quat.approx = approxEquals;
725
- /**
726
- * Alias for {@link approxEquals}. This is provided for compatibility with gl-matrix.
727
- * @category Shorthands
728
- * @deprecated Use {@link approxEquals} instead
729
- */
730
- quat.equals = approxEquals;
731
- /**
732
- * Sets a quaternion to represent the shortest rotation from one
733
- * vector to another.
734
- *
735
- * Both vectors are assumed to be unit length.
736
- *
737
- * @param a the initial vector
738
- * @param b the destination vector
739
- * @category Generators
740
- */
741
- quat.rotationTo = (function () {
742
- return (a, b) => {
743
- const dot = vec3_1.vec3.dot(a, b);
744
- if (dot > 1 - Common.EPSILON) {
745
- return [...quat.identity];
746
- }
747
- else if (dot < -1 + Common.EPSILON) {
748
- let temp = vec3_1.vec3.cross(vec3_1.vec3.unitX, a);
749
- if (vec3_1.vec3.length(temp) < 0.000001) {
750
- temp = vec3_1.vec3.cross(vec3_1.vec3.unitY, a);
751
- }
752
- temp = vec3_1.vec3.normalize(temp);
753
- return fromAxisAngle(temp, Math.PI);
754
- }
755
- else {
756
- const tmp = vec3_1.vec3.cross(a, b);
757
- const out = [tmp[0], tmp[1], tmp[2], 1 + dot];
758
- return quat.normalize(out);
759
- }
760
- };
761
- })();
762
- /**
763
- * Performs a spherical linear interpolation with two control points
764
- *
765
- * @param a the first operand
766
- * @param b the second operand
767
- * @param c the third operand
768
- * @param d the fourth operand
769
- * @param t interpolation amount, in the range [0-1], between the two inputs
770
- */
771
- function sqlerp(a, b, c, d, t) {
772
- const temp1 = slerp(a, d, t);
773
- const temp2 = slerp(b, c, t);
774
- return slerp(temp1, temp2, 2 * t * (1 - t));
775
- }
776
- quat.sqlerp = sqlerp;
777
- /**
778
- * Sets the specified quaternion with values corresponding to the given
779
- * axes. Each axis is a vec3 and is expected to be unit length and
780
- * perpendicular to all other specified axes.
781
- *
782
- * @param view the vector representing the viewing direction
783
- * @param right the vector representing the local "right" direction
784
- * @param up the vector representing the local "up" direction
785
- */
786
- function setAxes(view, right, up) {
787
- const matr = [
788
- right[0],
789
- up[0],
790
- -view[0],
791
- right[1],
792
- up[1],
793
- -view[1],
794
- right[2],
795
- up[2],
796
- -view[2],
797
- ];
798
- return quat.normalize(fromMat3(matr));
799
- }
800
- quat.setAxes = setAxes;
801
- })(quat || (exports.quat = quat = {}));
802
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicXVhdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9xdWF0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLGlEQUFrQztBQUVsQyxpQ0FBMkI7QUFDM0IsaUNBQTJCO0FBQzNCLGlDQUEyQjtBQVEzQjs7O0dBR0c7QUFDSCxJQUFpQixJQUFJLENBeXpCcEI7QUF6ekJELFdBQWlCLElBQUk7SUFPcEI7OztPQUdHO0lBQ0gsU0FBZ0IsRUFBRSxDQUFDLENBQVMsRUFBRSxDQUFTLEVBQUUsQ0FBUyxFQUFFLENBQVM7UUFDNUQsT0FBTyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFBO0lBQ3BCLENBQUM7SUFGZSxPQUFFLEtBRWpCLENBQUE7SUFFRDs7O09BR0c7SUFDSCxTQUFnQixLQUFLLENBQUMsQ0FBTztRQUM1QixPQUFPLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQTtJQUNkLENBQUM7SUFGZSxVQUFLLFFBRXBCLENBQUE7SUFFRDs7O09BR0c7SUFDSCxTQUFnQixLQUFLLENBQUMsQ0FBTyxFQUFFLEdBQVcsRUFBRSxHQUFXO1FBQ3RELE9BQU87WUFDTixJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRSxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUNsQyxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRSxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUNsQyxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRSxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUNsQyxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFB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VCxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDO2dCQUFFLENBQUMsR0FBRyxDQUFDLENBQUE7WUFDdEIsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDO2dCQUFFLENBQUMsR0FBRyxDQUFDLENBQUE7WUFDOUIsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFBO1lBQ3JCLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQTtZQUVyQixLQUFLLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQTtZQUNqRSxHQUFHLENBQUMsQ0FBQyxDQUFDLEdBQUcsR0FBRyxHQUFHLEtBQUssQ0FBQTtZQUNwQixLQUFLLEdBQUcsR0FBRyxHQUFHLEtBQUssQ0FBQTtZQUNuQixHQUFHLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxHQUFHLEtBQUssQ0FBQTtZQUM5QyxHQUFHLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxHQUFHLEtBQUssQ0FBQTtZQUM5QyxHQUFHLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENB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LEdBQUcsRUFBRSxHQUFHLEVBQUU7b0JBQzNCLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRTtvQkFDM0IsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFO29CQUMzQixFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUU7aUJBQzNCLENBQUE7WUFFRixLQUFLLEtBQUs7Z0JBQ1QsT0FBTztvQkFDTixFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUU7b0JBQzNCLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRTtvQkFDM0IsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFO29CQUMzQixFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUU7aUJBQzNCLENBQUE7WUFFRixLQUFLLEtBQUs7Z0JBQ1QsT0FBTztvQkFDTixFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUU7b0JBQzNCLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRTtvQkFDM0IsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFO29CQUMzQixFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUU7aUJBQzNCLENBQUE7WUFFRixLQUFLLEtBQUs7Z0JBQ1QsT0FBTztvQkFDTixFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUU7b0JBQzNCLEVBQUUsR0FBRyxFQUFFLEdB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