@chemistry/math 2.9.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 +12 -9
- 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 +3 -2
- 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 +3 -2
- 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 +2 -1
- 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 +4 -3
- 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 +2 -1
- 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 +2 -1
- 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 -13
package/README.md
CHANGED
|
@@ -1,27 +1,29 @@
|
|
|
1
1
|
# @chemistry/math
|
|
2
|
+
|
|
2
3
|
[](https://badge.fury.io/js/%40chemistry%2Fmath)
|
|
3
|
-
[](https://travis-ci.org/chemistry/chemical-libraries)
|
|
4
|
-
[](https://codecov.io/gh/chemistry/chemical-libraries)
|
|
5
4
|
[](https://opensource.org/licenses/MIT)
|
|
6
5
|
|
|
7
6
|
Simple linear algebra Math library to support [chemistry js project](http://vreshch.com/chemistry-js.html)
|
|
8
7
|
|
|
9
8
|
## Install
|
|
9
|
+
|
|
10
10
|
```bash
|
|
11
11
|
npm install @chemistry/math
|
|
12
12
|
```
|
|
13
13
|
|
|
14
14
|
## Include following clases:
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
15
|
+
|
|
16
|
+
- Vec3
|
|
17
|
+
- Matrix3x3
|
|
18
|
+
- Matrix3x4
|
|
19
|
+
- Transform3d
|
|
20
|
+
- Quaternion
|
|
20
21
|
|
|
21
22
|
## Getting started:
|
|
23
|
+
|
|
22
24
|
```javascript
|
|
23
25
|
import { V, ChemElementData } from '@chemistry/math';
|
|
24
|
-
const matrix = new Matrix3x3([1, 0, 0,
|
|
26
|
+
const matrix = new Matrix3x3([1, 0, 0, 0, 2, 0, 0, 0, 3]);
|
|
25
27
|
const vector = new Vec3(2, 3, 1);
|
|
26
28
|
|
|
27
29
|
const res = matrix.project(vector);
|
|
@@ -30,4 +32,5 @@ console.log(res);
|
|
|
30
32
|
```
|
|
31
33
|
|
|
32
34
|
## Commands:
|
|
33
|
-
|
|
35
|
+
|
|
36
|
+
- Build project: `npm run build`
|
package/dist/index.d.ts
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
|
-
export * from
|
|
2
|
-
export * from
|
|
3
|
-
export * from
|
|
4
|
-
export * from
|
|
5
|
-
export * from
|
|
1
|
+
export * from './matrix3x3';
|
|
2
|
+
export * from './matrix3x4';
|
|
3
|
+
export * from './transform3d';
|
|
4
|
+
export * from './vec3';
|
|
5
|
+
export * from './vec2';
|
|
6
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,aAAa,CAAC;AAC5B,cAAc,aAAa,CAAC;AAC5B,cAAc,eAAe,CAAC;AAC9B,cAAc,QAAQ,CAAC;AACvB,cAAc,QAAQ,CAAC"}
|
package/dist/index.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,aAAa,CAAC;AAC5B,cAAc,aAAa,CAAC;AAC5B,cAAc,eAAe,CAAC;AAC9B,cAAc,QAAQ,CAAC;AACvB,cAAc,QAAQ,CAAC"}
|
package/dist/matrix3x3.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { ICloneable, IEquatable } from
|
|
2
|
-
import { Vec3 } from
|
|
1
|
+
import { ICloneable, IEquatable } from '@chemistry/common';
|
|
2
|
+
import { Vec3 } from './vec3';
|
|
3
3
|
export declare class Matrix3x3 implements ICloneable<Matrix3x3>, IEquatable<Matrix3x3> {
|
|
4
4
|
static equals(m1: Matrix3x3, m2: Matrix3x3): boolean;
|
|
5
5
|
static inverse(matrix: Matrix3x3): Matrix3x3;
|
|
@@ -36,3 +36,4 @@ export declare class Matrix3x3 implements ICloneable<Matrix3x3>, IEquatable<Matr
|
|
|
36
36
|
*/
|
|
37
37
|
toString(): string;
|
|
38
38
|
}
|
|
39
|
+
//# sourceMappingURL=matrix3x3.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"matrix3x3.d.ts","sourceRoot":"","sources":["../src/matrix3x3.ts"],"names":[],"mappings":"AAAA,OAAO,EAAW,UAAU,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AACpE,OAAO,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAE9B,qBAAa,SAAU,YAAW,UAAU,CAAC,SAAS,CAAC,EAAE,UAAU,CAAC,SAAS,CAAC;WAC9D,MAAM,CAAC,EAAE,EAAE,SAAS,EAAE,EAAE,EAAE,SAAS,GAAG,OAAO;WAc7C,OAAO,CAAC,MAAM,EAAE,SAAS,GAAG,SAAS;IAsBnD,SAAS,CAAC,QAAQ,EAAE,MAAM,EAAE,CAAC;gBAEjB,QAAQ,CAAC,EAAE,MAAM,EAAE;IAI/B;;OAEG;IACI,GAAG,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM;IAO5C;;OAEG;IACI,GAAG,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,GAAG,MAAM;IAOjC,KAAK,CAAC,IAAI,EAAE,MAAM,GAAG,SAAS;IAc9B,OAAO,CAAC,IAAI,EAAE,IAAI,GAAG,IAAI;IAQhC;;OAEG;IACI,QAAQ,CAAC,IAAI,EAAE,SAAS,GAAG,SAAS;IAgC3C;;OAEG;IACI,WAAW,IAAI,MAAM;IAQ5B;;OAEG;IACI,KAAK,IAAI,SAAS;IAIzB;;OAEG;IACI,MAAM,CAAC,MAAM,EAAE,SAAS,GAAG,OAAO;IAIzC;;OAEG;IACI,QAAQ,IAAI,MAAM;CAiB1B"}
|
|
@@ -0,0 +1,143 @@
|
|
|
1
|
+
import { EPSILON } from '@chemistry/common';
|
|
2
|
+
import { Vec3 } from './vec3';
|
|
3
|
+
export class Matrix3x3 {
|
|
4
|
+
static equals(m1, m2) {
|
|
5
|
+
return (Math.abs(m1.elements[0] - m2.elements[0]) < EPSILON &&
|
|
6
|
+
Math.abs(m1.elements[1] - m2.elements[1]) < EPSILON &&
|
|
7
|
+
Math.abs(m1.elements[2] - m2.elements[2]) < EPSILON &&
|
|
8
|
+
Math.abs(m1.elements[3] - m2.elements[3]) < EPSILON &&
|
|
9
|
+
Math.abs(m1.elements[4] - m2.elements[4]) < EPSILON &&
|
|
10
|
+
Math.abs(m1.elements[5] - m2.elements[5]) < EPSILON &&
|
|
11
|
+
Math.abs(m1.elements[6] - m2.elements[6]) < EPSILON &&
|
|
12
|
+
Math.abs(m1.elements[7] - m2.elements[7]) < EPSILON &&
|
|
13
|
+
Math.abs(m1.elements[8] - m2.elements[8]) < EPSILON);
|
|
14
|
+
}
|
|
15
|
+
static inverse(matrix) {
|
|
16
|
+
const d = matrix.determinant();
|
|
17
|
+
if (d === 0) {
|
|
18
|
+
throw new Error('Matrix not invertable');
|
|
19
|
+
}
|
|
20
|
+
return new Matrix3x3([
|
|
21
|
+
(matrix.get(1, 1) * matrix.get(2, 2) - matrix.get(1, 2) * matrix.get(2, 1)) / d,
|
|
22
|
+
(-matrix.get(0, 1) * matrix.get(2, 2) + matrix.get(0, 2) * matrix.get(2, 1)) / d,
|
|
23
|
+
(matrix.get(0, 1) * matrix.get(1, 2) - matrix.get(0, 2) * matrix.get(1, 1)) / d,
|
|
24
|
+
(-matrix.get(1, 0) * matrix.get(2, 2) + matrix.get(1, 2) * matrix.get(2, 0)) / d,
|
|
25
|
+
(matrix.get(0, 0) * matrix.get(2, 2) - matrix.get(0, 2) * matrix.get(2, 0)) / d,
|
|
26
|
+
(-matrix.get(0, 0) * matrix.get(1, 2) + matrix.get(0, 2) * matrix.get(1, 0)) / d,
|
|
27
|
+
(matrix.get(1, 0) * matrix.get(2, 1) - matrix.get(1, 1) * matrix.get(2, 0)) / d,
|
|
28
|
+
(-matrix.get(0, 0) * matrix.get(2, 1) + matrix.get(0, 1) * matrix.get(2, 0)) / d,
|
|
29
|
+
(matrix.get(0, 0) * matrix.get(1, 1) - matrix.get(0, 1) * matrix.get(1, 0)) / d,
|
|
30
|
+
]);
|
|
31
|
+
}
|
|
32
|
+
constructor(elements) {
|
|
33
|
+
this.elements = elements?.length === 9 ? elements.slice(0) : [1, 0, 0, 0, 1, 0, 0, 0, 1];
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* Set value to specified element of the matrix
|
|
37
|
+
*/
|
|
38
|
+
set(i, j, val) {
|
|
39
|
+
if (i > 3 || i < 0 || j > 3 || j < 0) {
|
|
40
|
+
throw new Error('Wrong coefficients');
|
|
41
|
+
}
|
|
42
|
+
this.elements[i * 3 + j] = val;
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* return specified element of the matrix
|
|
46
|
+
*/
|
|
47
|
+
get(i, j) {
|
|
48
|
+
if (i > 3 || i < 0 || j > 3 || j < 0) {
|
|
49
|
+
throw new Error('Wrong coefficients');
|
|
50
|
+
}
|
|
51
|
+
return this.elements[i * 3 + j];
|
|
52
|
+
}
|
|
53
|
+
scale(mult) {
|
|
54
|
+
return new Matrix3x3([
|
|
55
|
+
this.elements[0] * mult,
|
|
56
|
+
this.elements[1] * mult,
|
|
57
|
+
this.elements[2] * mult,
|
|
58
|
+
this.elements[3] * mult,
|
|
59
|
+
this.elements[4] * mult,
|
|
60
|
+
this.elements[5] * mult,
|
|
61
|
+
this.elements[6] * mult,
|
|
62
|
+
this.elements[7] * mult,
|
|
63
|
+
this.elements[8] * mult,
|
|
64
|
+
]);
|
|
65
|
+
}
|
|
66
|
+
project(mult) {
|
|
67
|
+
return new Vec3(this.elements[0] * mult.x + this.elements[1] * mult.y + this.elements[2] * mult.z, this.elements[3] * mult.x + this.elements[4] * mult.y + this.elements[5] * mult.z, this.elements[6] * mult.x + this.elements[7] * mult.y + this.elements[8] * mult.z);
|
|
68
|
+
}
|
|
69
|
+
/**
|
|
70
|
+
* Returns matrix multiplication result to scalar, vector or another matrix
|
|
71
|
+
*/
|
|
72
|
+
multiply(mult) {
|
|
73
|
+
return new Matrix3x3([
|
|
74
|
+
this.elements[0] * mult.elements[0] +
|
|
75
|
+
this.elements[3] * mult.elements[1] +
|
|
76
|
+
this.elements[6] * mult.elements[2],
|
|
77
|
+
this.elements[1] * mult.elements[0] +
|
|
78
|
+
this.elements[4] * mult.elements[1] +
|
|
79
|
+
this.elements[7] * mult.elements[2],
|
|
80
|
+
this.elements[2] * mult.elements[0] +
|
|
81
|
+
this.elements[5] * mult.elements[1] +
|
|
82
|
+
this.elements[8] * mult.elements[2],
|
|
83
|
+
this.elements[0] * mult.elements[3] +
|
|
84
|
+
this.elements[3] * mult.elements[4] +
|
|
85
|
+
this.elements[6] * mult.elements[5],
|
|
86
|
+
this.elements[1] * mult.elements[3] +
|
|
87
|
+
this.elements[4] * mult.elements[4] +
|
|
88
|
+
this.elements[7] * mult.elements[5],
|
|
89
|
+
this.elements[2] * mult.elements[3] +
|
|
90
|
+
this.elements[5] * mult.elements[4] +
|
|
91
|
+
this.elements[8] * mult.elements[5],
|
|
92
|
+
this.elements[0] * mult.elements[6] +
|
|
93
|
+
this.elements[3] * mult.elements[7] +
|
|
94
|
+
this.elements[6] * mult.elements[8],
|
|
95
|
+
this.elements[1] * mult.elements[6] +
|
|
96
|
+
this.elements[4] * mult.elements[7] +
|
|
97
|
+
this.elements[7] * mult.elements[8],
|
|
98
|
+
this.elements[2] * mult.elements[6] +
|
|
99
|
+
this.elements[5] * mult.elements[7] +
|
|
100
|
+
this.elements[8] * mult.elements[8],
|
|
101
|
+
]);
|
|
102
|
+
}
|
|
103
|
+
/**
|
|
104
|
+
* Returns matrix determinant
|
|
105
|
+
*/
|
|
106
|
+
determinant() {
|
|
107
|
+
let result = this.get(0, 0) * (this.get(1, 1) * this.get(2, 2) - this.get(2, 1) * this.get(1, 2));
|
|
108
|
+
result -= this.get(1, 0) * (this.get(0, 1) * this.get(2, 2) - this.get(2, 1) * this.get(0, 2));
|
|
109
|
+
result += this.get(2, 0) * (this.get(0, 1) * this.get(1, 2) - this.get(1, 1) * this.get(0, 2));
|
|
110
|
+
return result;
|
|
111
|
+
}
|
|
112
|
+
/**
|
|
113
|
+
* Clone the matrix
|
|
114
|
+
*/
|
|
115
|
+
clone() {
|
|
116
|
+
return new Matrix3x3(this.elements.slice(0));
|
|
117
|
+
}
|
|
118
|
+
/**
|
|
119
|
+
* Compare 2 matrixes
|
|
120
|
+
*/
|
|
121
|
+
equals(matrix) {
|
|
122
|
+
return Matrix3x3.equals(this, matrix);
|
|
123
|
+
}
|
|
124
|
+
/**
|
|
125
|
+
* Returns string representation of the matrix
|
|
126
|
+
*/
|
|
127
|
+
toString() {
|
|
128
|
+
return ('(' +
|
|
129
|
+
[
|
|
130
|
+
this.elements[0].toFixed(3),
|
|
131
|
+
this.elements[1].toFixed(3),
|
|
132
|
+
this.elements[2].toFixed(3),
|
|
133
|
+
this.elements[3].toFixed(3),
|
|
134
|
+
this.elements[4].toFixed(3),
|
|
135
|
+
this.elements[5].toFixed(3),
|
|
136
|
+
this.elements[6].toFixed(3),
|
|
137
|
+
this.elements[7].toFixed(3),
|
|
138
|
+
this.elements[8].toFixed(3),
|
|
139
|
+
].join(',') +
|
|
140
|
+
')');
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
//# sourceMappingURL=matrix3x3.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"matrix3x3.js","sourceRoot":"","sources":["../src/matrix3x3.ts"],"names":[],"mappings":"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"}
|
package/dist/matrix3x4.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { ICloneable, IEquatable } from
|
|
2
|
-
import { Vec3 } from
|
|
1
|
+
import { ICloneable, IEquatable } from '@chemistry/common';
|
|
2
|
+
import { Vec3 } from './vec3';
|
|
3
3
|
/**
|
|
4
4
|
* Simple Class to work with special type of matrix.
|
|
5
5
|
* | x1 x2 x3 x4 |
|
|
@@ -43,3 +43,4 @@ export declare class Matrix3x4 implements ICloneable<Matrix3x4>, IEquatable<Matr
|
|
|
43
43
|
*/
|
|
44
44
|
toSymetryCode(): string;
|
|
45
45
|
}
|
|
46
|
+
//# sourceMappingURL=matrix3x4.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"matrix3x4.d.ts","sourceRoot":"","sources":["../src/matrix3x4.ts"],"names":[],"mappings":"AAAA,OAAO,EAAW,UAAU,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AACpE,OAAO,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAE9B;;;;;;GAMG;AACH,qBAAa,SAAU,YAAW,UAAU,CAAC,SAAS,CAAC,EAAE,UAAU,CAAC,SAAS,CAAC;WAC9D,GAAG,CAAC,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,SAAS,GAAG,SAAS;WAmBtD,GAAG,CAAC,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,SAAS,GAAG,SAAS;WAmBtD,OAAO,CAAC,MAAM,EAAE,SAAS,GAAG,SAAS;WAgJrC,GAAG,CAAC,MAAM,EAAE,SAAS,GAAG,OAAO;WAiB/B,MAAM,CAAC,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,SAAS,GAAG,OAAO;IAiBrE,SAAS,CAAC,QAAQ,EAAE,MAAM,EAAE,CAAC;gBAEjB,QAAQ,CAAC,EAAE,MAAM,EAAE;IAK/B;;OAEG;IACI,GAAG,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM;IAO5C;;;;;OAKG;IACI,GAAG,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM;IAOxB,GAAG,CAAC,MAAM,EAAE,SAAS,GAAG,SAAS;IAIjC,GAAG,CAAC,MAAM,EAAE,SAAS,GAAG,SAAS;IAIjC,SAAS,CAAC,CAAC,EAAE,IAAI,GAAG,SAAS;IAQ7B,KAAK,CAAC,IAAI,EAAE,MAAM,GAAG,SAAS;IAiB9B,OAAO,CAAC,IAAI,EAAE,IAAI,GAAG,IAAI;IAiBzB,QAAQ,CAAC,IAAI,EAAE,SAAS;IA0DxB,OAAO,IAAI,SAAS;IAIpB,GAAG,IAAI,OAAO;IAId,MAAM,CAAC,MAAM,EAAE,SAAS,GAAG,OAAO;IAIlC,KAAK,IAAI,SAAS;IAIlB,QAAQ,IAAI,MAAM;IAIzB;;;OAGG;IACI,aAAa,IAAI,MAAM;CAmD/B"}
|
|
@@ -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
|