@ntf/math 1.1.3 → 1.3.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 (125) hide show
  1. package/dist/index.cjs +2536 -0
  2. package/dist/index.d.cts +738 -0
  3. package/dist/index.d.mts +738 -0
  4. package/dist/index.mjs +2489 -0
  5. package/package.json +19 -12
  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 -42
  9. package/dist/cjs/algebra/linear.js.map +0 -1
  10. package/dist/cjs/algebra/quad.js +0 -53
  11. package/dist/cjs/algebra/quad.js.map +0 -1
  12. package/dist/cjs/color.js +0 -232
  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 -87
  23. package/dist/cjs/geometry/bbox.js.map +0 -1
  24. package/dist/cjs/geometry/circle.js +0 -64
  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 -83
  29. package/dist/cjs/geometry/rectangle.js.map +0 -1
  30. package/dist/cjs/geometry/square.js +0 -66
  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 -184
  37. package/dist/cjs/matrices/mat3.js.map +0 -1
  38. package/dist/cjs/matrices/mat4.js +0 -275
  39. package/dist/cjs/matrices/mat4.js.map +0 -1
  40. package/dist/cjs/quaternion.js +0 -196
  41. package/dist/cjs/quaternion.js.map +0 -1
  42. package/dist/cjs/vectors/vec2.js +0 -154
  43. package/dist/cjs/vectors/vec2.js.map +0 -1
  44. package/dist/cjs/vectors/vec3.js +0 -161
  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 -38
  49. package/dist/esm/algebra/linear.js.map +0 -1
  50. package/dist/esm/algebra/quad.js +0 -49
  51. package/dist/esm/algebra/quad.js.map +0 -1
  52. package/dist/esm/color.js +0 -226
  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 -83
  63. package/dist/esm/geometry/bbox.js.map +0 -1
  64. package/dist/esm/geometry/circle.js +0 -60
  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 -79
  69. package/dist/esm/geometry/rectangle.js.map +0 -1
  70. package/dist/esm/geometry/square.js +0 -62
  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 -180
  77. package/dist/esm/matrices/mat3.js.map +0 -1
  78. package/dist/esm/matrices/mat4.js +0 -271
  79. package/dist/esm/matrices/mat4.js.map +0 -1
  80. package/dist/esm/quaternion.js +0 -192
  81. package/dist/esm/quaternion.js.map +0 -1
  82. package/dist/esm/vectors/vec2.js +0 -150
  83. package/dist/esm/vectors/vec2.js.map +0 -1
  84. package/dist/esm/vectors/vec3.js +0 -157
  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 -87
  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 -35
  103. package/dist/types/geometry/bbox.d.ts.map +0 -1
  104. package/dist/types/geometry/circle.d.ts +0 -26
  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 -31
  109. package/dist/types/geometry/rectangle.d.ts.map +0 -1
  110. package/dist/types/geometry/square.d.ts +0 -27
  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 -58
  117. package/dist/types/matrices/mat3.d.ts.map +0 -1
  118. package/dist/types/matrices/mat4.d.ts +0 -85
  119. package/dist/types/matrices/mat4.d.ts.map +0 -1
  120. package/dist/types/quaternion.d.ts +0 -49
  121. package/dist/types/quaternion.d.ts.map +0 -1
  122. package/dist/types/vectors/vec2.d.ts +0 -56
  123. package/dist/types/vectors/vec2.d.ts.map +0 -1
  124. package/dist/types/vectors/vec3.d.ts +0 -55
  125. package/dist/types/vectors/vec3.d.ts.map +0 -1
