@ntf/math 1.0.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.
Files changed (117) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +41 -0
  3. package/dist/cjs/algebra/function.js +7 -0
  4. package/dist/cjs/algebra/function.js.map +1 -0
  5. package/dist/cjs/algebra/linear.js +42 -0
  6. package/dist/cjs/algebra/linear.js.map +1 -0
  7. package/dist/cjs/algebra/quad.js +53 -0
  8. package/dist/cjs/algebra/quad.js.map +1 -0
  9. package/dist/cjs/common/error.js +14 -0
  10. package/dist/cjs/common/error.js.map +1 -0
  11. package/dist/cjs/common/sign.js +14 -0
  12. package/dist/cjs/common/sign.js.map +1 -0
  13. package/dist/cjs/common/types.js +35 -0
  14. package/dist/cjs/common/types.js.map +1 -0
  15. package/dist/cjs/geometry/angle.js +11 -0
  16. package/dist/cjs/geometry/angle.js.map +1 -0
  17. package/dist/cjs/geometry/bbox.js +87 -0
  18. package/dist/cjs/geometry/bbox.js.map +1 -0
  19. package/dist/cjs/geometry/circle.js +64 -0
  20. package/dist/cjs/geometry/circle.js.map +1 -0
  21. package/dist/cjs/geometry/object.js +3 -0
  22. package/dist/cjs/geometry/object.js.map +1 -0
  23. package/dist/cjs/geometry/rectangle.js +77 -0
  24. package/dist/cjs/geometry/rectangle.js.map +1 -0
  25. package/dist/cjs/geometry/square.js +66 -0
  26. package/dist/cjs/geometry/square.js.map +1 -0
  27. package/dist/cjs/geometry/triangle.js +65 -0
  28. package/dist/cjs/geometry/triangle.js.map +1 -0
  29. package/dist/cjs/index.js +58 -0
  30. package/dist/cjs/index.js.map +1 -0
  31. package/dist/cjs/matrices/mat3.js +184 -0
  32. package/dist/cjs/matrices/mat3.js.map +1 -0
  33. package/dist/cjs/matrices/mat4.js +262 -0
  34. package/dist/cjs/matrices/mat4.js.map +1 -0
  35. package/dist/cjs/quaternion.js +196 -0
  36. package/dist/cjs/quaternion.js.map +1 -0
  37. package/dist/cjs/vectors/vec2.js +151 -0
  38. package/dist/cjs/vectors/vec2.js.map +1 -0
  39. package/dist/cjs/vectors/vec3.js +148 -0
  40. package/dist/cjs/vectors/vec3.js.map +1 -0
  41. package/dist/esm/algebra/function.js +3 -0
  42. package/dist/esm/algebra/function.js.map +1 -0
  43. package/dist/esm/algebra/linear.js +38 -0
  44. package/dist/esm/algebra/linear.js.map +1 -0
  45. package/dist/esm/algebra/quad.js +49 -0
  46. package/dist/esm/algebra/quad.js.map +1 -0
  47. package/dist/esm/common/error.js +10 -0
  48. package/dist/esm/common/error.js.map +1 -0
  49. package/dist/esm/common/sign.js +10 -0
  50. package/dist/esm/common/sign.js.map +1 -0
  51. package/dist/esm/common/types.js +26 -0
  52. package/dist/esm/common/types.js.map +1 -0
  53. package/dist/esm/geometry/angle.js +5 -0
  54. package/dist/esm/geometry/angle.js.map +1 -0
  55. package/dist/esm/geometry/bbox.js +83 -0
  56. package/dist/esm/geometry/bbox.js.map +1 -0
  57. package/dist/esm/geometry/circle.js +60 -0
  58. package/dist/esm/geometry/circle.js.map +1 -0
  59. package/dist/esm/geometry/object.js +2 -0
  60. package/dist/esm/geometry/object.js.map +1 -0
  61. package/dist/esm/geometry/rectangle.js +73 -0
  62. package/dist/esm/geometry/rectangle.js.map +1 -0
  63. package/dist/esm/geometry/square.js +62 -0
  64. package/dist/esm/geometry/square.js.map +1 -0
  65. package/dist/esm/geometry/triangle.js +59 -0
  66. package/dist/esm/geometry/triangle.js.map +1 -0
  67. package/dist/esm/index.js +39 -0
  68. package/dist/esm/index.js.map +1 -0
  69. package/dist/esm/matrices/mat3.js +180 -0
  70. package/dist/esm/matrices/mat3.js.map +1 -0
  71. package/dist/esm/matrices/mat4.js +258 -0
  72. package/dist/esm/matrices/mat4.js.map +1 -0
  73. package/dist/esm/quaternion.js +192 -0
  74. package/dist/esm/quaternion.js.map +1 -0
  75. package/dist/esm/vectors/vec2.js +147 -0
  76. package/dist/esm/vectors/vec2.js.map +1 -0
  77. package/dist/esm/vectors/vec3.js +144 -0
  78. package/dist/esm/vectors/vec3.js.map +1 -0
  79. package/dist/types/algebra/function.d.ts +6 -0
  80. package/dist/types/algebra/function.d.ts.map +1 -0
  81. package/dist/types/algebra/linear.d.ts +14 -0
  82. package/dist/types/algebra/linear.d.ts.map +1 -0
  83. package/dist/types/algebra/quad.d.ts +18 -0
  84. package/dist/types/algebra/quad.d.ts.map +1 -0
  85. package/dist/types/common/error.d.ts +6 -0
  86. package/dist/types/common/error.d.ts.map +1 -0
  87. package/dist/types/common/sign.d.ts +2 -0
  88. package/dist/types/common/sign.d.ts.map +1 -0
  89. package/dist/types/common/types.d.ts +21 -0
  90. package/dist/types/common/types.d.ts.map +1 -0
  91. package/dist/types/geometry/angle.d.ts +5 -0
  92. package/dist/types/geometry/angle.d.ts.map +1 -0
  93. package/dist/types/geometry/bbox.d.ts +35 -0
  94. package/dist/types/geometry/bbox.d.ts.map +1 -0
  95. package/dist/types/geometry/circle.d.ts +26 -0
  96. package/dist/types/geometry/circle.d.ts.map +1 -0
  97. package/dist/types/geometry/object.d.ts +5 -0
  98. package/dist/types/geometry/object.d.ts.map +1 -0
  99. package/dist/types/geometry/rectangle.d.ts +31 -0
  100. package/dist/types/geometry/rectangle.d.ts.map +1 -0
  101. package/dist/types/geometry/square.d.ts +27 -0
  102. package/dist/types/geometry/square.d.ts.map +1 -0
  103. package/dist/types/geometry/triangle.d.ts +42 -0
  104. package/dist/types/geometry/triangle.d.ts.map +1 -0
  105. package/dist/types/index.d.ts +22 -0
  106. package/dist/types/index.d.ts.map +1 -0
  107. package/dist/types/matrices/mat3.d.ts +58 -0
  108. package/dist/types/matrices/mat3.d.ts.map +1 -0
  109. package/dist/types/matrices/mat4.d.ts +84 -0
  110. package/dist/types/matrices/mat4.d.ts.map +1 -0
  111. package/dist/types/quaternion.d.ts +49 -0
  112. package/dist/types/quaternion.d.ts.map +1 -0
  113. package/dist/types/vectors/vec2.d.ts +55 -0
  114. package/dist/types/vectors/vec2.d.ts.map +1 -0
  115. package/dist/types/vectors/vec3.d.ts +53 -0
  116. package/dist/types/vectors/vec3.d.ts.map +1 -0
  117. package/package.json +40 -0
