@ntf/math 1.2.0 → 1.3.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.
Files changed (125) hide show
  1. package/dist/index.d.mts +754 -0
  2. package/dist/index.d.ts +754 -0
  3. package/dist/index.js +2892 -0
  4. package/dist/index.mjs +2869 -0
  5. package/package.json +23 -13
  6. package/dist/cjs/algebra/function.js +0 -7
  7. package/dist/cjs/algebra/function.js.map +0 -1
  8. package/dist/cjs/algebra/linear.js +0 -49
  9. package/dist/cjs/algebra/linear.js.map +0 -1
  10. package/dist/cjs/algebra/quad.js +0 -62
  11. package/dist/cjs/algebra/quad.js.map +0 -1
  12. package/dist/cjs/color.js +0 -243
  13. package/dist/cjs/color.js.map +0 -1
  14. package/dist/cjs/common/error.js +0 -14
  15. package/dist/cjs/common/error.js.map +0 -1
  16. package/dist/cjs/common/sign.js +0 -14
  17. package/dist/cjs/common/sign.js.map +0 -1
  18. package/dist/cjs/common/types.js +0 -77
  19. package/dist/cjs/common/types.js.map +0 -1
  20. package/dist/cjs/geometry/angle.js +0 -11
  21. package/dist/cjs/geometry/angle.js.map +0 -1
  22. package/dist/cjs/geometry/bbox.js +0 -102
  23. package/dist/cjs/geometry/bbox.js.map +0 -1
  24. package/dist/cjs/geometry/circle.js +0 -87
  25. package/dist/cjs/geometry/circle.js.map +0 -1
  26. package/dist/cjs/geometry/object.js +0 -3
  27. package/dist/cjs/geometry/object.js.map +0 -1
  28. package/dist/cjs/geometry/rectangle.js +0 -98
  29. package/dist/cjs/geometry/rectangle.js.map +0 -1
  30. package/dist/cjs/geometry/square.js +0 -70
  31. package/dist/cjs/geometry/square.js.map +0 -1
  32. package/dist/cjs/geometry/triangle.js +0 -65
  33. package/dist/cjs/geometry/triangle.js.map +0 -1
  34. package/dist/cjs/index.js +0 -59
  35. package/dist/cjs/index.js.map +0 -1
  36. package/dist/cjs/matrices/mat3.js +0 -202
  37. package/dist/cjs/matrices/mat3.js.map +0 -1
  38. package/dist/cjs/matrices/mat4.js +0 -292
  39. package/dist/cjs/matrices/mat4.js.map +0 -1
  40. package/dist/cjs/quaternion.js +0 -204
  41. package/dist/cjs/quaternion.js.map +0 -1
  42. package/dist/cjs/vectors/vec2.js +0 -168
  43. package/dist/cjs/vectors/vec2.js.map +0 -1
  44. package/dist/cjs/vectors/vec3.js +0 -177
  45. package/dist/cjs/vectors/vec3.js.map +0 -1
  46. package/dist/esm/algebra/function.js +0 -3
  47. package/dist/esm/algebra/function.js.map +0 -1
  48. package/dist/esm/algebra/linear.js +0 -45
  49. package/dist/esm/algebra/linear.js.map +0 -1
  50. package/dist/esm/algebra/quad.js +0 -58
  51. package/dist/esm/algebra/quad.js.map +0 -1
  52. package/dist/esm/color.js +0 -236
  53. package/dist/esm/color.js.map +0 -1
  54. package/dist/esm/common/error.js +0 -10
  55. package/dist/esm/common/error.js.map +0 -1
  56. package/dist/esm/common/sign.js +0 -10
  57. package/dist/esm/common/sign.js.map +0 -1
  58. package/dist/esm/common/types.js +0 -65
  59. package/dist/esm/common/types.js.map +0 -1
  60. package/dist/esm/geometry/angle.js +0 -5
  61. package/dist/esm/geometry/angle.js.map +0 -1
  62. package/dist/esm/geometry/bbox.js +0 -98
  63. package/dist/esm/geometry/bbox.js.map +0 -1
  64. package/dist/esm/geometry/circle.js +0 -83
  65. package/dist/esm/geometry/circle.js.map +0 -1
  66. package/dist/esm/geometry/object.js +0 -2
  67. package/dist/esm/geometry/object.js.map +0 -1
  68. package/dist/esm/geometry/rectangle.js +0 -94
  69. package/dist/esm/geometry/rectangle.js.map +0 -1
  70. package/dist/esm/geometry/square.js +0 -66
  71. package/dist/esm/geometry/square.js.map +0 -1
  72. package/dist/esm/geometry/triangle.js +0 -59
  73. package/dist/esm/geometry/triangle.js.map +0 -1
  74. package/dist/esm/index.js +0 -40
  75. package/dist/esm/index.js.map +0 -1
  76. package/dist/esm/matrices/mat3.js +0 -198
  77. package/dist/esm/matrices/mat3.js.map +0 -1
  78. package/dist/esm/matrices/mat4.js +0 -288
  79. package/dist/esm/matrices/mat4.js.map +0 -1
  80. package/dist/esm/quaternion.js +0 -200
  81. package/dist/esm/quaternion.js.map +0 -1
  82. package/dist/esm/vectors/vec2.js +0 -164
  83. package/dist/esm/vectors/vec2.js.map +0 -1
  84. package/dist/esm/vectors/vec3.js +0 -173
  85. package/dist/esm/vectors/vec3.js.map +0 -1
  86. package/dist/types/algebra/function.d.ts +0 -6
  87. package/dist/types/algebra/function.d.ts.map +0 -1
  88. package/dist/types/algebra/linear.d.ts +0 -14
  89. package/dist/types/algebra/linear.d.ts.map +0 -1
  90. package/dist/types/algebra/quad.d.ts +0 -18
  91. package/dist/types/algebra/quad.d.ts.map +0 -1
  92. package/dist/types/color.d.ts +0 -90
  93. package/dist/types/color.d.ts.map +0 -1
  94. package/dist/types/common/error.d.ts +0 -6
  95. package/dist/types/common/error.d.ts.map +0 -1
  96. package/dist/types/common/sign.d.ts +0 -2
  97. package/dist/types/common/sign.d.ts.map +0 -1
  98. package/dist/types/common/types.d.ts +0 -26
  99. package/dist/types/common/types.d.ts.map +0 -1
  100. package/dist/types/geometry/angle.d.ts +0 -5
  101. package/dist/types/geometry/angle.d.ts.map +0 -1
  102. package/dist/types/geometry/bbox.d.ts +0 -38
  103. package/dist/types/geometry/bbox.d.ts.map +0 -1
  104. package/dist/types/geometry/circle.d.ts +0 -32
  105. package/dist/types/geometry/circle.d.ts.map +0 -1
  106. package/dist/types/geometry/object.d.ts +0 -5
  107. package/dist/types/geometry/object.d.ts.map +0 -1
  108. package/dist/types/geometry/rectangle.d.ts +0 -34
  109. package/dist/types/geometry/rectangle.d.ts.map +0 -1
  110. package/dist/types/geometry/square.d.ts +0 -28
  111. package/dist/types/geometry/square.d.ts.map +0 -1
  112. package/dist/types/geometry/triangle.d.ts +0 -42
  113. package/dist/types/geometry/triangle.d.ts.map +0 -1
  114. package/dist/types/index.d.ts +0 -23
  115. package/dist/types/index.d.ts.map +0 -1
  116. package/dist/types/matrices/mat3.d.ts +0 -62
  117. package/dist/types/matrices/mat3.d.ts.map +0 -1
  118. package/dist/types/matrices/mat4.d.ts +0 -89
  119. package/dist/types/matrices/mat4.d.ts.map +0 -1
  120. package/dist/types/quaternion.d.ts +0 -50
  121. package/dist/types/quaternion.d.ts.map +0 -1
  122. package/dist/types/vectors/vec2.d.ts +0 -60
  123. package/dist/types/vectors/vec2.d.ts.map +0 -1
  124. package/dist/types/vectors/vec3.d.ts +0 -58
  125. package/dist/types/vectors/vec3.d.ts.map +0 -1
