@chemistry/math 2.7.0 → 3.0.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.
- package/README.md +36 -33
- package/dist/index.d.ts +6 -5
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +6 -0
- package/dist/index.js.map +1 -0
- package/dist/matrix3x3.d.ts +39 -38
- package/dist/matrix3x3.d.ts.map +1 -0
- package/dist/matrix3x3.js +143 -0
- package/dist/matrix3x3.js.map +1 -0
- package/dist/matrix3x4.d.ts +46 -45
- package/dist/matrix3x4.d.ts.map +1 -0
- package/dist/matrix3x4.js +393 -0
- package/dist/matrix3x4.js.map +1 -0
- package/dist/quaternion.d.ts +29 -28
- package/dist/quaternion.d.ts.map +1 -0
- package/dist/quaternion.js +41 -0
- package/dist/quaternion.js.map +1 -0
- package/dist/transform3d.d.ts +71 -70
- package/dist/transform3d.d.ts.map +1 -0
- package/dist/transform3d.js +392 -0
- package/dist/transform3d.js.map +1 -0
- package/dist/vec2.d.ts +26 -25
- package/dist/vec2.d.ts.map +1 -0
- package/dist/vec2.js +59 -0
- package/dist/vec2.js.map +1 -0
- package/dist/vec3.d.ts +30 -29
- package/dist/vec3.d.ts.map +1 -0
- package/dist/vec3.js +71 -0
- package/dist/vec3.js.map +1 -0
- package/package.json +48 -37
- package/LICENSE.md +0 -22
- package/dist/math.js +0 -2
- package/dist/math.js.map +0 -1
- package/package-lock.json +0 -11
|
@@ -0,0 +1,393 @@
|
|
|
1
|
+
import { EPSILON } from '@chemistry/common';
|
|
2
|
+
import { Vec3 } from './vec3';
|
|
3
|
+
/**
|
|
4
|
+
* Simple Class to work with special type of matrix.
|
|
5
|
+
* | x1 x2 x3 x4 |
|
|
6
|
+
* | x5 x6 x7 x8 |
|
|
7
|
+
* | x8 x10 x11 x12|
|
|
8
|
+
* | 0 0 0 1 |
|
|
9
|
+
*/
|
|
10
|
+
export class Matrix3x4 {
|
|
11
|
+
static add(matrix1, matrix2) {
|
|
12
|
+
const m1 = matrix1.elements;
|
|
13
|
+
const m2 = matrix2.elements;
|
|
14
|
+
return new Matrix3x4([
|
|
15
|
+
m1[0] + m2[0],
|
|
16
|
+
m1[1] + m2[1],
|
|
17
|
+
m1[2] + m2[2],
|
|
18
|
+
m1[3] + m2[3],
|
|
19
|
+
m1[4] + m2[4],
|
|
20
|
+
m1[5] + m2[5],
|
|
21
|
+
m1[6] + m2[6],
|
|
22
|
+
m1[7] + m2[7],
|
|
23
|
+
m1[8] + m2[8],
|
|
24
|
+
m1[9] + m2[9],
|
|
25
|
+
m1[10] + m2[10],
|
|
26
|
+
m1[11] + m2[11],
|
|
27
|
+
]);
|
|
28
|
+
}
|
|
29
|
+
static sub(matrix1, matrix2) {
|
|
30
|
+
const m1 = matrix1.elements;
|
|
31
|
+
const m2 = matrix2.elements;
|
|
32
|
+
return new Matrix3x4([
|
|
33
|
+
m1[0] - m2[0],
|
|
34
|
+
m1[1] - m2[1],
|
|
35
|
+
m1[2] - m2[2],
|
|
36
|
+
m1[3] - m2[3],
|
|
37
|
+
m1[4] - m2[4],
|
|
38
|
+
m1[5] - m2[5],
|
|
39
|
+
m1[6] - m2[6],
|
|
40
|
+
m1[7] - m2[7],
|
|
41
|
+
m1[8] - m2[8],
|
|
42
|
+
m1[9] - m2[9],
|
|
43
|
+
m1[10] - m2[10],
|
|
44
|
+
m1[11] - m2[11],
|
|
45
|
+
]);
|
|
46
|
+
}
|
|
47
|
+
static inverse(matrix) {
|
|
48
|
+
const r = [];
|
|
49
|
+
let i;
|
|
50
|
+
const m = matrix.elements.slice(0, 12);
|
|
51
|
+
m[12] = 0;
|
|
52
|
+
m[13] = 0;
|
|
53
|
+
m[14] = 0;
|
|
54
|
+
m[15] = 1;
|
|
55
|
+
r[0] =
|
|
56
|
+
m[5] * m[10] * m[15] -
|
|
57
|
+
m[5] * m[14] * m[11] -
|
|
58
|
+
m[6] * m[9] * m[15] +
|
|
59
|
+
m[6] * m[13] * m[11] +
|
|
60
|
+
m[7] * m[9] * m[14] -
|
|
61
|
+
m[7] * m[13] * m[10];
|
|
62
|
+
r[1] =
|
|
63
|
+
-m[1] * m[10] * m[15] +
|
|
64
|
+
m[1] * m[14] * m[11] +
|
|
65
|
+
m[2] * m[9] * m[15] -
|
|
66
|
+
m[2] * m[13] * m[11] -
|
|
67
|
+
m[3] * m[9] * m[14] +
|
|
68
|
+
m[3] * m[13] * m[10];
|
|
69
|
+
r[2] =
|
|
70
|
+
m[1] * m[6] * m[15] -
|
|
71
|
+
m[1] * m[14] * m[7] -
|
|
72
|
+
m[2] * m[5] * m[15] +
|
|
73
|
+
m[2] * m[13] * m[7] +
|
|
74
|
+
m[3] * m[5] * m[14] -
|
|
75
|
+
m[3] * m[13] * m[6];
|
|
76
|
+
r[3] =
|
|
77
|
+
-m[1] * m[6] * m[11] +
|
|
78
|
+
m[1] * m[10] * m[7] +
|
|
79
|
+
m[2] * m[5] * m[11] -
|
|
80
|
+
m[2] * m[9] * m[7] -
|
|
81
|
+
m[3] * m[5] * m[10] +
|
|
82
|
+
m[3] * m[9] * m[6];
|
|
83
|
+
r[4] =
|
|
84
|
+
-m[4] * m[10] * m[15] +
|
|
85
|
+
m[4] * m[14] * m[11] +
|
|
86
|
+
m[6] * m[8] * m[15] -
|
|
87
|
+
m[6] * m[12] * m[11] -
|
|
88
|
+
m[7] * m[8] * m[14] +
|
|
89
|
+
m[7] * m[12] * m[10];
|
|
90
|
+
r[5] =
|
|
91
|
+
m[0] * m[10] * m[15] -
|
|
92
|
+
m[0] * m[14] * m[11] -
|
|
93
|
+
m[2] * m[8] * m[15] +
|
|
94
|
+
m[2] * m[12] * m[11] +
|
|
95
|
+
m[3] * m[8] * m[14] -
|
|
96
|
+
m[3] * m[12] * m[10];
|
|
97
|
+
r[6] =
|
|
98
|
+
-m[0] * m[6] * m[15] +
|
|
99
|
+
m[0] * m[14] * m[7] +
|
|
100
|
+
m[2] * m[4] * m[15] -
|
|
101
|
+
m[2] * m[12] * m[7] -
|
|
102
|
+
m[3] * m[4] * m[14] +
|
|
103
|
+
m[3] * m[12] * m[6];
|
|
104
|
+
r[7] =
|
|
105
|
+
m[0] * m[6] * m[11] -
|
|
106
|
+
m[0] * m[10] * m[7] -
|
|
107
|
+
m[2] * m[4] * m[11] +
|
|
108
|
+
m[2] * m[8] * m[7] +
|
|
109
|
+
m[3] * m[4] * m[10] -
|
|
110
|
+
m[3] * m[8] * m[6];
|
|
111
|
+
r[8] =
|
|
112
|
+
m[4] * m[9] * m[15] -
|
|
113
|
+
m[4] * m[13] * m[11] -
|
|
114
|
+
m[5] * m[8] * m[15] +
|
|
115
|
+
m[5] * m[12] * m[11] +
|
|
116
|
+
m[7] * m[8] * m[13] -
|
|
117
|
+
m[7] * m[12] * m[9];
|
|
118
|
+
r[9] =
|
|
119
|
+
-m[0] * m[9] * m[15] +
|
|
120
|
+
m[0] * m[13] * m[11] +
|
|
121
|
+
m[1] * m[8] * m[15] -
|
|
122
|
+
m[1] * m[12] * m[11] -
|
|
123
|
+
m[3] * m[8] * m[13] +
|
|
124
|
+
m[3] * m[12] * m[9];
|
|
125
|
+
r[10] =
|
|
126
|
+
m[0] * m[5] * m[15] -
|
|
127
|
+
m[0] * m[13] * m[7] -
|
|
128
|
+
m[1] * m[4] * m[15] +
|
|
129
|
+
m[1] * m[12] * m[7] +
|
|
130
|
+
m[3] * m[4] * m[13] -
|
|
131
|
+
m[3] * m[12] * m[5];
|
|
132
|
+
r[11] =
|
|
133
|
+
-m[0] * m[5] * m[11] +
|
|
134
|
+
m[0] * m[9] * m[7] +
|
|
135
|
+
m[1] * m[4] * m[11] -
|
|
136
|
+
m[1] * m[8] * m[7] -
|
|
137
|
+
m[3] * m[4] * m[9] +
|
|
138
|
+
m[3] * m[8] * m[5];
|
|
139
|
+
r[12] =
|
|
140
|
+
-m[4] * m[9] * m[14] +
|
|
141
|
+
m[4] * m[13] * m[10] +
|
|
142
|
+
m[5] * m[8] * m[14] -
|
|
143
|
+
m[5] * m[12] * m[10] -
|
|
144
|
+
m[6] * m[8] * m[13] +
|
|
145
|
+
m[6] * m[12] * m[9];
|
|
146
|
+
r[13] =
|
|
147
|
+
m[0] * m[9] * m[14] -
|
|
148
|
+
m[0] * m[13] * m[10] -
|
|
149
|
+
m[1] * m[8] * m[14] +
|
|
150
|
+
m[1] * m[12] * m[10] +
|
|
151
|
+
m[2] * m[8] * m[13] -
|
|
152
|
+
m[2] * m[12] * m[9];
|
|
153
|
+
r[14] =
|
|
154
|
+
-m[0] * m[5] * m[14] +
|
|
155
|
+
m[0] * m[13] * m[6] +
|
|
156
|
+
m[1] * m[4] * m[14] -
|
|
157
|
+
m[1] * m[12] * m[6] -
|
|
158
|
+
m[2] * m[4] * m[13] +
|
|
159
|
+
m[2] * m[12] * m[5];
|
|
160
|
+
r[15] =
|
|
161
|
+
m[0] * m[5] * m[10] -
|
|
162
|
+
m[0] * m[9] * m[6] -
|
|
163
|
+
m[1] * m[4] * m[10] +
|
|
164
|
+
m[1] * m[8] * m[6] +
|
|
165
|
+
m[2] * m[4] * m[9] -
|
|
166
|
+
m[2] * m[8] * m[5];
|
|
167
|
+
const det = m[0] * r[0] + m[1] * r[4] + m[2] * r[8] + m[3] * r[12];
|
|
168
|
+
for (i = 0; i < 16; i++) {
|
|
169
|
+
r[i] /= det;
|
|
170
|
+
}
|
|
171
|
+
return new Matrix3x4(r.slice(0, 12));
|
|
172
|
+
}
|
|
173
|
+
static isE(matrix) {
|
|
174
|
+
return (Math.abs(matrix.elements[0] - 1) < EPSILON &&
|
|
175
|
+
Math.abs(matrix.elements[1] - 0) < EPSILON &&
|
|
176
|
+
Math.abs(matrix.elements[2] - 0) < EPSILON &&
|
|
177
|
+
Math.abs(matrix.elements[3] - 0) < EPSILON &&
|
|
178
|
+
Math.abs(matrix.elements[4] - 0) < EPSILON &&
|
|
179
|
+
Math.abs(matrix.elements[5] - 1) < EPSILON &&
|
|
180
|
+
Math.abs(matrix.elements[6] - 0) < EPSILON &&
|
|
181
|
+
Math.abs(matrix.elements[7] - 0) < EPSILON &&
|
|
182
|
+
Math.abs(matrix.elements[8] - 0) < EPSILON &&
|
|
183
|
+
Math.abs(matrix.elements[9] - 0) < EPSILON &&
|
|
184
|
+
Math.abs(matrix.elements[10] - 1) < EPSILON &&
|
|
185
|
+
Math.abs(matrix.elements[11] - 0) < EPSILON);
|
|
186
|
+
}
|
|
187
|
+
static equals(matrix1, matrix2) {
|
|
188
|
+
return (Math.abs(matrix1.elements[0] - matrix2.elements[0]) < EPSILON &&
|
|
189
|
+
Math.abs(matrix1.elements[1] - matrix2.elements[1]) < EPSILON &&
|
|
190
|
+
Math.abs(matrix1.elements[2] - matrix2.elements[2]) < EPSILON &&
|
|
191
|
+
Math.abs(matrix1.elements[3] - matrix2.elements[3]) < EPSILON &&
|
|
192
|
+
Math.abs(matrix1.elements[4] - matrix2.elements[4]) < EPSILON &&
|
|
193
|
+
Math.abs(matrix1.elements[5] - matrix2.elements[5]) < EPSILON &&
|
|
194
|
+
Math.abs(matrix1.elements[6] - matrix2.elements[6]) < EPSILON &&
|
|
195
|
+
Math.abs(matrix1.elements[7] - matrix2.elements[7]) < EPSILON &&
|
|
196
|
+
Math.abs(matrix1.elements[8] - matrix2.elements[8]) < EPSILON &&
|
|
197
|
+
Math.abs(matrix1.elements[9] - matrix2.elements[9]) < EPSILON &&
|
|
198
|
+
Math.abs(matrix1.elements[10] - matrix2.elements[10]) < EPSILON &&
|
|
199
|
+
Math.abs(matrix1.elements[11] - matrix2.elements[11]) < EPSILON);
|
|
200
|
+
}
|
|
201
|
+
constructor(elements) {
|
|
202
|
+
this.elements =
|
|
203
|
+
elements?.length === 12 ? elements.slice(0) : [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0];
|
|
204
|
+
}
|
|
205
|
+
/**
|
|
206
|
+
* Set value to specified element of the matrix
|
|
207
|
+
*/
|
|
208
|
+
set(i, j, val) {
|
|
209
|
+
if (i > 3 || i < 0 || j > 4 || j < 0) {
|
|
210
|
+
throw new Error('Wrong coefficients');
|
|
211
|
+
}
|
|
212
|
+
this.elements[i * 4 + j] = val;
|
|
213
|
+
}
|
|
214
|
+
/**
|
|
215
|
+
* return specified element of the matrix
|
|
216
|
+
* @param {Number} i row
|
|
217
|
+
* @param {Number} j column
|
|
218
|
+
* @return {Number}
|
|
219
|
+
*/
|
|
220
|
+
get(i, j) {
|
|
221
|
+
if (i > 3 || i < 0 || j > 4 || j < 0) {
|
|
222
|
+
throw new Error('Incorrect coeficients');
|
|
223
|
+
}
|
|
224
|
+
return this.elements[i * 4 + j];
|
|
225
|
+
}
|
|
226
|
+
add(matrix) {
|
|
227
|
+
return Matrix3x4.add(this, matrix);
|
|
228
|
+
}
|
|
229
|
+
sub(matrix) {
|
|
230
|
+
return Matrix3x4.sub(this, matrix);
|
|
231
|
+
}
|
|
232
|
+
translate(v) {
|
|
233
|
+
const elements = this.elements.slice(0);
|
|
234
|
+
elements[3] = elements[3] + v.x;
|
|
235
|
+
elements[7] = elements[7] + v.y;
|
|
236
|
+
elements[11] = elements[11] + v.z;
|
|
237
|
+
return new Matrix3x4(elements);
|
|
238
|
+
}
|
|
239
|
+
scale(mult) {
|
|
240
|
+
return new Matrix3x4([
|
|
241
|
+
this.elements[0] * mult,
|
|
242
|
+
this.elements[1] * mult,
|
|
243
|
+
this.elements[2] * mult,
|
|
244
|
+
this.elements[3] * mult,
|
|
245
|
+
this.elements[4] * mult,
|
|
246
|
+
this.elements[5] * mult,
|
|
247
|
+
this.elements[6] * mult,
|
|
248
|
+
this.elements[7] * mult,
|
|
249
|
+
this.elements[8] * mult,
|
|
250
|
+
this.elements[9] * mult,
|
|
251
|
+
this.elements[10] * mult,
|
|
252
|
+
this.elements[11] * mult,
|
|
253
|
+
]);
|
|
254
|
+
}
|
|
255
|
+
project(mult) {
|
|
256
|
+
return new Vec3(this.elements[0] * mult.x +
|
|
257
|
+
this.elements[1] * mult.y +
|
|
258
|
+
this.elements[2] * mult.z +
|
|
259
|
+
this.elements[3], this.elements[4] * mult.x +
|
|
260
|
+
this.elements[5] * mult.y +
|
|
261
|
+
this.elements[6] * mult.z +
|
|
262
|
+
this.elements[7], this.elements[8] * mult.x +
|
|
263
|
+
this.elements[9] * mult.y +
|
|
264
|
+
this.elements[10] * mult.z +
|
|
265
|
+
this.elements[11]);
|
|
266
|
+
}
|
|
267
|
+
multiply(mult) {
|
|
268
|
+
const elements = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0];
|
|
269
|
+
elements[0] =
|
|
270
|
+
mult.elements[0] * this.elements[0] +
|
|
271
|
+
mult.elements[4] * this.elements[1] +
|
|
272
|
+
mult.elements[8] * this.elements[2];
|
|
273
|
+
elements[1] =
|
|
274
|
+
mult.elements[1] * this.elements[0] +
|
|
275
|
+
mult.elements[5] * this.elements[1] +
|
|
276
|
+
mult.elements[9] * this.elements[2];
|
|
277
|
+
elements[2] =
|
|
278
|
+
mult.elements[2] * this.elements[0] +
|
|
279
|
+
mult.elements[6] * this.elements[1] +
|
|
280
|
+
mult.elements[10] * this.elements[2];
|
|
281
|
+
elements[3] =
|
|
282
|
+
mult.elements[3] * this.elements[0] +
|
|
283
|
+
mult.elements[7] * this.elements[1] +
|
|
284
|
+
mult.elements[11] * this.elements[2] +
|
|
285
|
+
this.elements[3];
|
|
286
|
+
elements[4] =
|
|
287
|
+
mult.elements[0] * this.elements[4] +
|
|
288
|
+
mult.elements[4] * this.elements[5] +
|
|
289
|
+
mult.elements[8] * this.elements[6];
|
|
290
|
+
elements[5] =
|
|
291
|
+
mult.elements[1] * this.elements[4] +
|
|
292
|
+
mult.elements[5] * this.elements[5] +
|
|
293
|
+
mult.elements[9] * this.elements[6];
|
|
294
|
+
elements[6] =
|
|
295
|
+
mult.elements[2] * this.elements[4] +
|
|
296
|
+
mult.elements[6] * this.elements[5] +
|
|
297
|
+
mult.elements[10] * this.elements[6];
|
|
298
|
+
elements[7] =
|
|
299
|
+
mult.elements[3] * this.elements[4] +
|
|
300
|
+
mult.elements[7] * this.elements[5] +
|
|
301
|
+
mult.elements[11] * this.elements[6] +
|
|
302
|
+
this.elements[7];
|
|
303
|
+
elements[8] =
|
|
304
|
+
mult.elements[0] * this.elements[8] +
|
|
305
|
+
mult.elements[4] * this.elements[9] +
|
|
306
|
+
mult.elements[8] * this.elements[10];
|
|
307
|
+
elements[9] =
|
|
308
|
+
mult.elements[1] * this.elements[8] +
|
|
309
|
+
mult.elements[5] * this.elements[9] +
|
|
310
|
+
mult.elements[9] * this.elements[10];
|
|
311
|
+
elements[10] =
|
|
312
|
+
mult.elements[2] * this.elements[8] +
|
|
313
|
+
mult.elements[6] * this.elements[9] +
|
|
314
|
+
mult.elements[10] * this.elements[10];
|
|
315
|
+
elements[11] =
|
|
316
|
+
mult.elements[3] * this.elements[8] +
|
|
317
|
+
mult.elements[7] * this.elements[9] +
|
|
318
|
+
mult.elements[11] * this.elements[10] +
|
|
319
|
+
this.elements[11];
|
|
320
|
+
return new Matrix3x4(elements);
|
|
321
|
+
}
|
|
322
|
+
inverse() {
|
|
323
|
+
return Matrix3x4.inverse(this);
|
|
324
|
+
}
|
|
325
|
+
isE() {
|
|
326
|
+
return Matrix3x4.isE(this);
|
|
327
|
+
}
|
|
328
|
+
equals(matrix) {
|
|
329
|
+
return Matrix3x4.equals(this, matrix);
|
|
330
|
+
}
|
|
331
|
+
clone() {
|
|
332
|
+
return new Matrix3x4(this.elements);
|
|
333
|
+
}
|
|
334
|
+
toString() {
|
|
335
|
+
return '(' + this.elements.slice(0, 12).map((element) => element.toFixed(3)) + ')';
|
|
336
|
+
}
|
|
337
|
+
/**
|
|
338
|
+
* Return transformation matrix as symetry code (common in Crystallography)
|
|
339
|
+
* e.g. 1-x,1-y,1-z
|
|
340
|
+
*/
|
|
341
|
+
toSymetryCode() {
|
|
342
|
+
function formatSymNumber(num) {
|
|
343
|
+
return (Math.round(num * 1000) / 1000).toString();
|
|
344
|
+
}
|
|
345
|
+
function closeToOne(num) {
|
|
346
|
+
return Math.abs(num - 1) < 0.001;
|
|
347
|
+
}
|
|
348
|
+
function codePart1(x, y, z, l) {
|
|
349
|
+
const arr = [];
|
|
350
|
+
if (x !== 0) {
|
|
351
|
+
if (closeToOne(Math.abs(x))) {
|
|
352
|
+
arr.push(x > 0 ? 'x' : '-x');
|
|
353
|
+
}
|
|
354
|
+
else {
|
|
355
|
+
arr.push(formatSymNumber(x) + 'x');
|
|
356
|
+
}
|
|
357
|
+
}
|
|
358
|
+
if (y !== 0) {
|
|
359
|
+
if (closeToOne(Math.abs(y))) {
|
|
360
|
+
arr.push(y > 0 ? 'y' : '-y');
|
|
361
|
+
}
|
|
362
|
+
else {
|
|
363
|
+
arr.push(formatSymNumber(y) + 'y');
|
|
364
|
+
}
|
|
365
|
+
}
|
|
366
|
+
if (z !== 0) {
|
|
367
|
+
if (closeToOne(Math.abs(z))) {
|
|
368
|
+
arr.push(z > 0 ? 'z' : '-z');
|
|
369
|
+
}
|
|
370
|
+
else {
|
|
371
|
+
arr.push(formatSymNumber(z) + 'z');
|
|
372
|
+
}
|
|
373
|
+
}
|
|
374
|
+
if (l !== 0) {
|
|
375
|
+
arr.push(formatSymNumber(l));
|
|
376
|
+
}
|
|
377
|
+
return arr.reduce((curr, next) => {
|
|
378
|
+
if (next?.startsWith('-')) {
|
|
379
|
+
return curr + next;
|
|
380
|
+
}
|
|
381
|
+
if (curr === '') {
|
|
382
|
+
return next;
|
|
383
|
+
}
|
|
384
|
+
return curr + '+' + next;
|
|
385
|
+
}, '');
|
|
386
|
+
}
|
|
387
|
+
const sx = codePart1(this.elements[0], this.elements[1], this.elements[2], this.elements[3]);
|
|
388
|
+
const sy = codePart1(this.elements[4], this.elements[5], this.elements[6], this.elements[7]);
|
|
389
|
+
const sz = codePart1(this.elements[8], this.elements[9], this.elements[10], this.elements[11]);
|
|
390
|
+
return sx + ',' + sy + ',' + sz;
|
|
391
|
+
}
|
|
392
|
+
}
|
|
393
|
+
//# sourceMappingURL=matrix3x4.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"matrix3x4.js","sourceRoot":"","sources":["../src/matrix3x4.ts"],"names":[],"mappings":"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gBACnB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;QAEvB,CAAC,CAAC,CAAC,CAAC;YACF,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACrB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACpB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACnB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACpB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACnB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;QAEvB,CAAC,CAAC,CAAC,CAAC;YACF,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACnB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;gBACnB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACnB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;gBACnB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACnB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QAEtB,CAAC,CAAC,CAAC,CAAC;YACF,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACpB,CAAC,CAAC,CAAC,CAA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CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACnB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACpB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACnB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACpB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACnB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QAEtB,CAAC,CAAC,CAAC,CAAC;YACF,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACpB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACpB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACnB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACpB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACnB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QAEtB,CAAC,CAAC,EAAE,CAAC;YACH,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACnB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;gBACnB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACnB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;gBACnB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACnB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QAEtB,CAAC,CAAC,EAAE,CAAC;YACH,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACpB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;gBAClB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACnB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;gBAClB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;gBAClB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QAErB,CAAC,CAAC,EAAE,CAAC;YACH,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACpB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACpB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACnB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACpB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACnB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QAEtB,CAAC,CAAC,EAAE,CAAC;YACH,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACnB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACpB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACnB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACpB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACnB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QAEtB,CAAC,CAAC,EAAE,CAAC;YACH,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACpB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;gBACnB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACnB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;gBACnB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACnB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QAEtB,CAAC,CAAC,EAAE,CAAC;YACH,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACnB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;gBAClB,CAAC,CAAC,CAAC,CAAC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"}
|
package/dist/quaternion.d.ts
CHANGED
|
@@ -1,28 +1,29 @@
|
|
|
1
|
-
import { Vec3 } from
|
|
2
|
-
/**
|
|
3
|
-
* Simple Class to work with Quaternion
|
|
4
|
-
*/
|
|
5
|
-
export declare class Quaternion {
|
|
6
|
-
/**
|
|
7
|
-
* Get Quaternion from Axis angle
|
|
8
|
-
*/
|
|
9
|
-
static fromAxisAngle(axis: Vec3, angle: number): Quaternion;
|
|
10
|
-
protected data: number[];
|
|
11
|
-
constructor(x: number, y: number, z: number, w: number);
|
|
12
|
-
/**
|
|
13
|
-
* X Component
|
|
14
|
-
*/
|
|
15
|
-
X(): number;
|
|
16
|
-
/**
|
|
17
|
-
* Y Component
|
|
18
|
-
*/
|
|
19
|
-
Y(): number;
|
|
20
|
-
/**
|
|
21
|
-
* Z Component
|
|
22
|
-
*/
|
|
23
|
-
Z(): number;
|
|
24
|
-
/**
|
|
25
|
-
* W Component
|
|
26
|
-
*/
|
|
27
|
-
W(): number;
|
|
28
|
-
}
|
|
1
|
+
import { Vec3 } from './vec3';
|
|
2
|
+
/**
|
|
3
|
+
* Simple Class to work with Quaternion
|
|
4
|
+
*/
|
|
5
|
+
export declare class Quaternion {
|
|
6
|
+
/**
|
|
7
|
+
* Get Quaternion from Axis angle
|
|
8
|
+
*/
|
|
9
|
+
static fromAxisAngle(axis: Vec3, angle: number): Quaternion;
|
|
10
|
+
protected data: number[];
|
|
11
|
+
constructor(x: number, y: number, z: number, w: number);
|
|
12
|
+
/**
|
|
13
|
+
* X Component
|
|
14
|
+
*/
|
|
15
|
+
X(): number;
|
|
16
|
+
/**
|
|
17
|
+
* Y Component
|
|
18
|
+
*/
|
|
19
|
+
Y(): number;
|
|
20
|
+
/**
|
|
21
|
+
* Z Component
|
|
22
|
+
*/
|
|
23
|
+
Z(): number;
|
|
24
|
+
/**
|
|
25
|
+
* W Component
|
|
26
|
+
*/
|
|
27
|
+
W(): number;
|
|
28
|
+
}
|
|
29
|
+
//# sourceMappingURL=quaternion.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"quaternion.d.ts","sourceRoot":"","sources":["../src/quaternion.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAC9B;;GAEG;AACH,qBAAa,UAAU;IACrB;;OAEG;WACW,aAAa,CAAC,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,GAAG,UAAU;IAMlE,SAAS,CAAC,IAAI,EAAE,MAAM,EAAE,CAAC;gBAEb,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM;IAItD;;OAEG;IACI,CAAC,IAAI,MAAM;IAIlB;;OAEG;IACI,CAAC,IAAI,MAAM;IAIlB;;OAEG;IACI,CAAC,IAAI,MAAM;IAIlB;;OAEG;IACI,CAAC,IAAI,MAAM;CAGnB"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Simple Class to work with Quaternion
|
|
3
|
+
*/
|
|
4
|
+
export class Quaternion {
|
|
5
|
+
/**
|
|
6
|
+
* Get Quaternion from Axis angle
|
|
7
|
+
*/
|
|
8
|
+
static fromAxisAngle(axis, angle) {
|
|
9
|
+
const f = angle * 0.5;
|
|
10
|
+
const pt = axis.scale(Math.sin(f));
|
|
11
|
+
return new Quaternion(pt.x, pt.y, pt.z, Math.cos(f));
|
|
12
|
+
}
|
|
13
|
+
constructor(x, y, z, w) {
|
|
14
|
+
this.data = [x, y, z, w];
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* X Component
|
|
18
|
+
*/
|
|
19
|
+
X() {
|
|
20
|
+
return this.data[0];
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* Y Component
|
|
24
|
+
*/
|
|
25
|
+
Y() {
|
|
26
|
+
return this.data[1];
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Z Component
|
|
30
|
+
*/
|
|
31
|
+
Z() {
|
|
32
|
+
return this.data[2];
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* W Component
|
|
36
|
+
*/
|
|
37
|
+
W() {
|
|
38
|
+
return this.data[3];
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
//# sourceMappingURL=quaternion.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"quaternion.js","sourceRoot":"","sources":["../src/quaternion.ts"],"names":[],"mappings":"AACA;;GAEG;AACH,MAAM,OAAO,UAAU;IACrB;;OAEG;IACI,MAAM,CAAC,aAAa,CAAC,IAAU,EAAE,KAAa;QACnD,MAAM,CAAC,GAAG,KAAK,GAAG,GAAG,CAAC;QACtB,MAAM,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QACnC,OAAO,IAAI,UAAU,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IACvD,CAAC;IAID,YAAY,CAAS,EAAE,CAAS,EAAE,CAAS,EAAE,CAAS;QACpD,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;IAC3B,CAAC;IAED;;OAEG;IACI,CAAC;QACN,OAAO,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACtB,CAAC;IAED;;OAEG;IACI,CAAC;QACN,OAAO,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACtB,CAAC;IAED;;OAEG;IACI,CAAC;QACN,OAAO,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACtB,CAAC;IAED;;OAEG;IACI,CAAC;QACN,OAAO,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACtB,CAAC;CACF"}
|