@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,154 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Vec2 = void 0;
4
- const error_1 = require("../common/error");
5
- const types_1 = require("../common/types");
6
- const square_1 = require("../geometry/square");
7
- const index_1 = require("../index");
8
- class Vec2 {
9
- x;
10
- y;
11
- w;
12
- static resolve(a) {
13
- if (a == null || typeof a == "undefined")
14
- throw new error_1.ResolveError("Vec2", a);
15
- if ((0, types_1.check_number_array)(a, 2) || (0, types_1.check_number_array)(a, 3))
16
- return new this(a[0], a[1], (0, types_1.check_number)(a[2]) ? a[2] : undefined);
17
- if ((0, types_1.has_property)(a, "x", "number") && (0, types_1.has_property)(a, "y", "number"))
18
- return new this(a.x, a.y, (0, types_1.has_property)(a, "w", "number") ? a.w : undefined);
19
- if ((0, types_1.check_string)(a)) {
20
- const [sxy, sw] = a.split(";");
21
- if ((0, types_1.check_string)(sxy)) {
22
- const parts = sxy.split(",");
23
- if ((0, types_1.check_string_array)(parts, 2))
24
- return new this(parseFloat(parts[0]), parseFloat(parts[1]), (0, types_1.check_string)(sw) ? parseFloat(sw) : undefined);
25
- }
26
- }
27
- if ((0, types_1.check_number)(a))
28
- return new this(a, a);
29
- throw new error_1.ResolveError("Vec2", a);
30
- }
31
- static resolveArgs(args) {
32
- if ((0, types_1.check_number_array)(args, 2))
33
- return new this(args[0], args[1]);
34
- return this.resolve(args[0]);
35
- }
36
- static is(a) {
37
- try {
38
- this.resolve(a);
39
- }
40
- catch (e) {
41
- return false;
42
- }
43
- return true;
44
- }
45
- static fromPoints(a, b) {
46
- const veca = this.resolve(a);
47
- const vecb = this.resolve(b);
48
- return new this(vecb.x - veca.x, vecb.y - veca.y);
49
- }
50
- static clamp(value, min, max) {
51
- const a = this.resolve(value), b = this.resolve(min), c = this.resolve(max);
52
- return new this((0, index_1.clamp)(a.x, b.x, c.x), (0, index_1.clamp)(a.y, b.y, c.y));
53
- }
54
- constructor(x = 0, y = 0, w = 1) {
55
- this.x = x;
56
- this.y = y;
57
- this.w = w;
58
- }
59
- toArray(w = false) {
60
- return w ? [this.x, this.y] : [this.x, this.y, this.w];
61
- }
62
- toJSON() {
63
- return {
64
- x: this.x, y: this.y, w: this.w
65
- };
66
- }
67
- toString(w = false) {
68
- return w ? `${this.x},${this.y}` : `${this.x},${this.y};${this.w}`;
69
- }
70
- toSquare() {
71
- return new square_1.Square(this.x, this.y);
72
- }
73
- clone() {
74
- return new Vec2(this.x, this.y, this.w);
75
- }
76
- setX(x) {
77
- this.x = x;
78
- return this;
79
- }
80
- setY(y) {
81
- this.y = y;
82
- return this;
83
- }
84
- setW(w) {
85
- this.w = w;
86
- return this;
87
- }
88
- set(...args) {
89
- const vec = Vec2.resolveArgs(args);
90
- return this.setX(vec.x).setY(vec.y);
91
- }
92
- add(...args) {
93
- const vec = Vec2.resolveArgs(args);
94
- return new Vec2(this.x + vec.x, this.y + vec.y);
95
- }
96
- offset(...args) {
97
- const vec = Vec2.resolveArgs(args);
98
- this.x += vec.x;
99
- this.y += vec.y;
100
- return this;
101
- }
102
- subtract(...args) {
103
- const vec = Vec2.resolveArgs(args);
104
- return new Vec2(this.x - vec.x, this.y - vec.y);
105
- }
106
- multiply(scalar) {
107
- return new Vec2(this.x * scalar, this.y * scalar);
108
- }
109
- naiveMultiply(...args) {
110
- const vec = Vec2.resolveArgs(args);
111
- return new Vec2(this.x * vec.x, this.y * vec.y);
112
- }
113
- divide(...args) {
114
- if ((0, types_1.check_number_array)(args, 1))
115
- return new Vec2(this.x / args[0], this.y / args[0]);
116
- const vec = Vec2.resolveArgs(args);
117
- return new Vec2(this.x / vec.x, this.y / vec.y);
118
- }
119
- dot(...args) {
120
- const vec = Vec2.resolveArgs(args);
121
- return this.x * vec.x + this.y * vec.y;
122
- }
123
- distance(...args) {
124
- const vec = Vec2.resolveArgs(args);
125
- return Math.pow(vec.x - this.x, 2) + Math.pow(vec.y - this.y, 2);
126
- }
127
- distanceSquare(...args) {
128
- const vec = Vec2.resolveArgs(args);
129
- return Math.sqrt(Math.pow(vec.x - this.x, 2) + Math.pow(vec.y - this.y, 2));
130
- }
131
- length() {
132
- return Math.sqrt(this.x * this.x + this.y * this.y);
133
- }
134
- cartesianify() {
135
- return new Vec2(this.x * Math.cos(this.y), this.x * Math.sin(this.y));
136
- }
137
- polarify() {
138
- return new Vec2(Math.sqrt(this.x * this.x + this.y * this.y), Math.atan(this.y / this.x));
139
- }
140
- normalize() {
141
- const length = this.length();
142
- if (length == 0)
143
- return new Vec2;
144
- return new Vec2(this.x / length, this.y / length);
145
- }
146
- invert() {
147
- return this.multiply(-1);
148
- }
149
- round() {
150
- return new Vec2(Math.round(this.x), Math.round(this.y), Math.round(this.w));
151
- }
152
- }
153
- exports.Vec2 = Vec2;
154
- //# 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,161 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Vec3 = void 0;
4
- const error_1 = require("../common/error");
5
- const types_1 = require("../common/types");
6
- const index_1 = require("../index");
7
- class Vec3 {
8
- x;
9
- y;
10
- z;
11
- w;
12
- static resolve(a) {
13
- if (a == null || typeof a == "undefined")
14
- throw new error_1.ResolveError("Vec3", a);
15
- if ((0, types_1.check_number_array)(a, 3) || (0, types_1.check_number_array)(a, 4))
16
- return new this(a[0], a[1], a[2], (0, types_1.check_number)(a[3]) ? a[3] : undefined);
17
- if ((0, types_1.has_property)(a, "x", "number") && (0, types_1.has_property)(a, "y", "number") && (0, types_1.has_property)(a, "z", "number"))
18
- return new this(a.x, a.y, a.z, (0, types_1.has_property)(a, "w", "number") ? a.w : undefined);
19
- if ((0, types_1.check_string)(a)) {
20
- const [sxyz, sw] = a.split(";");
21
- if ((0, types_1.check_string)(sxyz)) {
22
- const parts = sxyz.split(",");
23
- if ((0, types_1.check_string_array)(parts, 3))
24
- return new this(parseFloat(parts[0]), parseFloat(parts[1]), parseFloat(parts[2]), (0, types_1.check_string)(sw) ? parseFloat(sw) : undefined);
25
- }
26
- }
27
- if ((0, types_1.check_number)(a))
28
- return new this(a, a, a);
29
- throw new error_1.ResolveError("Vec3", a);
30
- }
31
- static resolveArgs(args) {
32
- if ((0, types_1.check_number_array)(args, 3))
33
- return new this(args[0], args[1], args[2]);
34
- return this.resolve(args[0]);
35
- }
36
- static is(a) {
37
- try {
38
- this.resolve(a);
39
- }
40
- catch (e) {
41
- return false;
42
- }
43
- return true;
44
- }
45
- static fromPoints(a, b) {
46
- const veca = this.resolve(a);
47
- const vecb = this.resolve(b);
48
- return new this(vecb.x - veca.x, vecb.y - veca.y, vecb.z - veca.z);
49
- }
50
- static clamp(value, min, max) {
51
- const a = this.resolve(value), b = this.resolve(min), c = this.resolve(max);
52
- return new this((0, index_1.clamp)(a.x, b.x, c.x), (0, index_1.clamp)(a.y, b.y, c.y), (0, index_1.clamp)(a.z, b.z, c.z));
53
- }
54
- static intersectPlane(planeP, planeN, lineStart, lineEnd, t) {
55
- planeN = this.resolve(planeN).normalize();
56
- const plane_d = -this.resolve(planeN).dot(planeP);
57
- const ad = this.resolve(lineStart).dot(planeN);
58
- const bd = this.resolve(lineEnd).dot(planeN);
59
- t = (-plane_d - ad) / (bd - ad);
60
- const lineStartToEnd = this.resolve(lineEnd).subtract(lineStart);
61
- const linetoIntersect = lineStartToEnd.multiply(t);
62
- return Vec3.resolve(lineStart).add(linetoIntersect);
63
- }
64
- constructor(x = 0, y = 0, z = 0, w = 1) {
65
- this.x = x;
66
- this.y = y;
67
- this.z = z;
68
- this.w = w;
69
- }
70
- toArray(w = false) {
71
- return w ? [this.x, this.y, this.z] : [this.x, this.y, this.z, this.w];
72
- }
73
- toJSON() {
74
- return {
75
- x: this.x, y: this.y, z: this.z, w: this.w
76
- };
77
- }
78
- toString(w = false) {
79
- return w ? `${this.x},${this.y},${this.z}` : `${this.x},${this.y},${this.z};${this.w}`;
80
- }
81
- clone() {
82
- return new Vec3(this.x, this.y, this.z, this.w);
83
- }
84
- setX(x) {
85
- this.x = x;
86
- return this;
87
- }
88
- setY(y) {
89
- this.y = y;
90
- return this;
91
- }
92
- setZ(z) {
93
- this.z = z;
94
- return this;
95
- }
96
- set(...args) {
97
- const vec = Vec3.resolveArgs(args);
98
- return this.setX(vec.x).setY(vec.y).setZ(vec.z);
99
- }
100
- add(...args) {
101
- const vec = Vec3.resolveArgs(args);
102
- return new Vec3(this.x + vec.x, this.y + vec.y, this.z + vec.z);
103
- }
104
- offset(...args) {
105
- const vec = Vec3.resolveArgs(args);
106
- this.x += vec.x;
107
- this.y += vec.y;
108
- this.z += vec.z;
109
- return this;
110
- }
111
- subtract(...args) {
112
- const vec = Vec3.resolveArgs(args);
113
- return new Vec3(this.x - vec.x, this.y - vec.y, this.z - vec.z);
114
- }
115
- multiply(scalar) {
116
- return new Vec3(this.x * scalar, this.y * scalar, this.z * scalar);
117
- }
118
- naiveMultiply(...args) {
119
- const vec = Vec3.resolveArgs(args);
120
- return new Vec3(this.x * vec.x, this.y * vec.y, this.z * vec.z);
121
- }
122
- divide(...args) {
123
- if ((0, types_1.check_number_array)(args, 1))
124
- return new Vec3(this.x / args[0], this.y / args[0], this.z / args[0]);
125
- const vec = Vec3.resolveArgs(args);
126
- return new Vec3(this.x / vec.x, this.y / vec.y, this.z / vec.z);
127
- }
128
- dot(...args) {
129
- const vec = Vec3.resolveArgs(args);
130
- return this.x * vec.x + this.y * vec.y + this.z * vec.z;
131
- }
132
- cross(...args) {
133
- const vec = Vec3.resolveArgs(args);
134
- 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);
135
- }
136
- distance(...args) {
137
- const vec = Vec3.resolveArgs(args);
138
- return Math.pow(vec.x - this.x, 2) + Math.pow(vec.y - this.y, 2) + Math.pow(vec.z - this.z, 2);
139
- }
140
- distanceSquare(...args) {
141
- const vec = Vec3.resolveArgs(args);
142
- return Math.sqrt(Math.pow(vec.x - this.x, 2) + Math.pow(vec.y - this.y, 2) + Math.pow(vec.z - this.z, 2));
143
- }
144
- length() {
145
- return Math.sqrt(this.x * this.x + this.y * this.y + this.z * this.z);
146
- }
147
- normalize() {
148
- const length = this.length();
149
- if (length == 0)
150
- return new Vec3;
151
- return new Vec3(this.x / length, this.y / length, this.z / length);
152
- }
153
- invert() {
154
- return this.multiply(-1);
155
- }
156
- round() {
157
- return new Vec3(Math.round(this.x), Math.round(this.y), Math.round(this.z), Math.round(this.w));
158
- }
159
- }
160
- exports.Vec3 = Vec3;
161
- //# 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,3 +0,0 @@
1
- export class MathFunction {
2
- }
3
- //# sourceMappingURL=function.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"function.js","sourceRoot":"","sources":["../../../source/algebra/function.ts"],"names":[],"mappings":"AAEA,MAAM,OAAgB,YAAY;CAIjC"}
@@ -1,38 +0,0 @@
1
- import { sign_char } from "../common/sign.js";
2
- import { Vec2 } from "../vectors/vec2.js";
3
- import { MathFunction } from "./function.js";
4
- export class LinearFunction extends MathFunction {
5
- m;
6
- b;
7
- static get(m, b, x) {
8
- return new this(m, b).get(x);
9
- }
10
- static fromPoints(a, b) {
11
- const veca = Vec2.resolve(a);
12
- const vecb = Vec2.resolve(b);
13
- const m = (vecb.y - veca.y) / (vecb.x - veca.x);
14
- const h = -m * veca.x + veca.y;
15
- return new this(m, h);
16
- }
17
- constructor(m, b) {
18
- super();
19
- this.m = m;
20
- this.b = b;
21
- }
22
- get(x) {
23
- return this.m;
24
- }
25
- roots() {
26
- const x = -(this.b) / this.m;
27
- if (!isNaN(x))
28
- return [new Vec2(x)];
29
- return [];
30
- }
31
- toString() {
32
- const bsign = sign_char(this.b);
33
- if (bsign)
34
- return `f(x) = ${this.m} * x ${bsign} ${Math.abs(this.b)}`;
35
- return `f(x) = ${this.m} * x`;
36
- }
37
- }
38
- //# sourceMappingURL=linear.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"linear.js","sourceRoot":"","sources":["../../../source/algebra/linear.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAA;AAC1C,OAAO,EAAY,IAAI,EAAE,MAAM,iBAAiB,CAAA;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAA;AAIzC,MAAM,OAAO,cAAe,SAAQ,YAAsB;IAc5B;IAAiB;IAZpC,MAAM,CAAC,GAAG,CAAC,CAAS,EAAC,CAAS,EAAC,CAAS;QAE3C,OAAO,IAAI,IAAI,CAAC,CAAC,EAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAA;IAC/B,CAAC;IACM,MAAM,CAAC,UAAU,CAAC,CAAW,EAAC,CAAW;QAE5C,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAA;QAC5B,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAA;QAC5B,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAC,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,CAAA;QAC7C,MAAM,CAAC,GAAG,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAA;QAC1B,OAAO,IAAI,IAAI,CAAC,CAAC,EAAC,CAAC,CAAC,CAAA;IACxB,CAAC;IACD,YAA0B,CAAS,EAAQ,CAAS;QAEhD,KAAK,EAAE,CAAA;QAFe,MAAC,GAAD,CAAC,CAAQ;QAAQ,MAAC,GAAD,CAAC,CAAQ;IAGpD,CAAC;IACM,GAAG,CAAC,CAAS;QAEhB,OAAO,IAAI,CAAC,CAAC,CAAA;IACjB,CAAC;IACM,KAAK;QAER,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAA;QAC1B,IAAG,CAAC,KAAK,CAAC,CAAC,CAAC;YACR,OAAO,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,CAAA;QACxB,OAAO,EAAE,CAAA;IACb,CAAC;IACM,QAAQ;QAEX,MAAM,KAAK,GAAG,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QAC/B,IAAG,KAAK;YACJ,OAAO,UAAU,IAAI,CAAC,CAAC,QAAQ,KAAK,IAAI,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAA;QAC9D,OAAO,UAAU,IAAI,CAAC,CAAC,MAAM,CAAA;IACjC,CAAC;CACJ"}
@@ -1,49 +0,0 @@
1
- import { sign_char } from "../common/sign.js";
2
- import { Vec2 } from "../vectors/vec2.js";
3
- import { MathFunction } from "./function.js";
4
- export class QuadFunction extends MathFunction {
5
- a;
6
- b;
7
- c;
8
- static get(a, b, c, x) {
9
- return new this(a, b, c).get(x);
10
- }
11
- constructor(a, b, c) {
12
- super();
13
- this.a = a;
14
- this.b = b;
15
- this.c = c;
16
- if (a == 0)
17
- throw new Error("'a' cannot be 0");
18
- }
19
- get(x) {
20
- return this.a * x * x + this.b * x + this.c;
21
- }
22
- roots() {
23
- const roots = new Array;
24
- const discriminant = this.b * this.b - 4 * this.a * this.c;
25
- const n0 = (-this.b + Math.sqrt(discriminant)) / (2 * this.a);
26
- const n1 = (-this.b + Math.sqrt(discriminant)) / (2 * this.a);
27
- if (!isNaN(n0))
28
- roots.push(new Vec2(n0));
29
- if (!isNaN(n1) && n0 != n1)
30
- roots.push(new Vec2(n1));
31
- return roots;
32
- }
33
- toString(type = "standard") {
34
- switch (type) {
35
- default:
36
- case "standard":
37
- {
38
- const bsign = sign_char(this.b);
39
- const csign = sign_char(this.c);
40
- if (bsign && csign)
41
- return `f(x) = ${this.a}x^2 ${bsign} ${Math.abs(this.b)}x ${csign} ${Math.abs(this.c)}`;
42
- if (bsign)
43
- return `f(x) = ${this.a}x^2 ${bsign} ${Math.abs(this.b)}x`;
44
- return `f(x) = ${this.a}x^2`;
45
- }
46
- }
47
- }
48
- }
49
- //# sourceMappingURL=quad.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"quad.js","sourceRoot":"","sources":["../../../source/algebra/quad.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAA;AAC1C,OAAO,EAAE,IAAI,EAAY,MAAM,iBAAiB,CAAA;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAA;AAQzC,MAAM,OAAO,YAAa,SAAQ,YAAsB;IAM1B;IAAiB;IAAiB;IAJrD,MAAM,CAAC,GAAG,CAAC,CAAS,EAAC,CAAS,EAAC,CAAS,EAAC,CAAS;QAErD,OAAO,IAAI,IAAI,CAAC,CAAC,EAAC,CAAC,EAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAA;IACjC,CAAC;IACD,YAA0B,CAAS,EAAQ,CAAS,EAAQ,CAAS;QAEjE,KAAK,EAAE,CAAA;QAFe,MAAC,GAAD,CAAC,CAAQ;QAAQ,MAAC,GAAD,CAAC,CAAQ;QAAQ,MAAC,GAAD,CAAC,CAAQ;QAGjE,IAAG,CAAC,IAAI,CAAC;YACL,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAA;IAC1C,CAAC;IACM,GAAG,CAAC,CAAS;QAEhB,OAAO,IAAI,CAAC,CAAC,GAAC,CAAC,GAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAA;IACzC,CAAC;IACM,KAAK;QAER,MAAM,KAAK,GAAG,IAAI,KAAW,CAAA;QAE7B,MAAM,YAAY,GAAG,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAA;QACxD,MAAM,EAAE,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,GAAC,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QACzD,MAAM,EAAE,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,GAAC,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QAEzD,IAAG,CAAC,KAAK,CAAC,EAAE,CAAC;YACT,KAAK,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,EAAE,CAAC,CAAC,CAAA;QAC5B,IAAG,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,EAAE;YACrB,KAAK,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,EAAE,CAAC,CAAC,CAAA;QAE5B,OAAO,KAAK,CAAA;IAChB,CAAC;IACM,QAAQ,CAA6B,OAAU,UAAe;QAEjE,QAAO,IAAI,EACX,CAAC;YACG,QAAQ;YACR,KAAK,UAAU;gBACf,CAAC;oBACG,MAAM,KAAK,GAAG,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;oBAC/B,MAAM,KAAK,GAAG,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;oBAC/B,IAAG,KAAK,IAAI,KAAK;wBACb,OAAO,UAAU,IAAI,CAAC,CAAC,OAAO,KAAK,IAAI,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,KAAK,IAAI,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAA;oBAC3F,IAAG,KAAK;wBACJ,OAAO,UAAU,IAAI,CAAC,CAAC,OAAO,KAAK,IAAI,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,CAAA;oBAC9D,OAAO,UAAU,IAAI,CAAC,CAAC,KAAK,CAAA;gBAChC,CAAC;QACL,CAAC;IACL,CAAC;CACJ"}