@@ -1,83 +0,0 @@
1
- import { ResolveError } from "../common/error.js";
2
- import { check_number, check_number_array, check_string, has_property } from "../common/types.js";
3
- import { Vec2 } from "../vectors/vec2.js";
4
- export class Circle {
5
- radius;
6
- get perimeter() { return this.radius * Math.PI * 2; }
7
- get area() { return Math.PI * Math.pow(this.radius, 2); }
8
- position;
9
- get x() { return this.position.x; }
10
- set x(val) { this.position.x = val; }
11
- get y() { return this.position.y; }
12
- set y(val) { this.position.y = val; }
13
- get w() { return this.position.w; }
14
- set w(val) { this.position.w = val; }
15
- static resolve(a) {
16
- const value = this.cast(a);
17
- if (typeof value != "undefined")
18
- return value;
19
- throw new ResolveError("Circle", a);
20
- }
21
- static cast(a) {
22
- if (a == null || typeof a == "undefined")
23
- return undefined;
24
- if (check_number_array(a, 3))
25
- return new this([a[0], a[1]], a[2]);
26
- if (check_number_array(a, 4)) {
27
- const c = new this([a[0], a[1]], a[3]);
28
- c.w = a[2];
29
- return c;
30
- }
31
- if (has_property(a, "x", "number") && has_property(a, "y", "number") && has_property(a, "radius", "number"))
32
- return new this(has_property(a, "w", "number") ? [a.x, a.y, a.w] : [a.x, a.y], a.radius);
33
- if (check_string(a)) {
34
- const [spos, sradius] = a.split("|");
35
- const pos = Vec2.cast(spos);
36
- if (typeof pos == "undefined")
37
- return undefined;
38
- const radius = parseFloat(sradius);
39
- if (!isNaN(radius))
40
- return new this(pos, radius);
41
- }
42
- return undefined;
43
- }
44
- static is(a) {
45
- return typeof this.cast(a) != "undefined";
46
- }
47
- constructor(position, radius) {
48
- this.position = Vec2.resolve(position);
49
- if (!check_number(radius))
50
- throw new TypeError("expected number for radius");
51
- this.radius = radius;
52
- }
53
- toArray() {
54
- return [...this.position.toArray(), this.radius];
55
- }
56
- toJSON() {
57
- return {
58
- ...this.position.toJSON(),
59
- radius: this.radius
60
- };
61
- }
62
- toString() {
63
- return `${this.position.toString()}|${this.radius}`;
64
- }
65
- clone() {
66
- return new Circle(this.position.clone(), this.radius);
67
- }
68
- equals(circle) {
69
- const c = Circle.resolve(circle);
70
- return c.position.equals(c.position) && this.radius == c.radius;
71
- }
72
- inside(a) {
73
- const circle = Circle.resolve(a);
74
- const distX = circle.x - this.x;
75
- const distY = circle.y - this.y;
76
- const dist = Math.sqrt((distX * distX) + (distY + distY));
77
- return dist <= this.radius + circle.radius;
78
- }
79
- insidePoint(a) {
80
- return this.position.distance(a) <= this.radius;
81
- }
82
- }
83
- //# sourceMappingURL=circle.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"circle.js","sourceRoot":"","sources":["../../../source/geometry/circle.ts"],"names":[],"mappings":"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"}
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=object.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"object.js","sourceRoot":"","sources":["../../../source/geometry/object.ts"],"names":[],"mappings":""}
@@ -1,94 +0,0 @@
1
- import { ResolveError } from "../common/error.js";
2
- import { check_number, check_number_array, check_string, has_property } from "../common/types.js";
3
- import { Vec2 } from "../vectors/vec2.js";
4
- import { BoundingBox } from "./bbox.js";
5
- import { Square } from "./square.js";
6
- export class Rectangle {
7
- position;
8
- size;
9
- get x() { return this.position.x; }
10
- set x(val) { this.position.x = val; }
11
- get y() { return this.position.y; }
12
- set y(val) { this.position.y = val; }
13
- get w() { return this.position.w; }
14
- set w(val) { this.position.w = val; }
15
- get width() { return this.size.width; }
16
- set width(val) { this.size.width = val; }
17
- get height() { return this.size.height; }
18
- set height(val) { this.size.height = val; }
19
- static resolve(a) {
20
- const value = this.cast(a);
21
- if (typeof value != "undefined")
22
- return value;
23
- throw new ResolveError("Rectangle", a);
24
- }
25
- static cast(a) {
26
- if (a == null || typeof a == "undefined")
27
- return undefined;
28
- if (check_number_array(a, 4))
29
- return new this(a[0], a[1], a[2], a[3]);
30
- if (check_number_array(a, 5)) {
31
- const rect = new this(a[0], a[1], a[3], a[4]);
32
- rect.w = a[2];
33
- return rect;
34
- }
35
- if (check_string(a)) {
36
- const [spos, ssize] = a.split("|");
37
- const pos = Vec2.cast(spos);
38
- const size = Square.cast(ssize);
39
- if (typeof pos == "undefined" || typeof size == "undefined")
40
- return undefined;
41
- const rect = new this(pos.x, pos.y, size.width, size.height);
42
- rect.w = pos.w;
43
- return rect;
44
- }
45
- if (has_property(a, "x", "number") && has_property(a, "y", "number") && has_property(a, "width", "number") && has_property(a, "height", "number")) {
46
- const rect = new this(a.x, a.y, a.width, a.height);
47
- if (has_property(a, "w", "number"))
48
- rect.w = a.w;
49
- return rect;
50
- }
51
- return undefined;
52
- }
53
- static is(a) {
54
- return typeof this.cast(a) != "undefined";
55
- }
56
- constructor(a, b, c, d) {
57
- const vec = Vec2.is(a) ? Vec2.resolve(a) : undefined;
58
- const size = Square.is(b) ? Square.resolve(b) : undefined;
59
- const x = typeof a == "number" ? a : vec?.x;
60
- if (!check_number(x))
61
- throw new TypeError("expected number for x position");
62
- const y = typeof b == "number" ? b : vec?.y;
63
- if (!check_number(y))
64
- throw new TypeError("expected number for y position");
65
- const width = typeof c == "number" ? c : size?.width;
66
- if (!check_number(width))
67
- throw new TypeError("expected number for width");
68
- const height = typeof d == "number" ? d : size?.height;
69
- if (!check_number(height))
70
- throw new TypeError("expected number for height");
71
- this.position = new Vec2(x, y);
72
- this.size = new Square(width, height);
73
- }
74
- toArray(w = false) {
75
- return [...this.position.toArray(w), ...this.size.toArray()];
76
- }
77
- toString(w = false) {
78
- return `${this.position.toString(w)}|${this.size.toString()}`;
79
- }
80
- toJSON() {
81
- return { ...this.position.toJSON(), ...this.size.toJSON() };
82
- }
83
- toBoundingBox() {
84
- return new BoundingBox(this.x, this.x + this.width, this.y, this.y + this.height);
85
- }
86
- clone() {
87
- return new Rectangle(this.position.clone(), this.size.clone());
88
- }
89
- equals(rectangle) {
90
- const rect = Rectangle.resolve(rectangle);
91
- return this.position.equals(rect.position) && this.size.equals(rect.size);
92
- }
93
- }
94
- //# sourceMappingURL=rectangle.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"rectangle.js","sourceRoot":"","sources":["../../../source/geometry/rectangle.ts"],"names":[],"mappings":"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"}
@@ -1,66 +0,0 @@
1
- import { ResolveError } from "../common/error.js";
2
- import { check_number, check_number_array, check_string, has_property } from "../common/types.js";
3
- import { Vec2 } from "../vectors/vec2.js";
4
- export class Square {
5
- width;
6
- height;
7
- get aspectRatio() { return this.height / this.width; }
8
- get area() { return this.width * this.height; }
9
- get perimeter() { return this.width + this.width + this.height + this.height; }
10
- static resolve(a) {
11
- const value = this.cast(a);
12
- if (typeof value != "undefined")
13
- return value;
14
- throw new ResolveError("Square", a);
15
- }
16
- static cast(a) {
17
- if (a == null || typeof a == "undefined")
18
- return undefined;
19
- if (check_number_array(a, 2))
20
- return new this(a[0], a[1]);
21
- if (has_property(a, "width", "number") && has_property(a, "height", "number"))
22
- return new this(a.width, a.height);
23
- if (check_string(a)) {
24
- const parts = a.split("x").map((v) => parseFloat(v));
25
- if (check_number_array(parts, 2))
26
- return this.cast(parts);
27
- }
28
- if (check_number(a))
29
- return new this(a, a);
30
- return undefined;
31
- }
32
- static is(a) {
33
- return typeof this.cast(a) != "undefined";
34
- }
35
- constructor(width, height) {
36
- if (!check_number(width))
37
- throw new TypeError("expected number for width");
38
- if (!check_number(height))
39
- throw new TypeError("expected number for height");
40
- this.width = width;
41
- this.height = height;
42
- }
43
- toArray() {
44
- return [this.width, this.height];
45
- }
46
- toString() {
47
- return `${this.width}x${this.height}`;
48
- }
49
- toJSON() {
50
- return {
51
- width: this.width,
52
- height: this.height
53
- };
54
- }
55
- clone() {
56
- return new Square(this.width, this.height);
57
- }
58
- equals(square) {
59
- const s = Square.resolve(square);
60
- return this.width == s.width && this.height == s.height;
61
- }
62
- toVector() {
63
- return new Vec2(this.width, this.height);
64
- }
65
- }
66
- //# sourceMappingURL=square.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"square.js","sourceRoot":"","sources":["../../../source/geometry/square.ts"],"names":[],"mappings":"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"}
@@ -1,59 +0,0 @@
1
- import { Vec2 } from "../vectors/vec2.js";
2
- import { Vec3 } from "../vectors/vec3.js";
3
- export class ATriangle {
4
- A;
5
- B;
6
- C;
7
- constructor(A, B, C) {
8
- this.A = A;
9
- this.B = B;
10
- this.C = C;
11
- }
12
- get alpha() {
13
- return Math.acos((this.b * this.b + this.c * this.c - this.a * this.a) / (2 * this.b * this.c));
14
- }
15
- get beta() {
16
- return Math.acos((this.c * this.c + this.a * this.a - this.b * this.b) / (2 * this.c * this.a));
17
- }
18
- get gamma() {
19
- return Math.acos((this.a * this.a + this.b * this.b - this.c * this.c) / (2 * this.a * this.b));
20
- }
21
- get perimeter() {
22
- return this.a + this.b + this.c;
23
- }
24
- get semiperimeter() {
25
- return this.perimeter / 2;
26
- }
27
- get area() {
28
- return Math.sqrt(this.semiperimeter * (this.semiperimeter - this.a) * (this.semiperimeter - this.b) * (this.semiperimeter - this.c));
29
- }
30
- get base() {
31
- return 2 * (this.area / (this.a * Math.sin(this.gamma)));
32
- }
33
- get height() {
34
- return 2 * (this.area / this.base);
35
- }
36
- }
37
- export class Triangle2D extends ATriangle {
38
- get a() {
39
- return Vec2.fromPoints(this.B, this.C).length();
40
- }
41
- get b() {
42
- return Vec2.fromPoints(this.A, this.C).length();
43
- }
44
- get c() {
45
- return Vec2.fromPoints(this.A, this.B).length();
46
- }
47
- }
48
- export class Triangle3D extends ATriangle {
49
- get a() {
50
- return Vec3.fromPoints(this.B, this.C).length();
51
- }
52
- get b() {
53
- return Vec3.fromPoints(this.A, this.C).length();
54
- }
55
- get c() {
56
- return Vec3.fromPoints(this.A, this.B).length();
57
- }
58
- }
59
- //# sourceMappingURL=triangle.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"triangle.js","sourceRoot":"","sources":["../../../source/geometry/triangle.ts"],"names":[],"mappings":"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"}
package/dist/esm/index.js DELETED
@@ -1,40 +0,0 @@
1
- export * from "./algebra/function.js";
2
- export * from "./algebra/linear.js";
3
- export * from "./algebra/quad.js";
4
- export * from "./common/error.js";
5
- export * from "./common/sign.js";
6
- export * from "./common/types.js";
7
- export * from "./geometry/angle.js";
8
- export * from "./geometry/bbox.js";
9
- export * from "./geometry/circle.js";
10
- export * from "./geometry/object.js";
11
- export * from "./geometry/rectangle.js";
12
- export * from "./geometry/square.js";
13
- export * from "./geometry/triangle.js";
14
- export * from "./matrices/mat3.js";
15
- export * from "./matrices/mat4.js";
16
- export * from "./vectors/vec2.js";
17
- export * from "./vectors/vec3.js";
18
- export * from "./quaternion.js";
19
- export * from "./color.js";
20
- export function log_hypot(a, b) {
21
- const a_abs = Math.abs(a);
22
- const b_abs = Math.abs(b);
23
- if (a == 0)
24
- return Math.log(b_abs);
25
- if (b == 0)
26
- return Math.log(a_abs);
27
- if (a_abs < 3000 && b_abs < 3000)
28
- return 0.5 * Math.log(a * a + b * b);
29
- const _a = a / 2, _b = b / 2;
30
- return 0.5 * Math.log(_a * _a + _b * _b) + Math.LN2;
31
- }
32
- export function clamp(value, min, max) {
33
- if (value <= min)
34
- return min;
35
- if (value >= max)
36
- return max;
37
- return value;
38
- }
39
- export const EPSILON = 1e-16;
40
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../source/index.ts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAA;AAClC,cAAc,kBAAkB,CAAA;AAChC,cAAc,gBAAgB,CAAA;AAC9B,cAAc,gBAAgB,CAAA;AAC9B,cAAc,eAAe,CAAA;AAC7B,cAAc,gBAAgB,CAAA;AAC9B,cAAc,kBAAkB,CAAA;AAChC,cAAc,iBAAiB,CAAA;AAC/B,cAAc,mBAAmB,CAAA;AACjC,cAAc,mBAAmB,CAAA;AACjC,cAAc,sBAAsB,CAAA;AACpC,cAAc,mBAAmB,CAAA;AACjC,cAAc,qBAAqB,CAAA;AACnC,cAAc,iBAAiB,CAAA;AAC/B,cAAc,iBAAiB,CAAA;AAC/B,cAAc,gBAAgB,CAAA;AAC9B,cAAc,gBAAgB,CAAA;AAC9B,cAAc,cAAc,CAAA;AAC5B,cAAc,SAAS,CAAA;AAEvB,MAAM,UAAU,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;AAED,MAAM,UAAU,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;AAED,MAAM,CAAC,MAAM,OAAO,GAAG,KAAK,CAAA"}
@@ -1,198 +0,0 @@
1
- import { ResolveError } from "../common/error.js";
2
- import { check_array, check_number, check_number_array, check_string, check_string_array, has_property } from "../common/types.js";
3
- import { Vec2 } from "../vectors/vec2.js";
4
- import { Mat4 } from "./mat4.js";
5
- export class Mat3 {
6
- _raw;
7
- get m00() { return this._raw[0]; }
8
- set m00(val) { this._raw[0] = val; }
9
- get m01() { return this._raw[1]; }
10
- set m01(val) { this._raw[1] = val; }
11
- get m02() { return this._raw[2]; }
12
- set m02(val) { this._raw[2] = val; }
13
- get m10() { return this._raw[3]; }
14
- set m10(val) { this._raw[3] = val; }
15
- get m11() { return this._raw[4]; }
16
- set m11(val) { this._raw[4] = val; }
17
- get m12() { return this._raw[5]; }
18
- set m12(val) { this._raw[5] = val; }
19
- get m20() { return this._raw[6]; }
20
- set m20(val) { this._raw[6] = val; }
21
- get m21() { return this._raw[7]; }
22
- set m21(val) { this._raw[7] = val; }
23
- get m22() { return this._raw[8]; }
24
- set m22(val) { this._raw[8] = val; }
25
- static resolve(a) {
26
- const value = this.cast(a);
27
- if (typeof value != "undefined")
28
- return value;
29
- throw new ResolveError("Mat3", a);
30
- }
31
- static cast(a) {
32
- if (a == null || typeof a == "undefined")
33
- return undefined;
34
- if (check_number_array(a, 9)) {
35
- return new this(a);
36
- }
37
- if (check_array(a, undefined, 3)) {
38
- const row0 = a[0], row1 = a[1], row2 = a[2];
39
- if (check_number_array(row0, 3) && check_number_array(row1, 3) && check_number_array(row2, 3))
40
- return new this([
41
- row0[0], row0[1], row0[2],
42
- row1[0], row1[1], row1[2],
43
- row2[0], row2[1], row2[2],
44
- ]);
45
- }
46
- if (check_string(a)) {
47
- const parts = a.split(",");
48
- if (check_string_array(parts, 9))
49
- return this.cast(parts.map((i) => parseFloat(i)));
50
- }
51
- if (has_property(a, "m00", "number") && has_property(a, "m01", "number") && has_property(a, "m02", "number") &&
52
- has_property(a, "m10", "number") && has_property(a, "m11", "number") && has_property(a, "m12", "number") &&
53
- has_property(a, "m20", "number") && has_property(a, "m21", "number") && has_property(a, "m22", "number"))
54
- return new this([
55
- a.m00, a.m01, a.m02,
56
- a.m10, a.m11, a.m12,
57
- a.m20, a.m21, a.m22
58
- ]);
59
- if (check_number(a)) {
60
- return new this([a, a, a, a, a, a, a, a, a]);
61
- }
62
- return undefined;
63
- }
64
- static is(a) {
65
- return typeof this.cast(a) != "undefined";
66
- }
67
- static projection(width, height) {
68
- return new this([
69
- 2 / width, 0, 0,
70
- 0, -2 / height, 0,
71
- -1, 1, 1
72
- ]);
73
- }
74
- constructor(init = [1, 0, 0, 0, 1, 0, 0, 0, 1]) {
75
- if (!check_number_array(init, 9))
76
- throw new TypeError("expected a number array with 9 elements");
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
- equals(mat) {
111
- const m = Mat3.resolve(mat);
112
- for (let index = 0; index < this._raw.length; index++)
113
- if (this._raw[index] != m._raw[index])
114
- return false;
115
- return true;
116
- }
117
- add(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
- subtract(mat) {
125
- const b = Mat3.resolve(mat);
126
- const m = new Mat3;
127
- for (let index = 0; index < this._raw.length; index++)
128
- m._raw[index] = this._raw[index] - b._raw[index];
129
- return this;
130
- }
131
- multiply(a) {
132
- if (check_number(a))
133
- return new Mat3([
134
- this.m00 * a, this.m01 * a, this.m02 * a,
135
- this.m10 * a, this.m11 * a, this.m12 * a,
136
- this.m20 * a, this.m21 * a, this.m22 * a
137
- ]);
138
- const b = Mat3.resolve(a);
139
- return new Mat3([
140
- b.m00 * this.m00 + b.m01 * this.m10 + b.m02 * this.m20,
141
- b.m00 * this.m01 + b.m01 * this.m11 + b.m02 * this.m21,
142
- b.m00 * this.m02 + b.m01 * this.m12 + b.m02 * this.m22,
143
- b.m10 * this.m00 + b.m11 * this.m10 + b.m12 * this.m20,
144
- b.m10 * this.m01 + b.m11 * this.m11 + b.m12 * this.m21,
145
- b.m10 * this.m02 + b.m11 * this.m12 + b.m12 * this.m22,
146
- b.m20 * this.m00 + b.m21 * this.m10 + b.m22 * this.m20,
147
- b.m20 * this.m01 + b.m21 * this.m11 + b.m22 * this.m21,
148
- b.m20 * this.m02 + b.m21 * this.m12 + b.m22 * this.m22
149
- ]);
150
- }
151
- translate(...args) {
152
- const vec = Vec2.resolveArgs(args);
153
- return this.multiply([
154
- 1, 0, 0,
155
- 0, 1, 0,
156
- vec.x, vec.y, 1
157
- ]);
158
- }
159
- rotate(angle) {
160
- const c = Math.cos(angle);
161
- const s = Math.sin(angle);
162
- return this.multiply([
163
- c, -s, 0,
164
- s, c, 0,
165
- 0, 0, 1
166
- ]);
167
- }
168
- scale(...args) {
169
- const vec = Vec2.resolve(args);
170
- return this.multiply([
171
- vec.x, 0, 0,
172
- 0, vec.y, 0,
173
- 0, 0, 1
174
- ]);
175
- }
176
- determinant() {
177
- return this.m00 * this.m11 * this.m22 - this.m21 * this.m12 -
178
- this.m01 * this.m10 * this.m22 - this.m12 * this.m20 +
179
- this.m02 * this.m10 * this.m21 - this.m11 * this.m20;
180
- }
181
- inverse() {
182
- const det = this.determinant();
183
- return new Mat3([
184
- (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,
185
- (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,
186
- (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
187
- ]);
188
- }
189
- toMat4() {
190
- return new Mat4([
191
- this.m00, this.m01, 0, this.m02,
192
- this.m10, this.m11, 0, this.m12,
193
- 0, 0, 1, 0,
194
- this.m20, this.m20, 0, this.m22,
195
- ]);
196
- }
197
- }
198
- //# sourceMappingURL=mat3.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"mat3.js","sourceRoot":"","sources":["../../../source/matrices/mat3.ts"],"names":[],"mappings":"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"}