@@ -1 +0,0 @@
1
- {"version":3,"file":"mat4.js","sourceRoot":"","sources":["../../../source/matrices/mat4.ts"],"names":[],"mappings":"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,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;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,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"}
@@ -1,192 +0,0 @@
1
- import { ResolveError } from "./common/error.js";
2
- import { check_number_array, check_string, check_string_array, has_property } from "./common/types.js";
3
- import { EPSILON, Mat3, Mat4, log_hypot } from "./index.js";
4
- import { Vec3 } from "./vectors/vec3.js";
5
- export class Quaternion {
6
- w;
7
- x;
8
- y;
9
- z;
10
- static is(obj) {
11
- try {
12
- this.resolve(obj);
13
- return true;
14
- }
15
- catch (e) {
16
- return false;
17
- }
18
- }
19
- static resolve(a) {
20
- if (a == null || typeof a == "undefined")
21
- throw new ResolveError("Quaternion", a);
22
- if (check_number_array(a, 4))
23
- return new this(a[0], a[1], a[2], a[3]);
24
- if (has_property(a, "w", "number") && has_property(a, "x", "number") && has_property(a, "y", "number") && has_property(a, "z", "number"))
25
- return new this(a.w, a.x, a.y, a.z);
26
- if (check_string(a)) {
27
- const parts = a.replaceAll(" ", "").split("+");
28
- if (check_string_array(parts, 4)) {
29
- const [sw, sxi, syj, szk] = parts;
30
- if (sxi.endsWith("i") && syj.endsWith("j") && szk.endsWith("k"))
31
- return this.resolve([
32
- parseFloat(sw),
33
- parseFloat(sxi.substring(0, sxi.length - 1)),
34
- parseFloat(syj.substring(0, syj.length - 1)),
35
- parseFloat(szk.substring(0, szk.length - 1))
36
- ]);
37
- }
38
- }
39
- throw new ResolveError("Quaternion", a);
40
- }
41
- static fromAxisAngle(axis, angle) {
42
- const vec = Vec3.resolve(axis);
43
- const hangle = angle * 0.5;
44
- const sin2 = Math.sin(hangle);
45
- const cos2 = Math.cos(hangle);
46
- const length = sin2 / Math.sqrt(vec.x * vec.x + vec.y * vec.y + vec.z * vec.z);
47
- return new this(cos2, vec.x * length, vec.y * length, vec.z * length);
48
- }
49
- static fromEuler(...args) {
50
- const vec = Vec3.resolveArgs(args);
51
- const x2 = vec.x * 0.5, y2 = vec.y * 0.5, z2 = vec.z * 0.5;
52
- const cx = Math.cos(x2), cy = Math.cos(y2), cz = Math.cos(z2);
53
- const sx = Math.sin(x2), sy = Math.sin(y2), sz = Math.sin(z2);
54
- return new Quaternion(cx * cy * cz - sx * sy * sz, sx * cy * cz - sy * sz * cx, sy * cx * cz - sx * sz * cy, sx * sy * cz + sz * cx * cy);
55
- }
56
- constructor(w = 0, x = 0, y = 0, z = 0) {
57
- this.w = w;
58
- this.x = x;
59
- this.y = y;
60
- this.z = z;
61
- }
62
- toArray() {
63
- return [this.w, this.x, this.y, this.z];
64
- }
65
- toString() {
66
- return `${this.w} + ${this.x}i + ${this.y}j + ${this.z}k`;
67
- }
68
- toJSON() {
69
- return {
70
- w: this.w, x: this.x, y: this.y, z: this.z
71
- };
72
- }
73
- clone() {
74
- return new Quaternion(this.w, this.x, this.y, this.z);
75
- }
76
- add(a) {
77
- const quat = Quaternion.resolve(a);
78
- return new Quaternion(this.w + quat.w, this.x + quat.x, this.y + quat.y, this.z + quat.z);
79
- }
80
- offset(a) {
81
- const quat = Quaternion.resolve(a);
82
- this.w += quat.w;
83
- this.x += quat.x;
84
- this.y += quat.y;
85
- this.z += quat.z;
86
- return this;
87
- }
88
- subtract(a) {
89
- const quat = Quaternion.resolve(a);
90
- return new Quaternion(this.w - quat.w, this.x - quat.x, this.y - quat.y, this.z - quat.z);
91
- }
92
- negative() {
93
- return new Quaternion(-this.w, -this.x, -this.y, -this.z);
94
- }
95
- length(sqrt = true) {
96
- const value = this.w * this.w + this.x * this.x + this.y * this.y + this.z * this.z;
97
- return sqrt ? Math.sqrt(value) : value;
98
- }
99
- normalize() {
100
- let length = this.length();
101
- if (length < EPSILON)
102
- return new Quaternion();
103
- length = 1 / length;
104
- return new Quaternion(this.w * length, this.x * length, this.y * length, this.z * length);
105
- }
106
- multiply(a) {
107
- const quat = Quaternion.resolve(a);
108
- return new Quaternion(this.w * quat.w - this.x * quat.x - this.y * quat.y - this.z * quat.z, this.w * quat.x + this.x * quat.w + this.y * quat.z - this.z * quat.y, this.w * quat.y + this.y * quat.w + this.z * quat.x - this.x * quat.z, this.w * quat.z + this.z * quat.w + this.x * quat.y - this.y * quat.x);
109
- }
110
- multiplyVector(...args) {
111
- const vec = Vec3.resolveArgs(args);
112
- const ix = this.w * vec.x + this.y * vec.y - this.z * vec.y;
113
- const iy = this.w * vec.y + this.z * vec.x - this.x * vec.z;
114
- const iz = this.w * vec.z + this.x * vec.y - this.y * vec.x;
115
- const iw = -this.w * vec.x - this.y * vec.y - this.z * vec.z;
116
- return new Vec3(ix * this.w + iw * -this.x + iy * -this.z - iz * -this.y, iy * this.w + iw * -this.y + iz * -this.x - ix * -this.z, iz * this.w + iw * -this.z + ix * -this.y - iy * -this.x);
117
- }
118
- scale(scalar) {
119
- return new Quaternion(this.w * scalar, this.x * scalar, this.y * scalar, this.z * scalar);
120
- }
121
- dot(a) {
122
- const quat = Quaternion.resolve(a);
123
- return this.w * quat.w + this.x * quat.x + this.y * quat.y + this.z * quat.z;
124
- }
125
- inverse() {
126
- let length = this.length(false);
127
- if (length == 0)
128
- return new Quaternion();
129
- length = 1 / length;
130
- return new Quaternion(this.w * length, -this.x * length, -this.y * length, -this.z * length);
131
- }
132
- divide(a) {
133
- const quat = Quaternion.resolve(a);
134
- let length = quat.length(false);
135
- if (length == 0)
136
- return new Quaternion();
137
- length = 1 / length;
138
- return new Quaternion((this.w * quat.w + this.x * quat.x + this.y * quat.y + this.z * quat.z) * length, (this.x * quat.w - this.w * quat.x - this.y * quat.z + this.z * quat.y) * length, (this.y * quat.w - this.w * quat.y - this.z * quat.x + this.x * quat.z) * length, (this.z * quat.w - this.w * quat.z - this.x * quat.y + this.y * quat.x) * length);
139
- }
140
- conjugate() {
141
- return new Quaternion(this.w, -this.x, -this.y, -this.z);
142
- }
143
- exp() {
144
- const length = Math.sqrt(this.x * this.x + this.y * this.y + this.z * this.z);
145
- const exp = Math.exp(this.w);
146
- const scale = exp * Math.sin(length) / length;
147
- if (length == 0)
148
- return new Quaternion(exp);
149
- return new Quaternion(exp * Math.cos(length), this.x * scale, this.y * scale, this.z * scale);
150
- }
151
- log() {
152
- if (this.x == 0 && this.z == 0)
153
- return new Quaternion(log_hypot(this.w, this.x), Math.atan2(this.x, this.w));
154
- const length = this.length(false);
155
- const length2 = Math.sqrt(this.x * this.x + this.y * this.y + this.z * this.z);
156
- const scale = Math.atan2(length2, this.w) / length;
157
- return new Quaternion(Math.log(length) * 0.5, this.x * scale, this.y * scale, this.z * scale);
158
- }
159
- toVector() {
160
- return new Vec3(this.x, this.y, this.z, this.w);
161
- }
162
- toAxisAngle() {
163
- const sin2 = 1 - this.w * this.w;
164
- if (sin2 > EPSILON)
165
- return new Vec3(this.x, this.y, this.z, 0);
166
- const isin = 1 / Math.sqrt(sin2);
167
- const angle = 2 * Math.acos(this.w);
168
- return new Vec3(this.x * isin, this.y * isin, this.z * isin, angle);
169
- }
170
- toEuler() {
171
- function asin(t) {
172
- return t >= 1 ? Math.PI / 2 : (t <= -1 ? -Math.PI / 2 : Math.asin(t));
173
- }
174
- return new Vec3(-Math.atan2(2 * (this.y * this.z - this.w * this.x), 1 - 2 * (this.x * this.x + this.y * this.y)), asin(2 * (this.x * this.z + this.w * this.y)), -Math.atan2(2 * (this.x * this.y - this.w * this.z), 1 - 2 * (this.y * this.y + this.z * this.z)));
175
- }
176
- toMat3() {
177
- return new Mat3([
178
- 1 - 2 * (this.y * this.y + this.z * this.z), 2 * (this.x * this.y - this.w * this.z), 2 * (this.x * this.z + this.w * this.y),
179
- 2 * (this.x * this.y + this.w * this.z), 1 - 2 * (this.x * this.x + this.z * this.z), 2 * (this.y * this.z - this.w * this.x),
180
- 2 * (this.x * this.z - this.w * this.y), 2 * (this.y * this.z + this.w * this.x), 1 - 2 * (this.x * this.x + this.y * this.y)
181
- ]);
182
- }
183
- toMat4() {
184
- return new Mat4([
185
- 1 - 2 * (this.y * this.y + this.z * this.z), 2 * (this.x * this.y - this.w * this.z), 2 * (this.x * this.z + this.w * this.y), 0,
186
- 2 * (this.x * this.y + this.w * this.z), 1 - 2 * (this.x * this.x + this.z * this.z), 2 * (this.y * this.z - this.w * this.x), 0,
187
- 2 * (this.x * this.z - this.w * this.y), 2 * (this.y * this.z + this.w * this.x), 1 - 2 * (this.x * this.x + this.y * this.y), 0,
188
- 0, 0, 0, 1
189
- ]);
190
- }
191
- }
192
- //# sourceMappingURL=quaternion.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"quaternion.js","sourceRoot":"","sources":["../../source/quaternion.ts"],"names":[],"mappings":"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CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC,EAAC,CAAC,GAAC,CAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC,EAAC,CAAC,GAAC,CAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC,EAAC,CAAC;YACnG,CAAC,GAAC,CAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC,EAAC,CAAC,GAAC,CAAC,GAAC,CAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC,EAAC,CAAC,GAAC,CAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC,EAAC,CAAC;YACnG,CAAC,GAAC,CAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC,EAAC,CAAC,GAAC,CAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC,EAAC,CAAC,GAAC,CAAC,GAAC,CAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC,EAAC,CAAC;YACnG,CAAC,EAAC,CAAC,EAAC,CAAC,EAAC,CAAC;SACV,CAAC,CAAA;IACN,CAAC;CACJ"}
@@ -1,150 +0,0 @@
1
- import { ResolveError } from "../common/error.js";
2
- import { check_number_array, check_number, check_string, check_string_array, has_property } from "../common/types.js";
3
- import { Square } from "../geometry/square.js";
4
- import { clamp } from "../index.js";
5
- export class Vec2 {
6
- x;
7
- y;
8
- w;
9
- static resolve(a) {
10
- if (a == null || typeof a == "undefined")
11
- throw new ResolveError("Vec2", a);
12
- if (check_number_array(a, 2) || check_number_array(a, 3))
13
- return new this(a[0], a[1], check_number(a[2]) ? a[2] : undefined);
14
- if (has_property(a, "x", "number") && has_property(a, "y", "number"))
15
- return new this(a.x, a.y, has_property(a, "w", "number") ? a.w : undefined);
16
- if (check_string(a)) {
17
- const [sxy, sw] = a.split(";");
18
- if (check_string(sxy)) {
19
- const parts = sxy.split(",");
20
- if (check_string_array(parts, 2))
21
- return new this(parseFloat(parts[0]), parseFloat(parts[1]), check_string(sw) ? parseFloat(sw) : undefined);
22
- }
23
- }
24
- if (check_number(a))
25
- return new this(a, a);
26
- throw new ResolveError("Vec2", a);
27
- }
28
- static resolveArgs(args) {
29
- if (check_number_array(args, 2))
30
- return new this(args[0], args[1]);
31
- return this.resolve(args[0]);
32
- }
33
- static is(a) {
34
- try {
35
- this.resolve(a);
36
- }
37
- catch (e) {
38
- return false;
39
- }
40
- return true;
41
- }
42
- static fromPoints(a, b) {
43
- const veca = this.resolve(a);
44
- const vecb = this.resolve(b);
45
- return new this(vecb.x - veca.x, vecb.y - veca.y);
46
- }
47
- static clamp(value, min, max) {
48
- const a = this.resolve(value), b = this.resolve(min), c = this.resolve(max);
49
- return new this(clamp(a.x, b.x, c.x), clamp(a.y, b.y, c.y));
50
- }
51
- constructor(x = 0, y = 0, w = 1) {
52
- this.x = x;
53
- this.y = y;
54
- this.w = w;
55
- }
56
- toArray(w = false) {
57
- return w ? [this.x, this.y] : [this.x, this.y, this.w];
58
- }
59
- toJSON() {
60
- return {
61
- x: this.x, y: this.y, w: this.w
62
- };
63
- }
64
- toString(w = false) {
65
- return w ? `${this.x},${this.y}` : `${this.x},${this.y};${this.w}`;
66
- }
67
- toSquare() {
68
- return new Square(this.x, this.y);
69
- }
70
- clone() {
71
- return new Vec2(this.x, this.y, this.w);
72
- }
73
- setX(x) {
74
- this.x = x;
75
- return this;
76
- }
77
- setY(y) {
78
- this.y = y;
79
- return this;
80
- }
81
- setW(w) {
82
- this.w = w;
83
- return this;
84
- }
85
- set(...args) {
86
- const vec = Vec2.resolveArgs(args);
87
- return this.setX(vec.x).setY(vec.y);
88
- }
89
- add(...args) {
90
- const vec = Vec2.resolveArgs(args);
91
- return new Vec2(this.x + vec.x, this.y + vec.y);
92
- }
93
- offset(...args) {
94
- const vec = Vec2.resolveArgs(args);
95
- this.x += vec.x;
96
- this.y += vec.y;
97
- return this;
98
- }
99
- subtract(...args) {
100
- const vec = Vec2.resolveArgs(args);
101
- return new Vec2(this.x - vec.x, this.y - vec.y);
102
- }
103
- multiply(scalar) {
104
- return new Vec2(this.x * scalar, this.y * scalar);
105
- }
106
- naiveMultiply(...args) {
107
- const vec = Vec2.resolveArgs(args);
108
- return new Vec2(this.x * vec.x, this.y * vec.y);
109
- }
110
- divide(...args) {
111
- if (check_number_array(args, 1))
112
- return new Vec2(this.x / args[0], this.y / args[0]);
113
- const vec = Vec2.resolveArgs(args);
114
- return new Vec2(this.x / vec.x, this.y / vec.y);
115
- }
116
- dot(...args) {
117
- const vec = Vec2.resolveArgs(args);
118
- return this.x * vec.x + this.y * vec.y;
119
- }
120
- distance(...args) {
121
- const vec = Vec2.resolveArgs(args);
122
- return Math.pow(vec.x - this.x, 2) + Math.pow(vec.y - this.y, 2);
123
- }
124
- distanceSquare(...args) {
125
- const vec = Vec2.resolveArgs(args);
126
- return Math.sqrt(Math.pow(vec.x - this.x, 2) + Math.pow(vec.y - this.y, 2));
127
- }
128
- length() {
129
- return Math.sqrt(this.x * this.x + this.y * this.y);
130
- }
131
- cartesianify() {
132
- return new Vec2(this.x * Math.cos(this.y), this.x * Math.sin(this.y));
133
- }
134
- polarify() {
135
- return new Vec2(Math.sqrt(this.x * this.x + this.y * this.y), Math.atan(this.y / this.x));
136
- }
137
- normalize() {
138
- const length = this.length();
139
- if (length == 0)
140
- return new Vec2;
141
- return new Vec2(this.x / length, this.y / length);
142
- }
143
- invert() {
144
- return this.multiply(-1);
145
- }
146
- round() {
147
- return new Vec2(Math.round(this.x), Math.round(this.y), Math.round(this.w));
148
- }
149
- }
150
- //# sourceMappingURL=vec2.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"vec2.js","sourceRoot":"","sources":["../../../source/vectors/vec2.ts"],"names":[],"mappings":"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"}
@@ -1,157 +0,0 @@
1
- import { ResolveError } from "../common/error.js";
2
- import { check_number_array, check_number, check_string, check_string_array, has_property } from "../common/types.js";
3
- import { clamp } from "../index.js";
4
- export class Vec3 {
5
- x;
6
- y;
7
- z;
8
- w;
9
- static resolve(a) {
10
- if (a == null || typeof a == "undefined")
11
- throw new ResolveError("Vec3", a);
12
- if (check_number_array(a, 3) || check_number_array(a, 4))
13
- return new this(a[0], a[1], a[2], check_number(a[3]) ? a[3] : undefined);
14
- if (has_property(a, "x", "number") && has_property(a, "y", "number") && has_property(a, "z", "number"))
15
- return new this(a.x, a.y, a.z, has_property(a, "w", "number") ? a.w : undefined);
16
- if (check_string(a)) {
17
- const [sxyz, sw] = a.split(";");
18
- if (check_string(sxyz)) {
19
- const parts = sxyz.split(",");
20
- if (check_string_array(parts, 3))
21
- return new this(parseFloat(parts[0]), parseFloat(parts[1]), parseFloat(parts[2]), check_string(sw) ? parseFloat(sw) : undefined);
22
- }
23
- }
24
- if (check_number(a))
25
- return new this(a, a, a);
26
- throw new ResolveError("Vec3", a);
27
- }
28
- static resolveArgs(args) {
29
- if (check_number_array(args, 3))
30
- return new this(args[0], args[1], args[2]);
31
- return this.resolve(args[0]);
32
- }
33
- static is(a) {
34
- try {
35
- this.resolve(a);
36
- }
37
- catch (e) {
38
- return false;
39
- }
40
- return true;
41
- }
42
- static fromPoints(a, b) {
43
- const veca = this.resolve(a);
44
- const vecb = this.resolve(b);
45
- return new this(vecb.x - veca.x, vecb.y - veca.y, vecb.z - veca.z);
46
- }
47
- static clamp(value, min, max) {
48
- const a = this.resolve(value), b = this.resolve(min), c = this.resolve(max);
49
- return new this(clamp(a.x, b.x, c.x), clamp(a.y, b.y, c.y), clamp(a.z, b.z, c.z));
50
- }
51
- static intersectPlane(planeP, planeN, lineStart, lineEnd, t) {
52
- planeN = this.resolve(planeN).normalize();
53
- const plane_d = -this.resolve(planeN).dot(planeP);
54
- const ad = this.resolve(lineStart).dot(planeN);
55
- const bd = this.resolve(lineEnd).dot(planeN);
56
- t = (-plane_d - ad) / (bd - ad);
57
- const lineStartToEnd = this.resolve(lineEnd).subtract(lineStart);
58
- const linetoIntersect = lineStartToEnd.multiply(t);
59
- return Vec3.resolve(lineStart).add(linetoIntersect);
60
- }
61
- constructor(x = 0, y = 0, z = 0, w = 1) {
62
- this.x = x;
63
- this.y = y;
64
- this.z = z;
65
- this.w = w;
66
- }
67
- toArray(w = false) {
68
- return w ? [this.x, this.y, this.z] : [this.x, this.y, this.z, this.w];
69
- }
70
- toJSON() {
71
- return {
72
- x: this.x, y: this.y, z: this.z, w: this.w
73
- };
74
- }
75
- toString(w = false) {
76
- return w ? `${this.x},${this.y},${this.z}` : `${this.x},${this.y},${this.z};${this.w}`;
77
- }
78
- clone() {
79
- return new Vec3(this.x, this.y, this.z, this.w);
80
- }
81
- setX(x) {
82
- this.x = x;
83
- return this;
84
- }
85
- setY(y) {
86
- this.y = y;
87
- return this;
88
- }
89
- setZ(z) {
90
- this.z = z;
91
- return this;
92
- }
93
- set(...args) {
94
- const vec = Vec3.resolveArgs(args);
95
- return this.setX(vec.x).setY(vec.y).setZ(vec.z);
96
- }
97
- add(...args) {
98
- const vec = Vec3.resolveArgs(args);
99
- return new Vec3(this.x + vec.x, this.y + vec.y, this.z + vec.z);
100
- }
101
- offset(...args) {
102
- const vec = Vec3.resolveArgs(args);
103
- this.x += vec.x;
104
- this.y += vec.y;
105
- this.z += vec.z;
106
- return this;
107
- }
108
- subtract(...args) {
109
- const vec = Vec3.resolveArgs(args);
110
- return new Vec3(this.x - vec.x, this.y - vec.y, this.z - vec.z);
111
- }
112
- multiply(scalar) {
113
- return new Vec3(this.x * scalar, this.y * scalar, this.z * scalar);
114
- }
115
- naiveMultiply(...args) {
116
- const vec = Vec3.resolveArgs(args);
117
- return new Vec3(this.x * vec.x, this.y * vec.y, this.z * vec.z);
118
- }
119
- divide(...args) {
120
- if (check_number_array(args, 1))
121
- return new Vec3(this.x / args[0], this.y / args[0], this.z / args[0]);
122
- const vec = Vec3.resolveArgs(args);
123
- return new Vec3(this.x / vec.x, this.y / vec.y, this.z / vec.z);
124
- }
125
- dot(...args) {
126
- const vec = Vec3.resolveArgs(args);
127
- return this.x * vec.x + this.y * vec.y + this.z * vec.z;
128
- }
129
- cross(...args) {
130
- const vec = Vec3.resolveArgs(args);
131
- return new Vec3(this.y * vec.z - this.z * vec.y, this.z * vec.x - this.x * vec.z, this.x * vec.y - this.y * vec.x);
132
- }
133
- distance(...args) {
134
- const vec = Vec3.resolveArgs(args);
135
- return Math.pow(vec.x - this.x, 2) + Math.pow(vec.y - this.y, 2) + Math.pow(vec.z - this.z, 2);
136
- }
137
- distanceSquare(...args) {
138
- const vec = Vec3.resolveArgs(args);
139
- return Math.sqrt(Math.pow(vec.x - this.x, 2) + Math.pow(vec.y - this.y, 2) + Math.pow(vec.z - this.z, 2));
140
- }
141
- length() {
142
- return Math.sqrt(this.x * this.x + this.y * this.y + this.z * this.z);
143
- }
144
- normalize() {
145
- const length = this.length();
146
- if (length == 0)
147
- return new Vec3;
148
- return new Vec3(this.x / length, this.y / length, this.z / length);
149
- }
150
- invert() {
151
- return this.multiply(-1);
152
- }
153
- round() {
154
- return new Vec3(Math.round(this.x), Math.round(this.y), Math.round(this.z), Math.round(this.w));
155
- }
156
- }
157
- //# sourceMappingURL=vec3.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"vec3.js","sourceRoot":"","sources":["../../../source/vectors/vec3.ts"],"names":[],"mappings":"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"}
@@ -1,6 +0,0 @@
1
- import { Vec2 } from "../vectors/vec2";
2
- export declare abstract class MathFunction<Input extends Array<number> = Array<number>> {
3
- abstract get(...args: Input): number;
4
- abstract roots(): Array<Vec2>;
5
- }
6
- //# sourceMappingURL=function.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"function.d.ts","sourceRoot":"","sources":["../../../source/algebra/function.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,iBAAiB,CAAA;AAEtC,8BAAsB,YAAY,CAAC,KAAK,SAAS,KAAK,CAAC,MAAM,CAAC,GAAG,KAAK,CAAC,MAAM,CAAC;aAE1D,GAAG,CAAC,GAAG,IAAI,EAAE,KAAK,GAAG,MAAM;aAC3B,KAAK,IAAI,KAAK,CAAC,IAAI,CAAC;CACvC"}
@@ -1,14 +0,0 @@
1
- import { Vec2Like, Vec2 } from "../vectors/vec2";
2
- import { MathFunction } from "./function";
3
- export type LinearFunctionString = `f(x) = ${number} * x ${"+" | "-"} ${number}` | `f(x) = ${number} * x`;
4
- export declare class LinearFunction extends MathFunction<[number]> {
5
- m: number;
6
- b: number;
7
- static get(m: number, b: number, x: number): number;
8
- static fromPoints(a: Vec2Like, b: Vec2Like): LinearFunction;
9
- constructor(m: number, b: number);
10
- get(x: number): number;
11
- roots(): Array<Vec2>;
12
- toString(): LinearFunctionString;
13
- }
14
- //# sourceMappingURL=linear.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"linear.d.ts","sourceRoot":"","sources":["../../../source/algebra/linear.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,iBAAiB,CAAA;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAA;AAEzC,MAAM,MAAM,oBAAoB,GAAG,UAAU,MAAM,QAAQ,GAAG,GAAG,GAAG,IAAI,MAAM,EAAE,GAAG,UAAU,MAAM,MAAM,CAAA;AAEzG,qBAAa,cAAe,SAAQ,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC;IAc5B,CAAC,EAAE,MAAM;IAAQ,CAAC,EAAE,MAAM;WAZtC,GAAG,CAAC,CAAC,EAAE,MAAM,EAAC,CAAC,EAAE,MAAM,EAAC,CAAC,EAAE,MAAM;WAIjC,UAAU,CAAC,CAAC,EAAE,QAAQ,EAAC,CAAC,EAAE,QAAQ;gBAQtB,CAAC,EAAE,MAAM,EAAQ,CAAC,EAAE,MAAM;IAI7C,GAAG,CAAC,CAAC,EAAE,MAAM,GAAG,MAAM;IAItB,KAAK,IAAI,KAAK,CAAC,IAAI,CAAC;IAOpB,QAAQ,IAAI,oBAAoB;CAO1C"}
@@ -1,18 +0,0 @@
1
- import { Vec2 } from "../vectors/vec2";
2
- import { MathFunction } from "./function";
3
- export type QuadFunctionType = "standard";
4
- export type QuadFunctionString = {
5
- "standard": `f(x) = ${number}x^2 ${"+" | "-"} ${number}x ${"+" | "-"} ${number}` | `f(x) = ${number}x^2 ${"+" | "-"} ${number}x` | `f(x) = ${number}x^2`;
6
- };
7
- export type QuadFunctionStrings = QuadFunctionString[QuadFunctionType];
8
- export declare class QuadFunction extends MathFunction<[number]> {
9
- a: number;
10
- b: number;
11
- c: number;
12
- static get(a: number, b: number, c: number, x: number): number;
13
- constructor(a: number, b: number, c: number);
14
- get(x: number): number;
15
- roots(): Array<Vec2>;
16
- toString<T extends QuadFunctionType>(type?: T): QuadFunctionString[T];
17
- }
18
- //# sourceMappingURL=quad.d.ts.map