linearly 0.3.0 → 0.4.1

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 (79) hide show
  1. package/lib/{common.d.ts → cjs/common.d.ts} +1 -0
  2. package/lib/cjs/common.d.ts.map +1 -0
  3. package/lib/cjs/common.js +20 -0
  4. package/lib/{index.d.ts → cjs/index.d.ts} +1 -0
  5. package/lib/cjs/index.d.ts.map +1 -0
  6. package/lib/cjs/index.js +35 -0
  7. package/lib/{mat2.d.ts → cjs/mat2.d.ts} +1 -0
  8. package/lib/cjs/mat2.d.ts.map +1 -0
  9. package/lib/cjs/mat2.js +224 -0
  10. package/lib/{mat2d.d.ts → cjs/mat2d.d.ts} +1 -0
  11. package/lib/cjs/mat2d.d.ts.map +1 -0
  12. package/lib/cjs/mat2d.js +291 -0
  13. package/lib/{mat3.d.ts → cjs/mat3.d.ts} +1 -0
  14. package/lib/cjs/mat3.d.ts.map +1 -0
  15. package/lib/cjs/mat3.js +450 -0
  16. package/lib/{mat4.d.ts → cjs/mat4.d.ts} +1 -0
  17. package/lib/cjs/mat4.d.ts.map +1 -0
  18. package/lib/cjs/mat4.js +1250 -0
  19. package/lib/{quat.d.ts → cjs/quat.d.ts} +1 -0
  20. package/lib/cjs/quat.d.ts.map +1 -0
  21. package/lib/cjs/quat.js +504 -0
  22. package/lib/{vec2.d.ts → cjs/vec2.d.ts} +1 -0
  23. package/lib/cjs/vec2.d.ts.map +1 -0
  24. package/lib/cjs/vec2.js +205 -0
  25. package/lib/{vec3.d.ts → cjs/vec3.d.ts} +1 -0
  26. package/lib/cjs/vec3.d.ts.map +1 -0
  27. package/lib/cjs/vec3.js +409 -0
  28. package/lib/{vec4.d.ts → cjs/vec4.d.ts} +1 -0
  29. package/lib/cjs/vec4.d.ts.map +1 -0
  30. package/lib/cjs/vec4.js +319 -0
  31. package/lib/esm/common.d.ts +12 -0
  32. package/lib/esm/common.d.ts.map +1 -0
  33. package/lib/esm/common.js +16 -0
  34. package/lib/esm/index.d.ts +17 -0
  35. package/lib/esm/index.d.ts.map +1 -0
  36. package/lib/esm/index.js +9 -0
  37. package/lib/esm/mat2.d.ts +91 -0
  38. package/lib/esm/mat2.d.ts.map +1 -0
  39. package/lib/esm/mat2.js +179 -0
  40. package/lib/esm/mat2d.d.ts +102 -0
  41. package/lib/esm/mat2d.d.ts.map +1 -0
  42. package/lib/esm/mat2d.js +246 -0
  43. package/lib/esm/mat3.d.ts +120 -0
  44. package/lib/esm/mat3.d.ts.map +1 -0
  45. package/lib/esm/mat3.js +400 -0
  46. package/lib/esm/mat4.d.ts +313 -0
  47. package/lib/esm/mat4.d.ts.map +1 -0
  48. package/lib/esm/mat4.js +1183 -0
  49. package/lib/esm/quat.d.ts +220 -0
  50. package/lib/esm/quat.d.ts.map +1 -0
  51. package/lib/esm/quat.js +458 -0
  52. package/lib/esm/vec2.d.ts +66 -0
  53. package/lib/esm/vec2.d.ts.map +1 -0
  54. package/lib/esm/vec2.js +149 -0
  55. package/lib/esm/vec3.d.ts +167 -0
  56. package/lib/esm/vec3.d.ts.map +1 -0
  57. package/lib/esm/vec3.js +348 -0
  58. package/lib/esm/vec4.d.ts +116 -0
  59. package/lib/esm/vec4.d.ts.map +1 -0
  60. package/lib/esm/vec4.js +266 -0
  61. package/package.json +6 -4
  62. package/lib/common.js +0 -30
  63. package/lib/index.js +0 -45
  64. package/lib/mat2.js +0 -234
  65. package/lib/mat2d.js +0 -301
  66. package/lib/mat2d.test.d.ts +0 -1
  67. package/lib/mat2d.test.js +0 -123
  68. package/lib/mat3.js +0 -460
  69. package/lib/mat4.js +0 -1260
  70. package/lib/quat.js +0 -514
  71. package/lib/vec2.js +0 -215
  72. package/lib/vec2.test.d.ts +0 -1
  73. package/lib/vec2.test.js +0 -147
  74. package/lib/vec3.js +0 -419
  75. package/lib/vec3.test.d.ts +0 -1
  76. package/lib/vec3.test.js +0 -149
  77. package/lib/vec4.js +0 -329
  78. package/lib/vec4.test.d.ts +0 -1
  79. package/lib/vec4.test.js +0 -45