@@ -0,0 +1,65 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Triangle3D = exports.Triangle2D = exports.ATriangle = void 0;
4
+ const vec2_1 = require("../vectors/vec2");
5
+ const vec3_1 = require("../vectors/vec3");
6
+ class ATriangle {
7
+ A;
8
+ B;
9
+ C;
10
+ constructor(A, B, C) {
11
+ this.A = A;
12
+ this.B = B;
13
+ this.C = C;
14
+ }
15
+ get alpha() {
16
+ return Math.acos((this.b * this.b + this.c * this.c - this.a * this.a) / (2 * this.b * this.c));
17
+ }
18
+ get beta() {
19
+ return Math.acos((this.c * this.c + this.a * this.a - this.b * this.b) / (2 * this.c * this.a));
20
+ }
21
+ get gamma() {
22
+ return Math.acos((this.a * this.a + this.b * this.b - this.c * this.c) / (2 * this.a * this.b));
23
+ }
24
+ get perimeter() {
25
+ return this.a + this.b + this.c;
26
+ }
27
+ get semiperimeter() {
28
+ return this.perimeter / 2;
29
+ }
30
+ get area() {
31
+ return Math.sqrt(this.semiperimeter * (this.semiperimeter - this.a) * (this.semiperimeter - this.b) * (this.semiperimeter - this.c));
32
+ }
33
+ get base() {
34
+ return 2 * (this.area / (this.a * Math.sin(this.gamma)));
35
+ }
36
+ get height() {
37
+ return 2 * (this.area / this.base);
38
+ }
39
+ }
40
+ exports.ATriangle = ATriangle;
41
+ class Triangle2D extends ATriangle {
42
+ get a() {
43
+ return vec2_1.Vec2.fromPoints(this.B, this.C).length();
44
+ }
45
+ get b() {
46
+ return vec2_1.Vec2.fromPoints(this.A, this.C).length();
47
+ }
48
+ get c() {
49
+ return vec2_1.Vec2.fromPoints(this.A, this.B).length();
50
+ }
51
+ }
52
+ exports.Triangle2D = Triangle2D;
53
+ class Triangle3D extends ATriangle {
54
+ get a() {
55
+ return vec3_1.Vec3.fromPoints(this.B, this.C).length();
56
+ }
57
+ get b() {
58
+ return vec3_1.Vec3.fromPoints(this.A, this.C).length();
59
+ }
60
+ get c() {
61
+ return vec3_1.Vec3.fromPoints(this.A, this.B).length();
62
+ }
63
+ }
64
+ exports.Triangle3D = Triangle3D;
65
+ //# sourceMappingURL=triangle.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"triangle.js","sourceRoot":"","sources":["../../../source/geometry/triangle.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,58 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ exports.EPSILON = exports.clamp = exports.log_hypot = void 0;
18
+ __exportStar(require("./algebra/function"), exports);
19
+ __exportStar(require("./algebra/linear"), exports);
20
+ __exportStar(require("./algebra/quad"), exports);
21
+ __exportStar(require("./common/error"), exports);
22
+ __exportStar(require("./common/sign"), exports);
23
+ __exportStar(require("./common/types"), exports);
24
+ __exportStar(require("./geometry/angle"), exports);
25
+ __exportStar(require("./geometry/bbox"), exports);
26
+ __exportStar(require("./geometry/circle"), exports);
27
+ __exportStar(require("./geometry/object"), exports);
28
+ __exportStar(require("./geometry/rectangle"), exports);
29
+ __exportStar(require("./geometry/square"), exports);
30
+ __exportStar(require("./geometry/triangle"), exports);
31
+ __exportStar(require("./matrices/mat3"), exports);
32
+ __exportStar(require("./matrices/mat4"), exports);
33
+ __exportStar(require("./vectors/vec2"), exports);
34
+ __exportStar(require("./vectors/vec3"), exports);
35
+ __exportStar(require("./quaternion"), exports);
36
+ function log_hypot(a, b) {
37
+ const a_abs = Math.abs(a);
38
+ const b_abs = Math.abs(b);
39
+ if (a == 0)
40
+ return Math.log(b_abs);
41
+ if (b == 0)
42
+ return Math.log(a_abs);
43
+ if (a_abs < 3000 && b_abs < 3000)
44
+ return 0.5 * Math.log(a * a + b * b);
45
+ const _a = a / 2, _b = b / 2;
46
+ return 0.5 * Math.log(_a * _a + _b * _b) + Math.LN2;
47
+ }
48
+ exports.log_hypot = log_hypot;
49
+ function clamp(value, min, max) {
50
+ if (value <= min)
51
+ return min;
52
+ if (value >= max)
53
+ return max;
54
+ return value;
55
+ }
56
+ exports.clamp = clamp;
57
+ exports.EPSILON = 1e-16;
58
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../source/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,qDAAkC;AAClC,mDAAgC;AAChC,iDAA8B;AAC9B,iDAA8B;AAC9B,gDAA6B;AAC7B,iDAA8B;AAC9B,mDAAgC;AAChC,kDAA+B;AAC/B,oDAAiC;AACjC,oDAAiC;AACjC,uDAAoC;AACpC,oDAAiC;AACjC,sDAAmC;AACnC,kDAA+B;AAC/B,kDAA+B;AAC/B,iDAA8B;AAC9B,iDAA8B;AAC9B,+CAA4B;AAE5B,SAAgB,SAAS,CAAC,CAAS,EAAC,CAAS;IAEzC,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAA;IACzB,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAA;IACzB,IAAG,CAAC,IAAI,CAAC;QACL,OAAO,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAA;IAC1B,IAAG,CAAC,IAAI,CAAC;QACL,OAAO,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAA;IAC1B,IAAG,KAAK,GAAG,IAAI,IAAI,KAAK,GAAG,IAAI;QAC3B,OAAO,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAC,CAAC,GAAC,CAAC,GAAC,CAAC,CAAC,CAAA;IAClC,MAAM,EAAE,GAAG,CAAC,GAAC,CAAC,EAAE,EAAE,GAAG,CAAC,GAAC,CAAC,CAAA;IACxB,OAAO,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,GAAC,EAAE,GAAC,EAAE,GAAC,EAAE,CAAC,GAAG,IAAI,CAAC,GAAG,CAAA;AACjD,CAAC;AAZD,8BAYC;AAED,SAAgB,KAAK,CAA4B,KAAQ,EAAC,GAAM,EAAC,GAAM;IAEnE,IAAG,KAAK,IAAI,GAAG;QACX,OAAO,GAAG,CAAA;IACd,IAAG,KAAK,IAAI,GAAG;QACX,OAAO,GAAG,CAAA;IACd,OAAO,KAAK,CAAA;AAChB,CAAC;AAPD,sBAOC;AAEY,QAAA,OAAO,GAAG,KAAK,CAAA"}
@@ -0,0 +1,184 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Mat3 = void 0;
4
+ const error_1 = require("../common/error");
5
+ const types_1 = require("../common/types");
6
+ const vec2_1 = require("../vectors/vec2");
7
+ class Mat3 {
8
+ _raw;
9
+ get m00() { return this._raw[0]; }
10
+ set m00(val) { this._raw[0] = val; }
11
+ get m01() { return this._raw[1]; }
12
+ set m01(val) { this._raw[1] = val; }
13
+ get m02() { return this._raw[2]; }
14
+ set m02(val) { this._raw[2] = val; }
15
+ get m10() { return this._raw[3]; }
16
+ set m10(val) { this._raw[3] = val; }
17
+ get m11() { return this._raw[4]; }
18
+ set m11(val) { this._raw[4] = val; }
19
+ get m12() { return this._raw[5]; }
20
+ set m12(val) { this._raw[5] = val; }
21
+ get m20() { return this._raw[6]; }
22
+ set m20(val) { this._raw[6] = val; }
23
+ get m21() { return this._raw[7]; }
24
+ set m21(val) { this._raw[7] = val; }
25
+ get m22() { return this._raw[8]; }
26
+ set m22(val) { this._raw[8] = val; }
27
+ static resolve(a) {
28
+ if (a == null || typeof a == "undefined")
29
+ throw new error_1.ResolveError("Mat3", a);
30
+ if ((0, types_1.check_number_array)(a, 9)) {
31
+ return new this(a);
32
+ }
33
+ if ((0, types_1.check_array)(a, undefined, 3)) {
34
+ const row0 = a[0], row1 = a[1], row2 = a[2];
35
+ if ((0, types_1.check_number_array)(row0, 3) && (0, types_1.check_number_array)(row1, 3) && (0, types_1.check_number_array)(row2, 3))
36
+ return new this([
37
+ row0[0], row0[1], row0[2],
38
+ row1[0], row1[1], row1[2],
39
+ row2[0], row2[1], row2[2],
40
+ ]);
41
+ }
42
+ if ((0, types_1.check_string)(a)) {
43
+ const parts = a.split(",");
44
+ if ((0, types_1.check_string_array)(parts, 9))
45
+ return this.resolve(parts.map((i) => parseFloat(i)));
46
+ }
47
+ if ((0, types_1.has_property)(a, "m00", "number") && (0, types_1.has_property)(a, "m01", "number") && (0, types_1.has_property)(a, "m02", "number") &&
48
+ (0, types_1.has_property)(a, "m10", "number") && (0, types_1.has_property)(a, "m11", "number") && (0, types_1.has_property)(a, "m12", "number") &&
49
+ (0, types_1.has_property)(a, "m20", "number") && (0, types_1.has_property)(a, "m21", "number") && (0, types_1.has_property)(a, "m22", "number"))
50
+ return new this([
51
+ a.m00, a.m01, a.m02,
52
+ a.m10, a.m11, a.m12,
53
+ a.m20, a.m21, a.m22
54
+ ]);
55
+ if ((0, types_1.check_number)(a)) {
56
+ return new this([a, a, a, a, a, a, a, a, a]);
57
+ }
58
+ throw new error_1.ResolveError("Mat3", a);
59
+ }
60
+ static is(a) {
61
+ try {
62
+ this.resolve(a);
63
+ }
64
+ catch (e) {
65
+ return false;
66
+ }
67
+ return true;
68
+ }
69
+ static projection(width, height) {
70
+ return new this([
71
+ 2 / width, 0, 0,
72
+ 0, -2 / height, 0,
73
+ -1, 1, 1
74
+ ]);
75
+ }
76
+ constructor(init = [1, 0, 0, 0, 1, 0, 0, 0, 1]) {
77
+ this._raw = init;
78
+ }
79
+ toArray() {
80
+ return [
81
+ this.m00, this.m01, this.m02,
82
+ this.m10, this.m11, this.m12,
83
+ this.m20, this.m21, this.m22
84
+ ];
85
+ }
86
+ toNestetArray() {
87
+ return [
88
+ [this.m00, this.m01, this.m02],
89
+ [this.m10, this.m11, this.m12],
90
+ [this.m20, this.m21, this.m22]
91
+ ];
92
+ }
93
+ toJSON() {
94
+ return {
95
+ m00: this.m00, m01: this.m01, m02: this.m02,
96
+ m10: this.m10, m11: this.m11, m12: this.m12,
97
+ m20: this.m20, m21: this.m21, m22: this.m22
98
+ };
99
+ }
100
+ toString() {
101
+ return `${this.m00},${this.m01},${this.m02},${this.m10},${this.m11},${this.m12},${this.m20},${this.m21},${this.m22}`;
102
+ }
103
+ clone() {
104
+ return new Mat3([
105
+ this.m00, this.m01, this.m02,
106
+ this.m10, this.m11, this.m12,
107
+ this.m20, this.m21, this.m22
108
+ ]);
109
+ }
110
+ add(mat) {
111
+ const b = Mat3.resolve(mat);
112
+ const m = new Mat3;
113
+ for (let index = 0; index < this._raw.length; index++)
114
+ m._raw[index] = this._raw[index] + b._raw[index];
115
+ return this;
116
+ }
117
+ subtract(mat) {
118
+ const b = Mat3.resolve(mat);
119
+ const m = new Mat3;
120
+ for (let index = 0; index < this._raw.length; index++)
121
+ m._raw[index] = this._raw[index] - b._raw[index];
122
+ return this;
123
+ }
124
+ multiply(a) {
125
+ if ((0, types_1.check_number)(a))
126
+ return new Mat3([
127
+ this.m00 * a, this.m01 * a, this.m02 * a,
128
+ this.m10 * a, this.m11 * a, this.m12 * a,
129
+ this.m20 * a, this.m21 * a, this.m22 * a
130
+ ]);
131
+ const b = Mat3.resolve(a);
132
+ return new Mat3([
133
+ b.m00 * this.m00 + b.m01 * this.m10 + b.m02 * this.m20,
134
+ b.m00 * this.m01 + b.m01 * this.m11 + b.m02 * this.m21,
135
+ b.m00 * this.m02 + b.m01 * this.m12 + b.m02 * this.m22,
136
+ b.m10 * this.m00 + b.m11 * this.m10 + b.m12 * this.m20,
137
+ b.m10 * this.m01 + b.m11 * this.m11 + b.m12 * this.m21,
138
+ b.m10 * this.m02 + b.m11 * this.m12 + b.m12 * this.m22,
139
+ b.m20 * this.m00 + b.m21 * this.m10 + b.m22 * this.m20,
140
+ b.m20 * this.m01 + b.m21 * this.m11 + b.m22 * this.m21,
141
+ b.m20 * this.m02 + b.m21 * this.m12 + b.m22 * this.m22
142
+ ]);
143
+ }
144
+ translate(...args) {
145
+ const vec = vec2_1.Vec2.resolveArgs(args);
146
+ return this.multiply([
147
+ 1, 0, 0,
148
+ 0, 1, 0,
149
+ vec.x, vec.y, 1
150
+ ]);
151
+ }
152
+ rotate(angle) {
153
+ const c = Math.cos(angle);
154
+ const s = Math.sin(angle);
155
+ return this.multiply([
156
+ c, -s, 0,
157
+ s, c, 0,
158
+ 0, 0, 1
159
+ ]);
160
+ }
161
+ scale(...args) {
162
+ const vec = vec2_1.Vec2.resolve(args);
163
+ return this.multiply([
164
+ vec.x, 0, 0,
165
+ 0, vec.y, 0,
166
+ 0, 0, 1
167
+ ]);
168
+ }
169
+ determinant() {
170
+ return this.m00 * this.m11 * this.m22 - this.m21 * this.m12 -
171
+ this.m01 * this.m10 * this.m22 - this.m12 * this.m20 +
172
+ this.m02 * this.m10 * this.m21 - this.m11 * this.m20;
173
+ }
174
+ inverse() {
175
+ const det = this.determinant();
176
+ return new Mat3([
177
+ (this.m11 * this.m22 - this.m21 * this.m12) * det, (this.m02 * this.m21 - this.m01 * this.m22) * det, (this.m01 * this.m12 - this.m02 * this.m11) * det,
178
+ (this.m12 * this.m20 - this.m10 * this.m22) * det, (this.m00 * this.m22 - this.m02 * this.m20) * det, (this.m10 * this.m02 - this.m00 * this.m12) * det,
179
+ (this.m10 * this.m21 - this.m20 * this.m11) * det, (this.m20 * this.m01 - this.m00 * this.m21) * det, (this.m00 * this.m11 - this.m10 * this.m01) * det
180
+ ]);
181
+ }
182
+ }
183
+ exports.Mat3 = Mat3;
184
+ //# sourceMappingURL=mat3.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mat3.js","sourceRoot":"","sources":["../../../source/matrices/mat3.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,262 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Mat4 = void 0;
4
+ const error_1 = require("../common/error");
5
+ const vec3_1 = require("../vectors/vec3");
6
+ const types_1 = require("../common/types");
7
+ class Mat4 {
8
+ _raw;
9
+ get m00() { return this._raw[0]; }
10
+ set m00(val) { this._raw[0] = val; }
11
+ get m01() { return this._raw[1]; }
12
+ set m01(val) { this._raw[1] = val; }
13
+ get m02() { return this._raw[2]; }
14
+ set m02(val) { this._raw[2] = val; }
15
+ get m03() { return this._raw[3]; }
16
+ set m03(val) { this._raw[3] = val; }
17
+ get m10() { return this._raw[4]; }
18
+ set m10(val) { this._raw[4] = val; }
19
+ get m11() { return this._raw[5]; }
20
+ set m11(val) { this._raw[5] = val; }
21
+ get m12() { return this._raw[6]; }
22
+ set m12(val) { this._raw[6] = val; }
23
+ get m13() { return this._raw[7]; }
24
+ set m13(val) { this._raw[7] = val; }
25
+ get m20() { return this._raw[8]; }
26
+ set m20(val) { this._raw[8] = val; }
27
+ get m21() { return this._raw[9]; }
28
+ set m21(val) { this._raw[9] = val; }
29
+ get m22() { return this._raw[10]; }
30
+ set m22(val) { this._raw[10] = val; }
31
+ get m23() { return this._raw[11]; }
32
+ set m23(val) { this._raw[11] = val; }
33
+ get m30() { return this._raw[12]; }
34
+ set m30(val) { this._raw[12] = val; }
35
+ get m31() { return this._raw[13]; }
36
+ set m31(val) { this._raw[13] = val; }
37
+ get m32() { return this._raw[14]; }
38
+ set m32(val) { this._raw[14] = val; }
39
+ get m33() { return this._raw[15]; }
40
+ set m33(val) { this._raw[15] = val; }
41
+ static resolve(a) {
42
+ if (a == null || typeof a == "undefined")
43
+ throw new error_1.ResolveError("Mat4", a);
44
+ if ((0, types_1.check_number_array)(a, 16)) {
45
+ return new this(a);
46
+ }
47
+ if ((0, types_1.check_array)(a, undefined, 4)) {
48
+ const row0 = a[0], row1 = a[1], row2 = a[2], row3 = a[3];
49
+ if ((0, types_1.check_number_array)(row0, 4) && (0, types_1.check_number_array)(row1, 4) && (0, types_1.check_number_array)(row2, 4) && (0, types_1.check_number_array)(row3, 4))
50
+ return new this([
51
+ row0[0], row0[1], row0[2], row0[3],
52
+ row1[0], row1[1], row1[2], row1[3],
53
+ row2[0], row2[1], row2[2], row2[3],
54
+ row3[0], row3[1], row3[2], row3[3]
55
+ ]);
56
+ }
57
+ if ((0, types_1.check_string)(a)) {
58
+ const parts = a.split(",");
59
+ if ((0, types_1.check_string_array)(parts, 16))
60
+ return this.resolve(parts.map((i) => parseFloat(i)));
61
+ }
62
+ if ((0, types_1.has_property)(a, "m00", "number") && (0, types_1.has_property)(a, "m01", "number") && (0, types_1.has_property)(a, "m02", "number") && (0, types_1.has_property)(a, "m03", "number") &&
63
+ (0, types_1.has_property)(a, "m10", "number") && (0, types_1.has_property)(a, "m11", "number") && (0, types_1.has_property)(a, "m12", "number") && (0, types_1.has_property)(a, "m13", "number") &&
64
+ (0, types_1.has_property)(a, "m20", "number") && (0, types_1.has_property)(a, "m21", "number") && (0, types_1.has_property)(a, "m22", "number") && (0, types_1.has_property)(a, "m23", "number") &&
65
+ (0, types_1.has_property)(a, "m30", "number") && (0, types_1.has_property)(a, "m31", "number") && (0, types_1.has_property)(a, "m32", "number") && (0, types_1.has_property)(a, "m33", "number"))
66
+ return new this([
67
+ a.m00, a.m01, a.m02, a.m03,
68
+ a.m10, a.m11, a.m12, a.m13,
69
+ a.m20, a.m21, a.m22, a.m23,
70
+ a.m30, a.m31, a.m32, a.m33
71
+ ]);
72
+ if ((0, types_1.check_number)(a)) {
73
+ return new this([a, a, a, a, a, a, a, a, a, a, a, a, a, a, a, a]);
74
+ }
75
+ throw new error_1.ResolveError("Mat4", a);
76
+ }
77
+ static is(a) {
78
+ try {
79
+ this.resolve(a);
80
+ }
81
+ catch (e) {
82
+ return false;
83
+ }
84
+ return true;
85
+ }
86
+ static orthographic(left, right, bottom, top, near, far) {
87
+ return new this([
88
+ 2 / (right - left), 0, 0, 0,
89
+ 0, 2 / (top - bottom), 0, 0,
90
+ 0, 0, 2 / (near - far), 0,
91
+ (left + right) / (left - right),
92
+ (bottom + top) / (bottom - top),
93
+ (near + far) / (near - far), 1
94
+ ]);
95
+ }
96
+ static perspective(fov, aspect, near, far) {
97
+ const f = Math.tan(Math.PI * 0.5 - 0.5 * fov);
98
+ const rangeInv = 1.0 / (near - far);
99
+ return new this([
100
+ f / aspect, 0, 0, 0,
101
+ 0, f, 0, 0,
102
+ 0, 0, (near + far) * rangeInv, -1,
103
+ 0, 0, near * far * rangeInv * 2, 0
104
+ ]);
105
+ }
106
+ constructor(init = [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1]) {
107
+ this._raw = init;
108
+ }
109
+ toArray() {
110
+ return [
111
+ this.m00, this.m01, this.m02, this.m03,
112
+ this.m10, this.m11, this.m12, this.m13,
113
+ this.m20, this.m21, this.m22, this.m23,
114
+ this.m30, this.m31, this.m32, this.m33
115
+ ];
116
+ }
117
+ toNestetArray() {
118
+ return [
119
+ [this.m00, this.m01, this.m02, this.m03],
120
+ [this.m10, this.m11, this.m12, this.m13],
121
+ [this.m20, this.m21, this.m22, this.m23],
122
+ [this.m30, this.m31, this.m32, this.m33]
123
+ ];
124
+ }
125
+ toJSON() {
126
+ return {
127
+ m00: this.m00, m01: this.m01, m02: this.m02, m03: this.m03,
128
+ m10: this.m10, m11: this.m11, m12: this.m12, m13: this.m13,
129
+ m20: this.m20, m21: this.m21, m22: this.m22, m23: this.m23,
130
+ m30: this.m20, m31: this.m21, m32: this.m22, m33: this.m23
131
+ };
132
+ }
133
+ toString() {
134
+ return `${this.m00},${this.m01},${this.m02},${this.m03},${this.m10},${this.m11},${this.m12},${this.m13},${this.m20},${this.m21},${this.m22},${this.m23},${this.m30},${this.m31},${this.m32},${this.m33}`;
135
+ }
136
+ clone() {
137
+ return new Mat4([
138
+ this.m00, this.m01, this.m02, this.m03,
139
+ this.m10, this.m11, this.m12, this.m13,
140
+ this.m20, this.m21, this.m22, this.m23,
141
+ this.m30, this.m31, this.m32, this.m33
142
+ ]);
143
+ }
144
+ add(mat) {
145
+ const b = Mat4.resolve(mat);
146
+ const m = new Mat4;
147
+ for (let index = 0; index < this._raw.length; index++)
148
+ m._raw[index] = this._raw[index] + b._raw[index];
149
+ return m;
150
+ }
151
+ subtract(mat) {
152
+ const b = Mat4.resolve(mat);
153
+ const m = new Mat4;
154
+ for (let index = 0; index < this._raw.length; index++)
155
+ m._raw[index] = this._raw[index] - b._raw[index];
156
+ return m;
157
+ }
158
+ multiply(a) {
159
+ if ((0, types_1.check_number)(a)) {
160
+ return new Mat4([
161
+ this.m00 * a, this.m01 * a, this.m02 * a, this.m03 * a,
162
+ this.m10 * a, this.m11 * a, this.m12 * a, this.m13 * a,
163
+ this.m20 * a, this.m21 * a, this.m22 * a, this.m23 * a,
164
+ this.m30 * a, this.m31 * a, this.m32 * a, this.m33 * a
165
+ ]);
166
+ }
167
+ if (Mat4.is(a)) {
168
+ const b = Mat4.resolve(a);
169
+ return new Mat4([
170
+ b.m00 * this.m00 + b.m01 * this.m10 + b.m02 * this.m20 + b.m03 * this.m30,
171
+ b.m00 * this.m01 + b.m01 * this.m11 + b.m02 * this.m21 + b.m03 * this.m31,
172
+ b.m00 * this.m02 + b.m01 * this.m12 + b.m02 * this.m22 + b.m03 * this.m32,
173
+ b.m00 * this.m03 + b.m01 * this.m13 + b.m02 * this.m23 + b.m03 * this.m33,
174
+ b.m10 * this.m00 + b.m11 * this.m10 + b.m12 * this.m20 + b.m13 * this.m30,
175
+ b.m10 * this.m01 + b.m11 * this.m11 + b.m12 * this.m21 + b.m13 * this.m31,
176
+ b.m10 * this.m02 + b.m11 * this.m12 + b.m12 * this.m22 + b.m13 * this.m32,
177
+ b.m10 * this.m03 + b.m11 * this.m13 + b.m12 * this.m23 + b.m13 * this.m33,
178
+ b.m20 * this.m00 + b.m21 * this.m10 + b.m22 * this.m20 + b.m23 * this.m30,
179
+ b.m20 * this.m01 + b.m21 * this.m11 + b.m22 * this.m21 + b.m23 * this.m31,
180
+ b.m20 * this.m02 + b.m21 * this.m12 + b.m22 * this.m22 + b.m23 * this.m32,
181
+ b.m20 * this.m03 + b.m21 * this.m13 + b.m22 * this.m23 + b.m23 * this.m33,
182
+ b.m30 * this.m00 + b.m31 * this.m10 + b.m32 * this.m20 + b.m33 * this.m30,
183
+ b.m30 * this.m01 + b.m31 * this.m11 + b.m32 * this.m21 + b.m33 * this.m31,
184
+ b.m30 * this.m02 + b.m31 * this.m12 + b.m32 * this.m22 + b.m33 * this.m32,
185
+ b.m30 * this.m03 + b.m31 * this.m13 + b.m32 * this.m23 + b.m33 * this.m33,
186
+ ]);
187
+ }
188
+ if (vec3_1.Vec3.is(a)) {
189
+ const b = vec3_1.Vec3.resolve(a);
190
+ const vec = new vec3_1.Vec3(b.x * this.m00 + b.y * this.m10 + b.z * this.m20 + this.m30, b.x * this.m01 + b.y * this.m11 + b.z * this.m21 + this.m31, b.x * this.m02 + b.y * this.m12 + b.z * this.m22 + this.m32, b.x * this.m03 + b.y * this.m13 + b.z * this.m23 + this.m33);
191
+ if (vec.w != 0)
192
+ return vec.divide(vec.w);
193
+ return vec;
194
+ }
195
+ throw new error_1.ResolveError("Mat4 or Vec3 or number", a);
196
+ }
197
+ translate(...args) {
198
+ const vec = vec3_1.Vec3.resolveArgs(args);
199
+ return this.multiply([
200
+ 1, 0, 0, 0,
201
+ 0, 1, 0, 0,
202
+ 0, 0, 1, 0,
203
+ vec.x, vec.y, vec.z, 1
204
+ ]);
205
+ }
206
+ rotateX(angle) {
207
+ const c = Math.cos(angle);
208
+ const s = Math.sin(angle);
209
+ return this.multiply([
210
+ 1, 0, 0, 0,
211
+ 0, c, s, 0,
212
+ 0, -s, c, 0,
213
+ 0, 0, 0, 1
214
+ ]);
215
+ }
216
+ rotateY(angle) {
217
+ const c = Math.cos(angle);
218
+ const s = Math.sin(angle);
219
+ return this.multiply([
220
+ c, 0, -s, 0,
221
+ 0, 1, 0, 0,
222
+ s, 0, c, 0,
223
+ 0, 0, 0, 1
224
+ ]);
225
+ }
226
+ rotateZ(angle) {
227
+ const c = Math.cos(angle);
228
+ const s = Math.sin(angle);
229
+ return this.multiply([
230
+ c, s, 0, 0,
231
+ -s, c, 0, 0,
232
+ 0, 0, 1, 0,
233
+ 0, 0, 0, 1
234
+ ]);
235
+ }
236
+ rotate(...args) {
237
+ const vec = vec3_1.Vec3.resolveArgs(args);
238
+ return this.rotateX(vec.x).rotateY(vec.y).rotateZ(vec.z);
239
+ }
240
+ scale(...args) {
241
+ const vec = vec3_1.Vec3.resolveArgs(args);
242
+ return this.multiply([
243
+ vec.x, 0, 0, 0,
244
+ 0, vec.y, 0, 0,
245
+ 0, 0, vec.z, 0,
246
+ 0, 0, 0, 1
247
+ ]);
248
+ }
249
+ inverse() {
250
+ return new Mat4([
251
+ this.m00, this.m10, this.m20, 0,
252
+ this.m01, this.m11, this.m21, 0,
253
+ this.m02, this.m12, this.m22, 0,
254
+ -(this.m30 * this.m00 + this.m31 * this.m10 + this.m32 * this.m20),
255
+ -(this.m30 * this.m01 + this.m31 * this.m11 + this.m32 * this.m21),
256
+ -(this.m30 * this.m02 + this.m31 * this.m12 + this.m32 * this.m22),
257
+ 1
258
+ ]);
259
+ }
260
+ }
261
+ exports.Mat4 = Mat4;
262
+ //# sourceMappingURL=mat4.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mat4.js","sourceRoot":"","sources":["../../../source/matrices/mat4.ts"],"names":[],"mappings":"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AG,GAAG,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG;gBACzE,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG;gBAEzE,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG;gBACzE,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG;gBACzE,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG;gBACzE,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG;gBAEzE,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG;gBACzE,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG;gBA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"}