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/vec4.js CHANGED
@@ -1,254 +1,316 @@
1
- import * as Common from './common';
2
- export const zero = Object.freeze([0, 0, 0, 0]);
3
- export const one = Object.freeze([1, 1, 1, 1]);
4
- /**
5
- * Adds two vec4's
6
- */
7
- export function add(a, b) {
8
- return [a[0] + b[0], a[1] + b[1], a[2] + b[2], a[3] + b[3]];
9
- }
10
- /**
11
- * Subtracts vector b from vector a
12
- */
13
- export function subtract(a, b) {
14
- return [a[0] - b[0], a[1] - b[1], a[2] - b[2], a[3] - b[3]];
15
- }
16
- /**
17
- * Multiplies two vec4's
18
- */
19
- export function multiply(a, b) {
20
- return [a[0] * b[0], a[1] * b[1], a[2] * b[2], a[3] * b[3]];
21
- }
22
- /**
23
- * Divides two vec4's
24
- */
25
- export function divide(a, b) {
26
- return [a[0] / b[0], a[1] / b[1], a[2] / b[2], a[3] / b[3]];
27
- }
28
- /**
29
- * Math.ceil the components of a vec4
30
- */
31
- export function ceil(a) {
32
- return [Math.ceil(a[0]), Math.ceil(a[1]), Math.ceil(a[2]), Math.ceil(a[3])];
33
- }
34
- /**
35
- * Math.floor the components of a vec4
36
- */
37
- export function floor(a) {
38
- return [
39
- Math.floor(a[0]),
40
- Math.floor(a[1]),
41
- Math.floor(a[2]),
42
- Math.floor(a[3]),
43
- ];
44
- }
45
- /**
46
- * Returns the minimum of two vec4's
47
- */
48
- export function min(a, b) {
49
- return [
50
- Math.min(a[0], b[0]),
51
- Math.min(a[1], b[1]),
52
- Math.min(a[2], b[2]),
53
- Math.min(a[3], b[3]),
54
- ];
55
- }
56
- /**
57
- * Returns the maximum of two vec4's
58
- */
59
- export function max(a, b) {
60
- return [
61
- Math.max(a[0], b[0]),
62
- Math.max(a[1], b[1]),
63
- Math.max(a[2], b[2]),
64
- Math.max(a[3], b[3]),
65
- ];
66
- }
67
- /**
68
- * Constrain a value to lie between two further values
69
- */
70
- export function clamp(a, min, max) {
71
- return [
72
- Math.min(Math.max(a[0], min[0]), max[0]),
73
- Math.min(Math.max(a[1], min[1]), max[1]),
74
- Math.min(Math.max(a[2], min[2]), max[2]),
75
- Math.min(Math.max(a[3], min[3]), max[3]),
76
- ];
77
- }
78
- /**
79
- * symmetric round the components of a vec4
80
- */
81
- export function round(a) {
82
- return [
83
- Common.round(a[0]),
84
- Common.round(a[1]),
85
- Common.round(a[2]),
86
- Common.round(a[3]),
87
- ];
88
- }
89
- /**
90
- * Scales a vec4 by a scalar number
91
- *
92
- * @param a the vector to scale
93
- * @param s amount to scale the vector by
94
- */
95
- export function scale(a, s) {
96
- return [a[0] * s, a[1] * s, a[2] * s, a[3] * s];
97
- }
98
- /**
99
- * Adds two vec4's after scaling the second operand by a scalar value
100
- * @param scale the amount to scale b by before adding
101
- */
102
- export function scaleAndAdd(a, b, scale) {
103
- return [
104
- a[0] + b[0] * scale,
105
- a[1] + b[1] * scale,
106
- a[2] + b[2] * scale,
107
- a[3] + b[3] * scale,
108
- ];
109
- }
110
- /**
111
- * Calculates the euclidian distance between two vec4's
112
- */
113
- export function distance(a, b) {
114
- const x = b[0] - a[0];
115
- const y = b[1] - a[1];
116
- const z = b[2] - a[2];
117
- const w = b[3] - a[3];
118
- return Math.sqrt(x * x + y * y + z * z + w * w);
119
- }
120
- /**
121
- * Calculates the squared euclidian distance between two vec4's
122
- */
123
- export function squaredDistance(a, b) {
124
- const x = b[0] - a[0];
125
- const y = b[1] - a[1];
126
- const z = b[2] - a[2];
127
- const w = b[3] - a[3];
128
- return x * x + y * y + z * z + w * w;
129
- }
130
- /**
131
- * Calculates the length of a vec4
132
- */
133
- export function length(a) {
134
- const [x, y, z, w] = a;
135
- return Math.sqrt(x * x + y * y + z * z + w * w);
136
- }
137
- /**
138
- * Calculates the squared length of a vec4
139
- */
140
- export function squaredLength(a) {
141
- const [x, y, z, w] = a;
142
- return x * x + y * y + z * z + w * w;
143
- }
144
- /**
145
- * Negates the components of a vec4
146
- */
147
- export function negate(a) {
148
- return [-a[0], -a[1], -a[2], -a[3]];
149
- }
150
- /**
151
- * Returns the inverse of the components of a vec4
152
- */
153
- export function inverse(a) {
154
- return [1 / a[0], 1 / a[1], 1 / a[2], 1 / a[3]];
155
- }
156
- /**
157
- * Normalize a vec4
158
- */
159
- export function normalize(a) {
160
- const [x, y, z, w] = a;
161
- const hyp = x * x + y * y + z * z + w * w;
162
- const len = hyp === 0 ? 0 : 1 / Math.sqrt(hyp);
163
- return [x * len, y * len, z * len, w * len];
164
- }
165
- /**
166
- * Calculates the dot product of two vec4's
167
- */
168
- export function dot(a, b) {
169
- return a[0] * b[0] + a[1] * b[1] + a[2] * b[2] + a[3] * b[3];
170
- }
171
- /**
172
- * Returns the cross-product of three vectors in a 4-dimensional space
173
- */
174
- export function cross(u, v, w) {
175
- const A = v[0] * w[1] - v[1] * w[0];
176
- const B = v[0] * w[2] - v[2] * w[0];
177
- const C = v[0] * w[3] - v[3] * w[0];
178
- const D = v[1] * w[2] - v[2] * w[1];
179
- const E = v[1] * w[3] - v[3] * w[1];
180
- const F = v[2] * w[3] - v[3] * w[2];
181
- const [G, H, I, J] = u;
182
- return [
183
- H * F - I * E + J * D,
184
- -(G * F) + I * C - J * B,
185
- G * E - H * C + J * A,
186
- -(G * D) + H * B - I * A,
187
- ];
188
- }
189
- /**
190
- * Performs a linear interpolation between two vec4's
191
- * @param t interpolation amount, in the range [0-1], between the two inputs
192
- */
193
- export function lerp(a, b, t) {
194
- const [ax, ay, az, aw] = a;
195
- return [
196
- ax + t * (b[0] - ax),
197
- ay + t * (b[1] - ay),
198
- az + t * (b[2] - az),
199
- aw + t * (b[3] - aw),
200
- ];
201
- }
202
- /**
203
- * Transforms the vec4 with a mat4.
204
- */
205
- export function transformMat4(a, m) {
206
- const [x, y, z, w] = a;
207
- return [
208
- m[0] * x + m[4] * y + m[8] * z + m[12] * w,
209
- m[1] * x + m[5] * y + m[9] * z + m[13] * w,
210
- m[2] * x + m[6] * y + m[10] * z + m[14] * w,
211
- m[3] * x + m[7] * y + m[11] * z + m[15] * w,
212
- ];
213
- }
214
- /**
215
- * Transforms the vec4 with a quat
216
- */
217
- export function transformQuat(a, q) {
218
- const [x, y, z] = a;
219
- const [qx, qy, qz, qw] = q;
220
- // calculate quat * vec
221
- const ix = qw * x + qy * z - qz * y;
222
- const iy = qw * y + qz * x - qx * z;
223
- const iz = qw * z + qx * y - qy * x;
224
- const iw = -qx * x - qy * y - qz * z;
225
- // calculate result * inverse quat
226
- return [
227
- ix * qw + iw * -qx + iy * -qz - iz * -qy,
228
- iy * qw + iw * -qy + iz * -qx - ix * -qz,
229
- iz * qw + iw * -qz + ix * -qy - iy * -qx,
230
- a[3],
231
- ];
232
- }
233
- /**
234
- * Returns whether or not the vectors have exactly the same elements in the same position (when compared with ===)
235
- */
236
- export function exactEquals(a, b) {
237
- return a[0] === b[0] && a[1] === b[1] && a[2] === b[2] && a[3] === b[3];
238
- }
239
- /**
240
- * Returns whether or not the vectors have approximately the same elements in the same position.
241
- */
242
- export function equals(a, b) {
243
- const [a0, a1, a2, a3] = a;
244
- const [b0, b1, b2, b3] = b;
245
- return (Math.abs(a0 - b0) <=
246
- Common.EPSILON * Math.max(1, Math.abs(a0), Math.abs(b0)) &&
247
- Math.abs(a1 - b1) <=
248
- Common.EPSILON * Math.max(1, Math.abs(a1), Math.abs(b1)) &&
249
- Math.abs(a2 - b2) <=
250
- Common.EPSILON * Math.max(1, Math.abs(a2), Math.abs(b2)) &&
251
- Math.abs(a3 - b3) <=
252
- Common.EPSILON * Math.max(1, Math.abs(a3), Math.abs(b3)));
253
- }
254
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vec4.js","sourceRoot":"","sources":["../src/vec4.ts"],"names":[],"mappings":"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"}
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]; } };
6
+ }
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.transformQuat = exports.transformMat4 = exports.lerp = exports.cross = exports.dot = exports.normalize = exports.inverse = exports.negate = exports.squaredLength = exports.length = exports.squaredDistance = exports.distance = exports.scaleAndAdd = exports.scale = exports.round = exports.clamp = exports.max = exports.min = exports.floor = exports.ceil = exports.divide = exports.multiply = exports.subtract = exports.add = exports.one = exports.zero = void 0;
36
+ const Common = __importStar(require("./common"));
37
+ exports.zero = Object.freeze([0, 0, 0, 0]);
38
+ exports.one = Object.freeze([1, 1, 1, 1]);
39
+ /**
40
+ * Adds two vec4's
41
+ */
42
+ function add(a, b) {
43
+ return [a[0] + b[0], a[1] + b[1], a[2] + b[2], a[3] + b[3]];
44
+ }
45
+ exports.add = add;
46
+ /**
47
+ * Subtracts vector b from vector a
48
+ */
49
+ function subtract(a, b) {
50
+ return [a[0] - b[0], a[1] - b[1], a[2] - b[2], a[3] - b[3]];
51
+ }
52
+ exports.subtract = subtract;
53
+ /**
54
+ * Multiplies two vec4's
55
+ */
56
+ function multiply(a, b) {
57
+ return [a[0] * b[0], a[1] * b[1], a[2] * b[2], a[3] * b[3]];
58
+ }
59
+ exports.multiply = multiply;
60
+ /**
61
+ * Divides two vec4's
62
+ */
63
+ function divide(a, b) {
64
+ return [a[0] / b[0], a[1] / b[1], a[2] / b[2], a[3] / b[3]];
65
+ }
66
+ exports.divide = divide;
67
+ /**
68
+ * Math.ceil the components of a vec4
69
+ */
70
+ function ceil(a) {
71
+ return [Math.ceil(a[0]), Math.ceil(a[1]), Math.ceil(a[2]), Math.ceil(a[3])];
72
+ }
73
+ exports.ceil = ceil;
74
+ /**
75
+ * Math.floor the components of a vec4
76
+ */
77
+ function floor(a) {
78
+ return [
79
+ Math.floor(a[0]),
80
+ Math.floor(a[1]),
81
+ Math.floor(a[2]),
82
+ Math.floor(a[3]),
83
+ ];
84
+ }
85
+ exports.floor = floor;
86
+ /**
87
+ * Returns the minimum of two vec4's
88
+ */
89
+ function min(a, b) {
90
+ return [
91
+ Math.min(a[0], b[0]),
92
+ Math.min(a[1], b[1]),
93
+ Math.min(a[2], b[2]),
94
+ Math.min(a[3], b[3]),
95
+ ];
96
+ }
97
+ exports.min = min;
98
+ /**
99
+ * Returns the maximum of two vec4's
100
+ */
101
+ function max(a, b) {
102
+ return [
103
+ Math.max(a[0], b[0]),
104
+ Math.max(a[1], b[1]),
105
+ Math.max(a[2], b[2]),
106
+ Math.max(a[3], b[3]),
107
+ ];
108
+ }
109
+ exports.max = max;
110
+ /**
111
+ * Constrain a value to lie between two further values
112
+ */
113
+ function clamp(a, min, max) {
114
+ return [
115
+ Math.min(Math.max(a[0], min[0]), max[0]),
116
+ Math.min(Math.max(a[1], min[1]), max[1]),
117
+ Math.min(Math.max(a[2], min[2]), max[2]),
118
+ Math.min(Math.max(a[3], min[3]), max[3]),
119
+ ];
120
+ }
121
+ exports.clamp = clamp;
122
+ /**
123
+ * symmetric round the components of a vec4
124
+ */
125
+ function round(a) {
126
+ return [
127
+ Common.round(a[0]),
128
+ Common.round(a[1]),
129
+ Common.round(a[2]),
130
+ Common.round(a[3]),
131
+ ];
132
+ }
133
+ exports.round = round;
134
+ /**
135
+ * Scales a vec4 by a scalar number
136
+ *
137
+ * @param a the vector to scale
138
+ * @param s amount to scale the vector by
139
+ */
140
+ function scale(a, s) {
141
+ return [a[0] * s, a[1] * s, a[2] * s, a[3] * s];
142
+ }
143
+ exports.scale = scale;
144
+ /**
145
+ * Adds two vec4's after scaling the second operand by a scalar value
146
+ * @param scale the amount to scale b by before adding
147
+ */
148
+ function scaleAndAdd(a, b, scale) {
149
+ return [
150
+ a[0] + b[0] * scale,
151
+ a[1] + b[1] * scale,
152
+ a[2] + b[2] * scale,
153
+ a[3] + b[3] * scale,
154
+ ];
155
+ }
156
+ exports.scaleAndAdd = scaleAndAdd;
157
+ /**
158
+ * Calculates the euclidian distance between two vec4's
159
+ */
160
+ function distance(a, b) {
161
+ const x = b[0] - a[0];
162
+ const y = b[1] - a[1];
163
+ const z = b[2] - a[2];
164
+ const w = b[3] - a[3];
165
+ return Math.sqrt(x * x + y * y + z * z + w * w);
166
+ }
167
+ exports.distance = distance;
168
+ /**
169
+ * Calculates the squared euclidian distance between two vec4's
170
+ */
171
+ function squaredDistance(a, b) {
172
+ const x = b[0] - a[0];
173
+ const y = b[1] - a[1];
174
+ const z = b[2] - a[2];
175
+ const w = b[3] - a[3];
176
+ return x * x + y * y + z * z + w * w;
177
+ }
178
+ exports.squaredDistance = squaredDistance;
179
+ /**
180
+ * Calculates the length of a vec4
181
+ */
182
+ function length(a) {
183
+ const [x, y, z, w] = a;
184
+ return Math.sqrt(x * x + y * y + z * z + w * w);
185
+ }
186
+ exports.length = length;
187
+ /**
188
+ * Calculates the squared length of a vec4
189
+ */
190
+ function squaredLength(a) {
191
+ const [x, y, z, w] = a;
192
+ return x * x + y * y + z * z + w * w;
193
+ }
194
+ exports.squaredLength = squaredLength;
195
+ /**
196
+ * Negates the components of a vec4
197
+ */
198
+ function negate(a) {
199
+ return [-a[0], -a[1], -a[2], -a[3]];
200
+ }
201
+ exports.negate = negate;
202
+ /**
203
+ * Returns the inverse of the components of a vec4
204
+ */
205
+ function inverse(a) {
206
+ return [1 / a[0], 1 / a[1], 1 / a[2], 1 / a[3]];
207
+ }
208
+ exports.inverse = inverse;
209
+ /**
210
+ * Normalize a vec4
211
+ */
212
+ function normalize(a) {
213
+ const [x, y, z, w] = a;
214
+ const hyp = x * x + y * y + z * z + w * w;
215
+ const len = hyp === 0 ? 0 : 1 / Math.sqrt(hyp);
216
+ return [x * len, y * len, z * len, w * len];
217
+ }
218
+ exports.normalize = normalize;
219
+ /**
220
+ * Calculates the dot product of two vec4's
221
+ */
222
+ function dot(a, b) {
223
+ return a[0] * b[0] + a[1] * b[1] + a[2] * b[2] + a[3] * b[3];
224
+ }
225
+ exports.dot = dot;
226
+ /**
227
+ * Returns the cross-product of three vectors in a 4-dimensional space
228
+ */
229
+ function cross(u, v, w) {
230
+ const A = v[0] * w[1] - v[1] * w[0];
231
+ const B = v[0] * w[2] - v[2] * w[0];
232
+ const C = v[0] * w[3] - v[3] * w[0];
233
+ const D = v[1] * w[2] - v[2] * w[1];
234
+ const E = v[1] * w[3] - v[3] * w[1];
235
+ const F = v[2] * w[3] - v[3] * w[2];
236
+ const [G, H, I, J] = u;
237
+ return [
238
+ H * F - I * E + J * D,
239
+ -(G * F) + I * C - J * B,
240
+ G * E - H * C + J * A,
241
+ -(G * D) + H * B - I * A,
242
+ ];
243
+ }
244
+ exports.cross = cross;
245
+ /**
246
+ * Performs a linear interpolation between two vec4's
247
+ * @param t interpolation amount, in the range [0-1], between the two inputs
248
+ */
249
+ function lerp(a, b, t) {
250
+ const [ax, ay, az, aw] = a;
251
+ return [
252
+ ax + t * (b[0] - ax),
253
+ ay + t * (b[1] - ay),
254
+ az + t * (b[2] - az),
255
+ aw + t * (b[3] - aw),
256
+ ];
257
+ }
258
+ exports.lerp = lerp;
259
+ /**
260
+ * Transforms the vec4 with a mat4.
261
+ */
262
+ function transformMat4(a, m) {
263
+ const [x, y, z, w] = a;
264
+ return [
265
+ m[0] * x + m[4] * y + m[8] * z + m[12] * w,
266
+ m[1] * x + m[5] * y + m[9] * z + m[13] * w,
267
+ m[2] * x + m[6] * y + m[10] * z + m[14] * w,
268
+ m[3] * x + m[7] * y + m[11] * z + m[15] * w,
269
+ ];
270
+ }
271
+ exports.transformMat4 = transformMat4;
272
+ /**
273
+ * Transforms the vec4 with a quat
274
+ */
275
+ function transformQuat(a, q) {
276
+ const [x, y, z] = a;
277
+ const [qx, qy, qz, qw] = q;
278
+ // calculate quat * vec
279
+ const ix = qw * x + qy * z - qz * y;
280
+ const iy = qw * y + qz * x - qx * z;
281
+ const iz = qw * z + qx * y - qy * x;
282
+ const iw = -qx * x - qy * y - qz * z;
283
+ // calculate result * inverse quat
284
+ return [
285
+ ix * qw + iw * -qx + iy * -qz - iz * -qy,
286
+ iy * qw + iw * -qy + iz * -qx - ix * -qz,
287
+ iz * qw + iw * -qz + ix * -qy - iy * -qx,
288
+ a[3],
289
+ ];
290
+ }
291
+ exports.transformQuat = transformQuat;
292
+ /**
293
+ * Returns whether or not the vectors have exactly the same elements in the same position (when compared with ===)
294
+ */
295
+ function exactEquals(a, b) {
296
+ return a[0] === b[0] && a[1] === b[1] && a[2] === b[2] && a[3] === b[3];
297
+ }
298
+ exports.exactEquals = exactEquals;
299
+ /**
300
+ * Returns whether or not the vectors have approximately the same elements in the same position.
301
+ */
302
+ function equals(a, b) {
303
+ const [a0, a1, a2, a3] = a;
304
+ const [b0, b1, b2, b3] = b;
305
+ return (Math.abs(a0 - b0) <=
306
+ Common.EPSILON * Math.max(1, Math.abs(a0), Math.abs(b0)) &&
307
+ Math.abs(a1 - b1) <=
308
+ Common.EPSILON * Math.max(1, Math.abs(a1), Math.abs(b1)) &&
309
+ Math.abs(a2 - b2) <=
310
+ Common.EPSILON * Math.max(1, Math.abs(a2), Math.abs(b2)) &&
311
+ Math.abs(a3 - b3) <=
312
+ Common.EPSILON * Math.max(1, Math.abs(a3), Math.abs(b3)));
313
+ }
314
+ exports.equals = equals;
315
+ });
316
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vec4.js","sourceRoot":"","sources":["../src/vec4.ts"],"names":[],"mappings":"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"}