@@ -217,3 +217,4 @@ export declare function sqlerp(a: Quat, b: Quat, c: Quat, d: Quat, t: number): Q
217
217
  */
218
218
  export declare function setAxes(view: Vec3, right: Vec3, up: Vec3): Quat;
219
219
  export {};
220
+ //# sourceMappingURL=quat.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"quat.d.ts","sourceRoot":"","sources":["../../src/quat.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,504 @@
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 (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ exports.setAxes = exports.sqlerp = exports.rotationTo = exports.equals = exports.exactEquals = exports.normalize = exports.sqrLen = exports.squaredLength = exports.len = exports.length = exports.lerp = exports.dot = exports.scale = exports.add = exports.fromEuler = exports.fromMat3 = exports.conjugate = exports.invert = exports.slerp = exports.pow = exports.ln = exports.exp = exports.calculateW = exports.rotateZ = exports.rotateY = exports.rotateX = exports.multiply = exports.getAngle = exports.getAxisAngle = exports.setAxisAngle = exports.identity = exports.of = void 0;
27
+ const Common = __importStar(require("./common"));
28
+ const vec3 = __importStar(require("./vec3"));
29
+ const vec4 = __importStar(require("./vec4"));
30
+ function of(x, y, z, w) {
31
+ return [x, y, z, w];
32
+ }
33
+ exports.of = of;
34
+ /**
35
+ * The identity quaternion
36
+ */
37
+ exports.identity = Object.freeze([0, 0, 0, 1]);
38
+ /**
39
+ * Sets a quat from the given angle and rotation axis,
40
+ * then returns it.
41
+ *
42
+ * @param axis the axis around which to rotate
43
+ * @param rad the angle in radians
44
+ **/
45
+ function setAxisAngle(axis, rad) {
46
+ rad = rad * 0.5;
47
+ const s = Math.sin(rad);
48
+ return [s * axis[0], s * axis[1], s * axis[2], Math.cos(rad)];
49
+ }
50
+ exports.setAxisAngle = setAxisAngle;
51
+ /**
52
+ * Gets the rotation axis and angle for a given
53
+ * quaternion. If a quaternion is created with
54
+ * setAxisAngle, this method will return the same
55
+ * values as providied in the original parameter list
56
+ * OR functionally equivalent values.
57
+ * Example: The quaternion formed by axis [0, 0, 1] and
58
+ * angle -90 is the same as the quaternion formed by
59
+ * [0, 0, 1] and 270. This method favors the latter.
60
+ *
61
+ * @param q Quaternion to be decomposed
62
+ */
63
+ function getAxisAngle(q) {
64
+ const rad = Math.acos(q[3]) * 2;
65
+ const s = Math.sin(rad / 2);
66
+ let axis;
67
+ if (s > Common.EPSILON) {
68
+ axis = [q[0] / s, q[1] / s, q[2] / s];
69
+ }
70
+ else {
71
+ // If s is zero, return any axis (no rotation - axis does not matter)
72
+ axis = [1, 0, 0];
73
+ }
74
+ return { axis, rad };
75
+ }
76
+ exports.getAxisAngle = getAxisAngle;
77
+ /**
78
+ * Gets the angular distance between two unit quaternions
79
+ *
80
+ * @param a Origin unit quaternion
81
+ * @param b Destination unit quaternion
82
+ * @return Angle, in radians, between the two quaternions
83
+ */
84
+ function getAngle(a, b) {
85
+ const dotproduct = (0, exports.dot)(a, b);
86
+ return Math.acos(2 * dotproduct * dotproduct - 1);
87
+ }
88
+ exports.getAngle = getAngle;
89
+ /**
90
+ * Multiplies two quat's
91
+ *
92
+ * @param a the first operand
93
+ * @param b the second operand
94
+ */
95
+ function multiply(a, b) {
96
+ const [ax, ay, az, aw] = a;
97
+ const [bx, by, bz, bw] = b;
98
+ return [
99
+ ax * bw + aw * bx + ay * bz - az * by,
100
+ ay * bw + aw * by + az * bx - ax * bz,
101
+ az * bw + aw * bz + ax * by - ay * bx,
102
+ aw * bw - ax * bx - ay * by - az * bz,
103
+ ];
104
+ }
105
+ exports.multiply = multiply;
106
+ /**
107
+ * Rotates a quaternion by the given angle about the X axis
108
+ *
109
+ * @param a quat to rotate
110
+ * @param rad angle (in radians) to rotate
111
+ */
112
+ function rotateX(a, rad) {
113
+ rad *= 0.5;
114
+ const ax = a[0], ay = a[1], az = a[2], aw = a[3];
115
+ const bx = Math.sin(rad), bw = Math.cos(rad);
116
+ return [
117
+ ax * bw + aw * bx,
118
+ ay * bw + az * bx,
119
+ az * bw - ay * bx,
120
+ aw * bw - ax * bx,
121
+ ];
122
+ }
123
+ exports.rotateX = rotateX;
124
+ /**
125
+ * Rotates a quaternion by the given angle about the Y axis
126
+ *
127
+ * @param a quat to rotate
128
+ * @param rad angle (in radians) to rotate
129
+ */
130
+ function rotateY(a, rad) {
131
+ rad *= 0.5;
132
+ const ax = a[0], ay = a[1], az = a[2], aw = a[3];
133
+ const by = Math.sin(rad), bw = Math.cos(rad);
134
+ return [
135
+ ax * bw - az * by,
136
+ ay * bw + aw * by,
137
+ az * bw + ax * by,
138
+ aw * bw - ay * by,
139
+ ];
140
+ }
141
+ exports.rotateY = rotateY;
142
+ /**
143
+ * Rotates a quaternion by the given angle about the Z axis
144
+ *
145
+ * @param a quat to rotate
146
+ * @param rad angle (in radians) to rotate
147
+ */
148
+ function rotateZ(a, rad) {
149
+ rad *= 0.5;
150
+ const ax = a[0], ay = a[1], az = a[2], aw = a[3];
151
+ const bz = Math.sin(rad), bw = Math.cos(rad);
152
+ return [
153
+ ax * bw + ay * bz,
154
+ ay * bw - ax * bz,
155
+ az * bw + aw * bz,
156
+ aw * bw - az * bz,
157
+ ];
158
+ }
159
+ exports.rotateZ = rotateZ;
160
+ /**
161
+ * Calculates the W component of a quat from the X, Y, and Z components.
162
+ * Assumes that quaternion is 1 unit in length.
163
+ * Any existing W component will be ignored.
164
+ */
165
+ function calculateW(a) {
166
+ const [x, y, z] = a;
167
+ return [x, y, z, Math.sqrt(Math.abs(1 - x * x - y * y - z * z))];
168
+ }
169
+ exports.calculateW = calculateW;
170
+ /**
171
+ * Calculate the exponential of a unit quaternion.
172
+ */
173
+ function exp(a) {
174
+ const [x, y, z, w] = a;
175
+ const r = Math.sqrt(x * x + y * y + z * z);
176
+ const et = Math.exp(w);
177
+ const s = r > 0 ? (et * Math.sin(r)) / r : 0;
178
+ return [x * s, y * s, z * s, et * Math.cos(r)];
179
+ }
180
+ exports.exp = exp;
181
+ /**
182
+ * Calculate the natural logarithm of a unit quaternion.
183
+ */
184
+ function ln(a) {
185
+ const [x, y, z, w] = a;
186
+ const r = Math.sqrt(x * x + y * y + z * z);
187
+ const t = r > 0 ? Math.atan2(r, w) / r : 0;
188
+ return [x * t, y * t, z * t, 0.5 * Math.log(x * x + y * y + z * z + w * w)];
189
+ }
190
+ exports.ln = ln;
191
+ /**
192
+ * Calculate the scalar power of a unit quaternion.
193
+ */
194
+ function pow(a, b) {
195
+ return exp((0, exports.scale)(ln(a), b));
196
+ }
197
+ exports.pow = pow;
198
+ /**
199
+ * Performs a spherical linear interpolation between two quat
200
+ *
201
+ * @param a the first operand
202
+ * @param b the second operand
203
+ * @param t interpolation amount, in the range [0-1], between the two inputs
204
+ */
205
+ function slerp(a, b, t) {
206
+ // benchmarks:
207
+ // http://jsperf.com/quaternion-slerp-implementations
208
+ const [ax, ay, az, aw] = a;
209
+ let [bx, by, bz, bw] = b;
210
+ let omega, cosom, sinom, scale0, scale1;
211
+ // calc cosine
212
+ cosom = ax * bx + ay * by + az * bz + aw * bw;
213
+ // adjust signs (if necessary)
214
+ if (cosom < 0) {
215
+ cosom *= -1;
216
+ bx *= -1;
217
+ by *= -1;
218
+ bz *= -1;
219
+ bw *= -1;
220
+ }
221
+ // calculate coefficients
222
+ if (1 - cosom > Common.EPSILON) {
223
+ // standard case (slerp)
224
+ omega = Math.acos(cosom);
225
+ sinom = Math.sin(omega);
226
+ scale0 = Math.sin((1 - t) * omega) / sinom;
227
+ scale1 = Math.sin(t * omega) / sinom;
228
+ }
229
+ else {
230
+ // "from" and "to" quaternions are very close
231
+ // ... so we can do a linear interpolation
232
+ scale0 = 1 - t;
233
+ scale1 = t;
234
+ }
235
+ // calculate final values
236
+ return [
237
+ scale0 * ax + scale1 * bx,
238
+ scale0 * ay + scale1 * by,
239
+ scale0 * az + scale1 * bz,
240
+ scale0 * aw + scale1 * bw,
241
+ ];
242
+ }
243
+ exports.slerp = slerp;
244
+ /**
245
+ * Calculates the inverse of a quat
246
+ */
247
+ function invert(a) {
248
+ const a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3];
249
+ const dot = a0 * a0 + a1 * a1 + a2 * a2 + a3 * a3;
250
+ const invDot = dot ? 1 / dot : 0;
251
+ // TODO: Would be faster to return [0,0,0,0] immediately if dot == 0
252
+ return [-a0 * invDot, -a1 * invDot, -a2 * invDot, a3 * invDot];
253
+ }
254
+ exports.invert = invert;
255
+ /**
256
+ * Calculates the conjugate of a quat
257
+ * If the quaternion is normalized, this function is faster than quat.inverse and produces the same result.
258
+ */
259
+ function conjugate(a) {
260
+ return [-a[0], -a[1], -a[2], a[3]];
261
+ }
262
+ exports.conjugate = conjugate;
263
+ /**
264
+ * Creates a quaternion from the given 3x3 rotation matrix.
265
+ *
266
+ * NOTE: The resultant quaternion is not normalized, so you should be sure
267
+ * to renormalize the quaternion yourself where necessary.
268
+ */
269
+ function fromMat3(m) {
270
+ // Algorithm in Ken Shoemake's article in 1987 SIGGRAPH course notes
271
+ // article "Quaternion Calculus and Fast Animation".
272
+ const fTrace = m[0] + m[4] + m[8];
273
+ let fRoot;
274
+ const out = [0, 0, 0, 0];
275
+ if (fTrace > 0) {
276
+ // |w| > 1/2, may as well choose w > 1/2
277
+ fRoot = Math.sqrt(fTrace + 1); // 2w
278
+ out[3] = 0.5 * fRoot;
279
+ fRoot = 0.5 / fRoot; // 1/(4w)
280
+ out[0] = (m[5] - m[7]) * fRoot;
281
+ out[1] = (m[6] - m[2]) * fRoot;
282
+ out[2] = (m[1] - m[3]) * fRoot;
283
+ }
284
+ else {
285
+ // |w| <= 1/2
286
+ let i = 0;
287
+ if (m[4] > m[0])
288
+ i = 1;
289
+ if (m[8] > m[i * 3 + i])
290
+ i = 2;
291
+ const j = (i + 1) % 3;
292
+ const k = (i + 2) % 3;
293
+ fRoot = Math.sqrt(m[i * 3 + i] - m[j * 3 + j] - m[k * 3 + k] + 1);
294
+ out[i] = 0.5 * fRoot;
295
+ fRoot = 0.5 / fRoot;
296
+ out[3] = (m[j * 3 + k] - m[k * 3 + j]) * fRoot;
297
+ out[j] = (m[j * 3 + i] + m[i * 3 + j]) * fRoot;
298
+ out[k] = (m[k * 3 + i] + m[i * 3 + k]) * fRoot;
299
+ }
300
+ return out;
301
+ }
302
+ exports.fromMat3 = fromMat3;
303
+ /**
304
+ * Creates a quaternion from the given euler angle x, y, z using the provided intrinsic order for the conversion.
305
+ *
306
+ * @param x Angle to rotate around X axis in degrees.
307
+ * @param y Angle to rotate around Y axis in degrees.
308
+ * @param z Angle to rotate around Z axis in degrees.
309
+ * @param order Intrinsic order for conversion, default is zyx.
310
+ * @function
311
+ */
312
+ function fromEuler(x, y, z, order = Common.DEFAULT_ANGLE_ORDER) {
313
+ const halfToRad = Math.PI / 360;
314
+ x *= halfToRad;
315
+ z *= halfToRad;
316
+ y *= halfToRad;
317
+ const sx = Math.sin(x);
318
+ const cx = Math.cos(x);
319
+ const sy = Math.sin(y);
320
+ const cy = Math.cos(y);
321
+ const sz = Math.sin(z);
322
+ const cz = Math.cos(z);
323
+ switch (order) {
324
+ case 'xyz':
325
+ return [
326
+ sx * cy * cz + cx * sy * sz,
327
+ cx * sy * cz - sx * cy * sz,
328
+ cx * cy * sz + sx * sy * cz,
329
+ cx * cy * cz - sx * sy * sz,
330
+ ];
331
+ case 'xzy':
332
+ return [
333
+ sx * cy * cz - cx * sy * sz,
334
+ cx * sy * cz - sx * cy * sz,
335
+ cx * cy * sz + sx * sy * cz,
336
+ cx * cy * cz + sx * sy * sz,
337
+ ];
338
+ case 'yxz':
339
+ return [
340
+ sx * cy * cz + cx * sy * sz,
341
+ cx * sy * cz - sx * cy * sz,
342
+ cx * cy * sz - sx * sy * cz,
343
+ cx * cy * cz + sx * sy * sz,
344
+ ];
345
+ case 'yzx':
346
+ return [
347
+ sx * cy * cz + cx * sy * sz,
348
+ cx * sy * cz + sx * cy * sz,
349
+ cx * cy * sz - sx * sy * cz,
350
+ cx * cy * cz - sx * sy * sz,
351
+ ];
352
+ case 'zxy':
353
+ return [
354
+ sx * cy * cz - cx * sy * sz,
355
+ cx * sy * cz + sx * cy * sz,
356
+ cx * cy * sz + sx * sy * cz,
357
+ cx * cy * cz - sx * sy * sz,
358
+ ];
359
+ case 'zyx':
360
+ return [
361
+ sx * cy * cz - cx * sy * sz,
362
+ cx * sy * cz + sx * cy * sz,
363
+ cx * cy * sz - sx * sy * cz,
364
+ cx * cy * cz + sx * sy * sz,
365
+ ];
366
+ }
367
+ }
368
+ exports.fromEuler = fromEuler;
369
+ /**
370
+ * Adds two quat's
371
+ */
372
+ exports.add = vec4.add;
373
+ /**
374
+ * Scales a quat by a scalar number
375
+ */
376
+ exports.scale = vec4.scale;
377
+ /**
378
+ * Calculates the dot product of two quat's
379
+ */
380
+ exports.dot = vec4.dot;
381
+ /**
382
+ * Performs a linear interpolation between two quat's
383
+ *
384
+ * @param a the first operand
385
+ * @param b the second operand
386
+ * @param t interpolation amount, in the range [0-1], between the two inputs
387
+ */
388
+ exports.lerp = vec4.lerp;
389
+ /**
390
+ * Calculates the length of a quat
391
+ *
392
+ * @param a vector to calculate length of
393
+ * @returns length of a
394
+ */
395
+ exports.length = vec4.length;
396
+ /**
397
+ * Alias for {@link quat.length}
398
+ * @function
399
+ */
400
+ exports.len = exports.length;
401
+ /**
402
+ * Calculates the squared length of a quat
403
+ *
404
+ * @param a vector to calculate squared length of
405
+ * @returns squared length of a
406
+ * @function
407
+ */
408
+ exports.squaredLength = vec4.squaredLength;
409
+ /**
410
+ * Alias for {@link quat.squaredLength}
411
+ * @function
412
+ */
413
+ exports.sqrLen = exports.squaredLength;
414
+ /**
415
+ * Normalize a quat
416
+ *
417
+ * @param a quaternion to normalize
418
+ */
419
+ exports.normalize = vec4.normalize;
420
+ /**
421
+ * Returns whether or not the quaternions have exactly the same elements in the same position (when compared with ===)
422
+ */
423
+ exports.exactEquals = vec4.exactEquals;
424
+ /**
425
+ * Returns whether or not the quaternions point approximately to the same direction.
426
+ *
427
+ * Both quaternions are assumed to be unit length.
428
+ */
429
+ function equals(a, b) {
430
+ return Math.abs(vec4.dot(a, b)) >= 1 - Common.EPSILON;
431
+ }
432
+ exports.equals = equals;
433
+ /**
434
+ * Sets a quaternion to represent the shortest rotation from one
435
+ * vector to another.
436
+ *
437
+ * Both vectors are assumed to be unit length.
438
+ *
439
+ * @param a the initial vector
440
+ * @param b the destination vector
441
+ */
442
+ exports.rotationTo = (function () {
443
+ const xUnitVec3 = [1, 0, 0];
444
+ const yUnitVec3 = [0, 1, 0];
445
+ return (a, b) => {
446
+ const dot = vec3.dot(a, b);
447
+ if (dot > 1 - Common.EPSILON) {
448
+ return exports.identity;
449
+ }
450
+ else if (dot < -1 + Common.EPSILON) {
451
+ let temp = vec3.cross(xUnitVec3, a);
452
+ if (vec3.length(temp) < 0.000001) {
453
+ temp = vec3.cross(yUnitVec3, a);
454
+ }
455
+ temp = vec3.normalize(temp);
456
+ return setAxisAngle(temp, Math.PI);
457
+ }
458
+ else {
459
+ const tmp = vec3.cross(a, b);
460
+ const out = [tmp[0], tmp[1], tmp[2], 1 + dot];
461
+ return (0, exports.normalize)(out);
462
+ }
463
+ };
464
+ })();
465
+ /**
466
+ * Performs a spherical linear interpolation with two control points
467
+ *
468
+ * @param a the first operand
469
+ * @param b the second operand
470
+ * @param c the third operand
471
+ * @param d the fourth operand
472
+ * @param t interpolation amount, in the range [0-1], between the two inputs
473
+ */
474
+ function sqlerp(a, b, c, d, t) {
475
+ const temp1 = slerp(a, d, t);
476
+ const temp2 = slerp(b, c, t);
477
+ return slerp(temp1, temp2, 2 * t * (1 - t));
478
+ }
479
+ exports.sqlerp = sqlerp;
480
+ /**
481
+ * Sets the specified quaternion with values corresponding to the given
482
+ * axes. Each axis is a vec3 and is expected to be unit length and
483
+ * perpendicular to all other specified axes.
484
+ *
485
+ * @param view the vector representing the viewing direction
486
+ * @param right the vector representing the local "right" direction
487
+ * @param up the vector representing the local "up" direction
488
+ */
489
+ function setAxes(view, right, up) {
490
+ const matr = [
491
+ right[0],
492
+ up[0],
493
+ -view[0],
494
+ right[1],
495
+ up[1],
496
+ -view[1],
497
+ right[2],
498
+ up[2],
499
+ -view[2],
500
+ ];
501
+ return (0, exports.normalize)(fromMat3(matr));
502
+ }
503
+ exports.setAxes = setAxes;
504
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicXVhdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9xdWF0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsaURBQWtDO0FBR2xDLDZDQUE4QjtBQUM5Qiw2Q0FBOEI7QUFTOUIsU0FBZ0IsRUFBRSxDQUFDLENBQVMsRUFBRSxDQUFTLEVBQUUsQ0FBUyxFQUFFLENBQVM7SUFDNUQsT0FBTyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFBO0FBQ3BCLENBQUM7QUFGRCxnQkFFQztBQUVEOztHQUVHO0FBQ1UsUUFBQSxRQUFRLEdBQVMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUE7QUFFekQ7Ozs7OztJQU1JO0FBQ0osU0FBZ0IsWUFBWSxDQUFDLElBQVUsRUFBRSxHQUFXO0lBQ25ELEdBQUcsR0FBRyxHQUFHLEdBQUcsR0FBRyxDQUFBO0lBQ2YsTUFBTSxDQUFDLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQTtJQUV2QixPQUFPLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLEdBQUcsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsR0FBRyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFBO0FBQzlELENBQUM7QUFMRCxvQ0FLQztBQU9EOzs7Ozs7Ozs7OztHQVdHO0FBQ0gsU0FBZ0IsWUFBWSxDQUFDLENBQU87SUFDbkMsTUFBTSxHQUFHLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUE7SUFDL0IsTUFBTSxDQUFDLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLEdBQUcsQ0FBQyxDQUFDLENBQUE7SUFFM0IsSUFBSSxJQUFVLENBQUE7SUFFZCxJQUFJLENBQUMsR0FBRyxNQUFNLENBQUMsT0FBTyxFQUFFO1FBQ3ZCLElBQUksR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUE7S0FDckM7U0FBTTtRQUNOLHFFQUFxRTtRQUNyRSxJQUFJLEdBQUcsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFBO0tBQ2hCO0lBQ0QsT0FBTyxFQUFDLElBQUksRUFBRSxHQUFHLEVBQUMsQ0FBQTtBQUNuQixDQUFDO0FBYkQsb0NBYUM7QUFFRDs7Ozs7O0dBTUc7QUFDSCxTQUFnQixRQUFRLENBQUMsQ0FBTyxFQUFFLENBQU87SUFDeEMsTUFBTSxVQUFVLEdBQUcsSUFBQSxXQUFHLEVBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFBO0lBRTVCLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLEdBQUcsVUFBVSxHQUFHLFVBQVUsR0FBRyxDQUFDLENBQUMsQ0FBQTtBQUNsRCxDQUFDO0FBSkQsNEJBSUM7QUFFRDs7Ozs7R0FLRztBQUNILFNBQWdCLFFBQVEsQ0FBQyxDQUFPLEVBQUUsQ0FBTztJQUN4QyxNQUFNLENBQUMsRUFBRSxFQUFFLEVBQUUsRUFBRSxFQUFFLEVBQUUsRUFBRSxDQUFDLEdBQUcsQ0FBQyxDQUFBO0lBQzFCLE1BQU0sQ0FBQyxFQUFFLEVBQUUsRUFBRSxFQUFFLEVBQUUsRUFBRSxFQUFFLENBQUMsR0FBRyxDQUFDLENBQUE7SUFFMUIsT0FBTztRQUNOLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFO1FBQ3JDLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFO1FBQ3JDLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFO1FBQ3JDLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFO0tBQ3JDLENBQUE7QUFDRixDQUFDO0FBVkQsNEJBVUM7QUFFRDs7Ozs7R0FLRztBQUNILFNBQWdCLE9BQU8sQ0FBQyxDQUFPLEVBQUUsR0FBVztJQUMzQyxHQUFHLElBQUksR0FBRyxDQUFBO0lBRVYsTUFBTSxFQUFFLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUNkLEVBQUUsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQ1QsRUFBRSxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFDVCxFQUFFLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFBO0lBQ1YsTUFBTSxFQUFFLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsRUFDdkIsRUFBRSxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUE7SUFFbkIsT0FBTztRQUNOLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUU7UUFDakIsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRTtRQUNqQixFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFO1FBQ2pCLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUU7S0FDakIsQ0FBQTtBQUNGLENBQUM7QUFoQkQsMEJBZ0JDO0FBRUQ7Ozs7O0dBS0c7QUFDSCxTQUFnQixPQUFPLENBQUMsQ0FBTyxFQUFFLEdBQVc7SUFDM0MsR0FBRyxJQUFJLEdBQUcsQ0FBQTtJQUVWLE1BQU0sRUFBRSxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFDZCxFQUFFLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUNULEVBQUUsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQ1QsRUFBRSxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQTtJQUNWLE1BQU0sRUFBRSxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLEVBQ3ZCLEVBQUUsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFBO0lBRW5CLE9BQU87UUFDTixFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFO1FBQ2pCLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUU7UUFDakIsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRTtRQUNqQixFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFO0tBQ2pCLENBQUE7QUFDRixDQUFDO0FBaEJELDBCQWdCQztBQUVEOzs7OztHQUtHO0FBQ0gsU0FBZ0IsT0FBTyxDQUFDLENBQU8sRUFBRSxHQUFXO0lBQzNDLEdBQUcsSUFBSSxHQUFHLENBQUE7SUFFVixNQUFNLEVBQUUsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQ2QsRUFBRSxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFDVCxFQUFFLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUNULEVBQUUsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUE7SUFDVixNQUFNLEVBQUUsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxFQUN2QixFQUFFLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQTtJQUVuQixPQUFPO1FBQ04sRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRTtRQUNqQixFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFO1FBQ2pCLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUU7UUFDakIsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRTtLQUNqQixDQUFBO0FBQ0YsQ0FBQztBQWhCRCwwQkFnQkM7QUFFRDs7OztHQUlHO0FBQ0gsU0FBZ0IsVUFBVSxDQUFDLENBQU87SUFDakMsTUFBTSxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFBO0lBRW5CLE9BQU8sQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFBO0FBQ2pFLENBQUM7QUFKRCxnQ0FJQztBQUVEOztHQUVHO0FBQ0gsU0FBZ0IsR0FBRyxDQUFDLENBQU87SUFDMUIsTUFBTSxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQTtJQUV0QixNQUFNLENBQUMsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUE7SUFDMUMsTUFBTSxFQUFFLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQTtJQUN0QixNQUFNLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUE7SUFFNUMsT0FBTyxDQUFDLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyxFQUFFLEVBQUUsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUE7QUFDL0MsQ0FBQztBQVJELGtCQVFDO0FBRUQ7O0dBRUc7QUFDSCxTQUFnQixFQUFFLENBQUMsQ0FBTztJQUN6QixNQUFNLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFBO0lBRXRCLE1BQU0sQ0FBQyxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQTtJQUMxQyxNQUFNLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQTtJQUUxQyxPQUFPLENBQUMsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxDQUFDLEVBQUUsR0FBRyxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUE7QUFDNUUsQ0FBQztBQVBELGdCQU9DO0FBRUQ7O0dBRUc7QUFDSCxTQUFnQixHQUFHLENBQUMsQ0FBTyxFQUFFLENBQVM7SUFDckMsT0FBTyxHQUFHLENBQUMsSUFBQSxhQUFLLEVBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUE7QUFDNUIsQ0FBQztBQUZELGtCQUVDO0FBRUQ7Ozs7OztHQU1HO0FBQ0gsU0FBZ0IsS0FBSyxDQUFDLENBQU8sRUFBRSxDQUFPLEVBQUUsQ0FBUztJQUNoRCxjQUFjO0lBQ2Qsd0RBQXdEO0lBQ3hELE1BQU0sQ0FBQyxFQUFFLEVBQUUsRUFBRSxFQUFFLEVBQUUsRUFBRSxFQUFFLENBQUMsR0FBRyxDQUFDLENBQUE7SUFDMUIsSUFBSSxDQUFDLEVBQUUsRUFBRSxFQUFFLEVBQUUsRUFBRSxFQUFFLEVBQUUsQ0FBQyxHQUFHLENBQUMsQ0FBQTtJQUV4QixJQUFJLEtBQUssRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLENBQUE7SUFFdkMsY0FBYztJQUNkLEtBQUssR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxDQUFBO0lBQzdDLDhCQUE4QjtJQUM5QixJQUFJLEtBQUssR0FBRyxDQUFDLEVBQUU7UUFDZCxLQUFLLElBQUksQ0FBQyxDQUFDLENBQUE7UUFDWCxFQUFFLElBQUksQ0FBQyxDQUFDLENBQUE7UUFDUixFQUFFLElBQUksQ0FBQyxDQUFDLENBQUE7UUFDUixFQUFFLElBQUksQ0FBQyxDQUFDLENBQUE7UUFDUixFQUFFLElBQUksQ0FBQyxDQUFDLENBQUE7S0FDUjtJQUNELHlCQUF5QjtJQUN6QixJQUFJLENBQUMsR0FBRyxLQUFLLEdBQUcsTUFBTSxDQUFDLE9BQU8sRUFBRTtRQUMvQix3QkFBd0I7UUFDeEIsS0FBSyxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUE7UUFDeEIsS0FBSyxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUE7UUFDdkIsTUFBTSxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsS0FBSyxDQUFDLEdBQUcsS0FBSyxDQUFBO1FBQzFDLE1BQU0sR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsR0FBRyxLQUFLLENBQUMsR0FBRyxLQUFLLENBQUE7S0FDcEM7U0FBTTtRQUNOLDZDQUE2QztRQUM3QywyQ0FBMkM7UUFDM0MsTUFBTSxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUE7UUFDZCxNQUFNLEdBQUcsQ0FBQyxDQUFBO0tBQ1Y7SUFDRCx5QkFBeUI7SUFDekIsT0FBTztRQUNOLE1BQU0sR0FBRyxFQUFFLEdBQUcsTUFBTSxHQUFHLEVBQUU7UUFDekIsTUFBTSxHQUFHLEVBQUUsR0FBRyxNQUFNLEdBQUcsRUFBRTtRQUN6QixNQUFNLEdBQUcsRUFBRSxHQUFHLE1BQU0sR0FBRyxFQUFFO1FBQ3pCLE1BQU0sR0FBRyxFQUFFLEdBQUcsTUFBTSxHQUFHLEVBQUU7S0FDekIsQ0FBQTtBQUNGLENBQUM7QUF0Q0Qsc0JBc0NDO0FBRUQ7O0dBRUc7QUFDSCxTQUFnQixNQUFNLENBQUMsQ0FBTztJQUM3QixNQUFNLEVBQUUsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQ2QsRUFBRSxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFDVCxFQUFFLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUNULEVBQUUsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUE7SUFDVixNQUFNLEdBQUcsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxDQUFBO0lBQ2pELE1BQU0sTUFBTSxHQUFHLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFBO0lBRWhDLG9FQUFvRTtJQUNwRSxPQUFPLENBQUMsQ0FBQyxFQUFFLEdBQUcsTUFBTSxFQUFFLENBQUMsRUFBRSxHQUFHLE1BQU0sRUFBRSxDQUFDLEVBQUUsR0FBRyxNQUFNLEVBQUUsRUFBRSxHQUFHLE1BQU0sQ0FBQyxDQUFBO0FBQy9ELENBQUM7QUFWRCx3QkFVQztBQUVEOzs7R0FHRztBQUNILFNBQWdCLFNBQVMsQ0FBQyxDQUFPO0lBQ2hDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQTtBQUNuQyxDQUFDO0FBRkQsOEJBRUM7QUFFRDs7Ozs7R0FLRztBQUNILFNBQWdCLFFBQVEsQ0FBQyxDQUFPO0lBQy9CLG9FQUFvRTtJQUNwRSxvREFBb0Q7SUFDcEQsTUFBTSxNQUFNLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUE7SUFDakMsSUFBSSxLQUFLLENBQUE7SUFDVCxNQUFNLEdBQUcsR0FBRyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFBO0lBRXhCLElBQUksTUFBTSxHQUFHLENBQUMsRUFBRTtRQUNmLHdDQUF3QztRQUN4QyxLQUFLLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLENBQUEsQ0FBQyxLQUFLO1FBQ25DLEdBQUcsQ0FBQyxDQUFDLENBQUMsR0FBRyxHQUFHLEdBQUcsS0FBSyxDQUFBO1FBQ3BCLEtBQUssR0FBRyxHQUFHLEdBQUcsS0FBSyxDQUFBLENBQUMsU0FBUztRQUM3QixHQUFHLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsS0FBSyxDQUFBO1FBQzlCLEdBQUcsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsR0FBRyxLQUFLLENBQUE7UUFDOUIsR0FBRyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLEtBQUssQ0FBQTtLQUM5QjtTQUFNO1FBQ04sYUFBYTtRQUNiLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQTtRQUNULElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFBRSxDQUFDLEdBQUcsQ0FBQyxDQUFBO1FBQ3RCLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQztZQUFFLENBQUMsR0FBRyxDQUFDLENBQUE7UUFDOUIsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFBO1FBQ3JCLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQTtRQUVyQixLQUFLLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQTtRQUNqRSxHQUFHLENBQUMsQ0FBQyxDQUFDLEdBQUcsR0FBRyxHQUFHLEtBQUssQ0FBQTtRQUNwQixLQUFLLEdBQUcsR0FBRyxHQUFHLEtBQUssQ0FBQTtRQUNuQixHQUFHLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxHQUFHLEtBQUssQ0FBQTtRQUM5QyxHQUFHLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxHQUFHLEtBQUssQ0FBQTtRQUM5QyxHQUFHLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxHQUFHLEtBQUssQ0FBQTtLQUM5QztJQUVELE9BQU8s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
@@ -63,3 +63,4 @@ export declare function exactEquals(a: Vec2, b: Vec2): boolean;
63
63
  * Returns whether or not the vectors have approximately the same elements in the same position.
64
64
  */
65
65
  export declare function equals(a: Vec2, b: Vec2): boolean;
66
+ //# sourceMappingURL=vec2.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"vec2.d.ts","sourceRoot":"","sources":["../../src/vec2.ts"],"names":[],"mappings":"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"}