@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 CHANGED
@@ -1,27 +1,29 @@
1
1
  # @chemistry/math
2
+
2
3
  [![npm version](https://badge.fury.io/js/%40chemistry%2Fmath.svg)](https://badge.fury.io/js/%40chemistry%2Fmath)
3
- [![Build Status](https://travis-ci.com/chemistry/chemical-libraries.svg?branch=master)](https://travis-ci.org/chemistry/chemical-libraries)
4
- [![codecov](https://codecov.io/gh/chemistry/chemical-libraries/branch/master/graph/badge.svg)](https://codecov.io/gh/chemistry/chemical-libraries)
5
4
  [![License: MIT](https://img.shields.io/badge/License-MIT-gren.svg)](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
- * Vec3
16
- * Matrix3x3
17
- * Matrix3x4
18
- * Transform3d
19
- * Quaternion
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, 0, 2, 0, 0, 0, 3]);
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
- * Build project: `npm run build`
35
+
36
+ - Build project: `npm run build`
package/dist/index.d.ts CHANGED
@@ -1,5 +1,6 @@
1
- export * from "./matrix3x3";
2
- export * from "./matrix3x4";
3
- export * from "./transform3d";
4
- export * from "./vec3";
5
- export * from "./vec2";
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,6 @@
1
+ export * from './matrix3x3';
2
+ export * from './matrix3x4';
3
+ export * from './transform3d';
4
+ export * from './vec3';
5
+ export * from './vec2';
6
+ //# sourceMappingURL=index.js.map
@@ -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"}
@@ -1,5 +1,5 @@
1
- import { ICloneable, IEquatable } from "@chemistry/common";
2
- import { Vec3 } from "./vec3";
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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"}
@@ -1,5 +1,5 @@
1
- import { ICloneable, IEquatable } from "@chemistry/common";
2
- import { Vec3 } from "./vec3";
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