@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.
- package/LICENSE +21 -0
- package/README.md +41 -0
- package/dist/cjs/algebra/function.js +7 -0
- package/dist/cjs/algebra/function.js.map +1 -0
- package/dist/cjs/algebra/linear.js +42 -0
- package/dist/cjs/algebra/linear.js.map +1 -0
- package/dist/cjs/algebra/quad.js +53 -0
- package/dist/cjs/algebra/quad.js.map +1 -0
- package/dist/cjs/common/error.js +14 -0
- package/dist/cjs/common/error.js.map +1 -0
- package/dist/cjs/common/sign.js +14 -0
- package/dist/cjs/common/sign.js.map +1 -0
- package/dist/cjs/common/types.js +35 -0
- package/dist/cjs/common/types.js.map +1 -0
- package/dist/cjs/geometry/angle.js +11 -0
- package/dist/cjs/geometry/angle.js.map +1 -0
- package/dist/cjs/geometry/bbox.js +87 -0
- package/dist/cjs/geometry/bbox.js.map +1 -0
- package/dist/cjs/geometry/circle.js +64 -0
- package/dist/cjs/geometry/circle.js.map +1 -0
- package/dist/cjs/geometry/object.js +3 -0
- package/dist/cjs/geometry/object.js.map +1 -0
- package/dist/cjs/geometry/rectangle.js +77 -0
- package/dist/cjs/geometry/rectangle.js.map +1 -0
- package/dist/cjs/geometry/square.js +66 -0
- package/dist/cjs/geometry/square.js.map +1 -0
- package/dist/cjs/geometry/triangle.js +65 -0
- package/dist/cjs/geometry/triangle.js.map +1 -0
- package/dist/cjs/index.js +58 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/cjs/matrices/mat3.js +184 -0
- package/dist/cjs/matrices/mat3.js.map +1 -0
- package/dist/cjs/matrices/mat4.js +262 -0
- package/dist/cjs/matrices/mat4.js.map +1 -0
- package/dist/cjs/quaternion.js +196 -0
- package/dist/cjs/quaternion.js.map +1 -0
- package/dist/cjs/vectors/vec2.js +151 -0
- package/dist/cjs/vectors/vec2.js.map +1 -0
- package/dist/cjs/vectors/vec3.js +148 -0
- package/dist/cjs/vectors/vec3.js.map +1 -0
- package/dist/esm/algebra/function.js +3 -0
- package/dist/esm/algebra/function.js.map +1 -0
- package/dist/esm/algebra/linear.js +38 -0
- package/dist/esm/algebra/linear.js.map +1 -0
- package/dist/esm/algebra/quad.js +49 -0
- package/dist/esm/algebra/quad.js.map +1 -0
- package/dist/esm/common/error.js +10 -0
- package/dist/esm/common/error.js.map +1 -0
- package/dist/esm/common/sign.js +10 -0
- package/dist/esm/common/sign.js.map +1 -0
- package/dist/esm/common/types.js +26 -0
- package/dist/esm/common/types.js.map +1 -0
- package/dist/esm/geometry/angle.js +5 -0
- package/dist/esm/geometry/angle.js.map +1 -0
- package/dist/esm/geometry/bbox.js +83 -0
- package/dist/esm/geometry/bbox.js.map +1 -0
- package/dist/esm/geometry/circle.js +60 -0
- package/dist/esm/geometry/circle.js.map +1 -0
- package/dist/esm/geometry/object.js +2 -0
- package/dist/esm/geometry/object.js.map +1 -0
- package/dist/esm/geometry/rectangle.js +73 -0
- package/dist/esm/geometry/rectangle.js.map +1 -0
- package/dist/esm/geometry/square.js +62 -0
- package/dist/esm/geometry/square.js.map +1 -0
- package/dist/esm/geometry/triangle.js +59 -0
- package/dist/esm/geometry/triangle.js.map +1 -0
- package/dist/esm/index.js +39 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/matrices/mat3.js +180 -0
- package/dist/esm/matrices/mat3.js.map +1 -0
- package/dist/esm/matrices/mat4.js +258 -0
- package/dist/esm/matrices/mat4.js.map +1 -0
- package/dist/esm/quaternion.js +192 -0
- package/dist/esm/quaternion.js.map +1 -0
- package/dist/esm/vectors/vec2.js +147 -0
- package/dist/esm/vectors/vec2.js.map +1 -0
- package/dist/esm/vectors/vec3.js +144 -0
- package/dist/esm/vectors/vec3.js.map +1 -0
- package/dist/types/algebra/function.d.ts +6 -0
- package/dist/types/algebra/function.d.ts.map +1 -0
- package/dist/types/algebra/linear.d.ts +14 -0
- package/dist/types/algebra/linear.d.ts.map +1 -0
- package/dist/types/algebra/quad.d.ts +18 -0
- package/dist/types/algebra/quad.d.ts.map +1 -0
- package/dist/types/common/error.d.ts +6 -0
- package/dist/types/common/error.d.ts.map +1 -0
- package/dist/types/common/sign.d.ts +2 -0
- package/dist/types/common/sign.d.ts.map +1 -0
- package/dist/types/common/types.d.ts +21 -0
- package/dist/types/common/types.d.ts.map +1 -0
- package/dist/types/geometry/angle.d.ts +5 -0
- package/dist/types/geometry/angle.d.ts.map +1 -0
- package/dist/types/geometry/bbox.d.ts +35 -0
- package/dist/types/geometry/bbox.d.ts.map +1 -0
- package/dist/types/geometry/circle.d.ts +26 -0
- package/dist/types/geometry/circle.d.ts.map +1 -0
- package/dist/types/geometry/object.d.ts +5 -0
- package/dist/types/geometry/object.d.ts.map +1 -0
- package/dist/types/geometry/rectangle.d.ts +31 -0
- package/dist/types/geometry/rectangle.d.ts.map +1 -0
- package/dist/types/geometry/square.d.ts +27 -0
- package/dist/types/geometry/square.d.ts.map +1 -0
- package/dist/types/geometry/triangle.d.ts +42 -0
- package/dist/types/geometry/triangle.d.ts.map +1 -0
- package/dist/types/index.d.ts +22 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/matrices/mat3.d.ts +58 -0
- package/dist/types/matrices/mat3.d.ts.map +1 -0
- package/dist/types/matrices/mat4.d.ts +84 -0
- package/dist/types/matrices/mat4.d.ts.map +1 -0
- package/dist/types/quaternion.d.ts +49 -0
- package/dist/types/quaternion.d.ts.map +1 -0
- package/dist/types/vectors/vec2.d.ts +55 -0
- package/dist/types/vectors/vec2.d.ts.map +1 -0
- package/dist/types/vectors/vec3.d.ts +53 -0
- package/dist/types/vectors/vec3.d.ts.map +1 -0
- package/package.json +40 -0
|
@@ -0,0 +1,192 @@
|
|
|
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
|
|
@@ -0,0 +1 @@
|
|
|
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"}
|
|
@@ -0,0 +1,147 @@
|
|
|
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))
|
|
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);
|
|
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
|
+
}
|
|
147
|
+
//# sourceMappingURL=vec2.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vec2.js","sourceRoot":"","sources":["../../../source/vectors/vec2.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,144 @@
|
|
|
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))
|
|
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
|
+
constructor(x = 0, y = 0, z = 0, w = 1) {
|
|
52
|
+
this.x = x;
|
|
53
|
+
this.y = y;
|
|
54
|
+
this.z = z;
|
|
55
|
+
this.w = w;
|
|
56
|
+
}
|
|
57
|
+
toArray(w = false) {
|
|
58
|
+
return w ? [this.x, this.y, this.z] : [this.x, this.y, this.z, this.w];
|
|
59
|
+
}
|
|
60
|
+
toJSON() {
|
|
61
|
+
return {
|
|
62
|
+
x: this.x, y: this.y, z: this.z, w: this.w
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
toString(w = false) {
|
|
66
|
+
return w ? `${this.x},${this.y},${this.z}` : `${this.x},${this.y},${this.z};${this.w}`;
|
|
67
|
+
}
|
|
68
|
+
clone() {
|
|
69
|
+
return new Vec3(this.x, this.y, this.z, this.w);
|
|
70
|
+
}
|
|
71
|
+
setX(x) {
|
|
72
|
+
this.x = x;
|
|
73
|
+
return this;
|
|
74
|
+
}
|
|
75
|
+
setY(y) {
|
|
76
|
+
this.y = y;
|
|
77
|
+
return this;
|
|
78
|
+
}
|
|
79
|
+
setZ(z) {
|
|
80
|
+
this.z = z;
|
|
81
|
+
return this;
|
|
82
|
+
}
|
|
83
|
+
set(...args) {
|
|
84
|
+
const vec = Vec3.resolveArgs(args);
|
|
85
|
+
return this.setX(vec.x).setY(vec.y).setZ(vec.z);
|
|
86
|
+
}
|
|
87
|
+
add(...args) {
|
|
88
|
+
const vec = Vec3.resolveArgs(args);
|
|
89
|
+
return new Vec3(this.x + vec.x, this.y + vec.y, this.z + vec.z);
|
|
90
|
+
}
|
|
91
|
+
offset(...args) {
|
|
92
|
+
const vec = Vec3.resolveArgs(args);
|
|
93
|
+
this.x += vec.x;
|
|
94
|
+
this.y += vec.y;
|
|
95
|
+
this.z += vec.z;
|
|
96
|
+
return this;
|
|
97
|
+
}
|
|
98
|
+
subtract(...args) {
|
|
99
|
+
const vec = Vec3.resolveArgs(args);
|
|
100
|
+
return new Vec3(this.x - vec.x, this.y - vec.y, this.z - vec.z);
|
|
101
|
+
}
|
|
102
|
+
multiply(scalar) {
|
|
103
|
+
return new Vec3(this.x * scalar, this.y * scalar, this.z * scalar);
|
|
104
|
+
}
|
|
105
|
+
naiveMultiply(...args) {
|
|
106
|
+
const vec = Vec3.resolveArgs(args);
|
|
107
|
+
return new Vec3(this.x * vec.x, this.y * vec.y, this.z * vec.z);
|
|
108
|
+
}
|
|
109
|
+
divide(...args) {
|
|
110
|
+
if (check_number_array(args, 1))
|
|
111
|
+
return new Vec3(this.x / args[0], this.y / args[0], this.z / args[0]);
|
|
112
|
+
const vec = Vec3.resolveArgs(args);
|
|
113
|
+
return new Vec3(this.x / vec.x, this.y / vec.y, this.z / vec.z);
|
|
114
|
+
}
|
|
115
|
+
dot(...args) {
|
|
116
|
+
const vec = Vec3.resolveArgs(args);
|
|
117
|
+
return this.x * vec.x + this.y * vec.y + this.z * vec.z;
|
|
118
|
+
}
|
|
119
|
+
cross(...args) {
|
|
120
|
+
const vec = Vec3.resolveArgs(args);
|
|
121
|
+
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);
|
|
122
|
+
}
|
|
123
|
+
distance(...args) {
|
|
124
|
+
const vec = Vec3.resolveArgs(args);
|
|
125
|
+
return Math.pow(vec.x - this.x, 2) + Math.pow(vec.y - this.y, 2) + Math.pow(vec.z - this.z, 2);
|
|
126
|
+
}
|
|
127
|
+
distanceSquare(...args) {
|
|
128
|
+
const vec = Vec3.resolveArgs(args);
|
|
129
|
+
return Math.sqrt(Math.pow(vec.x - this.x, 2) + Math.pow(vec.y - this.y, 2) + Math.pow(vec.z - this.z, 2));
|
|
130
|
+
}
|
|
131
|
+
length() {
|
|
132
|
+
return Math.sqrt(this.x * this.x + this.y * this.y + this.z * this.z);
|
|
133
|
+
}
|
|
134
|
+
normalize() {
|
|
135
|
+
const length = this.length();
|
|
136
|
+
if (length == 0)
|
|
137
|
+
return new Vec3;
|
|
138
|
+
return new Vec3(this.x / length, this.y / length, this.z / length);
|
|
139
|
+
}
|
|
140
|
+
invert() {
|
|
141
|
+
return this.multiply(-1);
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
//# sourceMappingURL=vec3.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vec3.js","sourceRoot":"","sources":["../../../source/vectors/vec3.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
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
|
|
@@ -0,0 +1 @@
|
|
|
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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
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
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"quad.d.ts","sourceRoot":"","sources":["../../../source/algebra/quad.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,IAAI,EAAY,MAAM,iBAAiB,CAAA;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAA;AAEzC,MAAM,MAAM,gBAAgB,GAAG,UAAU,CAAA;AACzC,MAAM,MAAM,kBAAkB,GAAG;IAC7B,UAAU,EAAE,UAAU,MAAM,OAAO,GAAG,GAAG,GAAG,IAAI,MAAM,KAAK,GAAG,GAAG,GAAG,IAAI,MAAM,EAAE,GAAG,UAAU,MAAM,OAAO,GAAG,GAAG,GAAG,IAAI,MAAM,GAAG,GAAG,UAAU,MAAM,KAAK,CAAA;CAC3J,CAAA;AACD,MAAM,MAAM,mBAAmB,GAAG,kBAAkB,CAAC,gBAAgB,CAAC,CAAA;AAEtE,qBAAa,YAAa,SAAQ,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC;IAM1B,CAAC,EAAE,MAAM;IAAQ,CAAC,EAAE,MAAM;IAAQ,CAAC,EAAE,MAAM;WAJvD,GAAG,CAAC,CAAC,EAAE,MAAM,EAAC,CAAC,EAAE,MAAM,EAAC,CAAC,EAAE,MAAM,EAAC,CAAC,EAAE,MAAM;gBAI/B,CAAC,EAAE,MAAM,EAAQ,CAAC,EAAE,MAAM,EAAQ,CAAC,EAAE,MAAM;IAM9D,GAAG,CAAC,CAAC,EAAE,MAAM,GAAG,MAAM;IAItB,KAAK,IAAI,KAAK,CAAC,IAAI,CAAC;IAepB,QAAQ,CAAC,CAAC,SAAS,gBAAgB,EAAE,IAAI,GAAE,CAAmB,GAAG,kBAAkB,CAAC,CAAC,CAAC;CAiBhG"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"error.d.ts","sourceRoot":"","sources":["../../../source/common/error.ts"],"names":[],"mappings":"AAAA,qBAAa,YAAa,SAAQ,KAAK;aAEA,MAAM,EAAE,MAAM;aAAiB,KAAK,EAAE,OAAO;gBAA7C,MAAM,EAAE,MAAM,EAAiB,KAAK,EAAE,OAAO;CAInF"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sign.d.ts","sourceRoot":"","sources":["../../../source/common/sign.ts"],"names":[],"mappings":"AAAA,wBAAgB,SAAS,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,yBAS7C"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
export type JavaScriptTypes = "string" | "number" | "bigint" | "boolean" | "symbol" | "undefined" | "object" | "function";
|
|
2
|
+
export type JavaScriptTypeMap = {
|
|
3
|
+
"string": string;
|
|
4
|
+
"number": number;
|
|
5
|
+
"bigint": bigint;
|
|
6
|
+
"boolean": boolean;
|
|
7
|
+
"symbol": symbol;
|
|
8
|
+
"undefined": undefined;
|
|
9
|
+
"object": object;
|
|
10
|
+
"function": Function;
|
|
11
|
+
};
|
|
12
|
+
export type Predicate<T> = (a: unknown) => a is T;
|
|
13
|
+
export declare function check_number(obj: unknown): obj is number;
|
|
14
|
+
export declare function check_string(obj: unknown): obj is string;
|
|
15
|
+
export declare function check_array<T>(obj: unknown, predicate?: Predicate<T>, requiredLength?: number): obj is Array<T>;
|
|
16
|
+
export declare function check_number_array(obj: unknown, requiredLength?: number): obj is Array<number>;
|
|
17
|
+
export declare function check_string_array(obj: unknown, requiredLength?: number): obj is Array<string>;
|
|
18
|
+
export declare function has_property<Obj, Name extends string, Type extends JavaScriptTypes>(obj: Obj, name: Name, type: Type): obj is Obj & {
|
|
19
|
+
[name in Name]: JavaScriptTypeMap[Type];
|
|
20
|
+
};
|
|
21
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../source/common/types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,eAAe,GAAG,QAAQ,GAAG,QAAQ,GAAG,QAAQ,GAAG,SAAS,GAAG,QAAQ,GAAG,WAAW,GAAG,QAAQ,GAAG,UAAU,CAAA;AACzH,MAAM,MAAM,iBAAiB,GAAG;IAC5B,QAAQ,EAAE,MAAM,CAAA;IAChB,QAAQ,EAAE,MAAM,CAAA;IAChB,QAAQ,EAAE,MAAM,CAAA;IAChB,SAAS,EAAE,OAAO,CAAA;IAClB,QAAQ,EAAE,MAAM,CAAA;IAChB,WAAW,EAAE,SAAS,CAAA;IACtB,QAAQ,EAAE,MAAM,CAAA;IAChB,UAAU,EAAE,QAAQ,CAAA;CACvB,CAAA;AACD,MAAM,MAAM,SAAS,CAAC,CAAC,IAAI,CAAC,CAAC,EAAE,OAAO,KAAK,CAAC,IAAI,CAAC,CAAA;AAEjD,wBAAgB,YAAY,CAAC,GAAG,EAAE,OAAO,GAAG,GAAG,IAAI,MAAM,CAGxD;AAED,wBAAgB,YAAY,CAAC,GAAG,EAAE,OAAO,GAAG,GAAG,IAAI,MAAM,CAGxD;AAED,wBAAgB,WAAW,CAAC,CAAC,EAAE,GAAG,EAAE,OAAO,EAAC,SAAS,CAAC,EAAE,SAAS,CAAC,CAAC,CAAC,EAAC,cAAc,CAAC,EAAE,MAAM,GAAG,GAAG,IAAI,KAAK,CAAC,CAAC,CAAC,CAQ7G;AAED,wBAAgB,kBAAkB,CAAC,GAAG,EAAE,OAAO,EAAC,cAAc,CAAC,EAAE,MAAM,GAAG,GAAG,IAAI,KAAK,CAAC,MAAM,CAAC,CAG7F;AAED,wBAAgB,kBAAkB,CAAC,GAAG,EAAE,OAAO,EAAC,cAAc,CAAC,EAAE,MAAM,GAAG,GAAG,IAAI,KAAK,CAAC,MAAM,CAAC,CAG7F;AAED,wBAAgB,YAAY,CAAC,GAAG,EAAC,IAAI,SAAS,MAAM,EAAC,IAAI,SAAS,eAAe,EAAE,GAAG,EAAE,GAAG,EAAC,IAAI,EAAE,IAAI,EAAC,IAAI,EAAE,IAAI,GAAG,GAAG,IAAI,GAAG,GAAG;KAAE,IAAI,IAAI,IAAI,GAAG,iBAAiB,CAAC,IAAI,CAAC;CAAC,CAGzK"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export declare const MAX_ANGLE_DEGREE = 360;
|
|
2
|
+
export declare const cap_angle_degree: (angle: number) => number;
|
|
3
|
+
export declare const radian_to_degree: (angle: number) => number;
|
|
4
|
+
export declare const degree_to_radian: (angle: number) => number;
|
|
5
|
+
//# sourceMappingURL=angle.d.ts.map
|