@benev/math 0.1.0 → 0.2.0-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 (118) hide show
  1. package/README.md +110 -23
  2. package/package.json +3 -1
  3. package/s/{concepts → core}/quat.ts +56 -16
  4. package/s/{concepts → core}/vec2.ts +52 -38
  5. package/s/{concepts → core}/vec3.ts +57 -47
  6. package/s/{concepts → core}/vec4.ts +13 -16
  7. package/s/index.ts +25 -10
  8. package/s/optimizers/hash-map.ts +71 -0
  9. package/s/optimizers/hash-set.ts +50 -0
  10. package/s/optimizers/zen.ts +151 -0
  11. package/s/physics/2d/collide2d.ts +51 -0
  12. package/s/physics/2d/intersect2d.ts +80 -0
  13. package/s/shapes/2d/circle.ts +43 -0
  14. package/s/shapes/2d/edge.ts +3 -0
  15. package/s/shapes/2d/index.ts +6 -0
  16. package/s/shapes/2d/pill.ts +3 -0
  17. package/s/shapes/2d/rect.ts +74 -0
  18. package/s/shapes/3d/box.ts +84 -0
  19. package/s/shapes/3d/capsule.ts +3 -0
  20. package/s/shapes/3d/index.ts +6 -0
  21. package/s/shapes/3d/segment.ts +48 -0
  22. package/s/shapes/3d/sphere.ts +3 -0
  23. package/s/tools/angles.ts +49 -0
  24. package/s/{concepts → tools}/circular.ts +5 -3
  25. package/s/{concepts → tools}/randy.ts +0 -14
  26. package/s/{concepts → tools}/scalar.ts +11 -11
  27. package/s/{concepts → tools}/spline.ts +11 -10
  28. package/x/{concepts → core}/quat.d.ts +10 -5
  29. package/x/{concepts → core}/quat.js +49 -12
  30. package/x/core/quat.js.map +1 -0
  31. package/x/{concepts → core}/vec2.d.ts +16 -17
  32. package/x/{concepts → core}/vec2.js +37 -21
  33. package/x/core/vec2.js.map +1 -0
  34. package/x/{concepts → core}/vec3.d.ts +19 -20
  35. package/x/{concepts → core}/vec3.js +46 -27
  36. package/x/core/vec3.js.map +1 -0
  37. package/x/{concepts → core}/vec4.d.ts +5 -7
  38. package/x/{concepts → core}/vec4.js +12 -12
  39. package/x/core/vec4.js.map +1 -0
  40. package/x/index.d.ts +21 -10
  41. package/x/index.js +21 -10
  42. package/x/index.js.map +1 -1
  43. package/x/optimizers/hash-map.d.ts +17 -0
  44. package/x/optimizers/hash-map.js +55 -0
  45. package/x/optimizers/hash-map.js.map +1 -0
  46. package/x/optimizers/hash-set.d.ts +13 -0
  47. package/x/optimizers/hash-set.js +39 -0
  48. package/x/optimizers/hash-set.js.map +1 -0
  49. package/x/optimizers/zen.d.ts +33 -0
  50. package/x/optimizers/zen.js +121 -0
  51. package/x/optimizers/zen.js.map +1 -0
  52. package/x/physics/2d/collide2d.d.ts +8 -0
  53. package/x/physics/2d/collide2d.js +36 -0
  54. package/x/physics/2d/collide2d.js.map +1 -0
  55. package/x/physics/2d/intersect2d.d.ts +13 -0
  56. package/x/physics/2d/intersect2d.js +57 -0
  57. package/x/physics/2d/intersect2d.js.map +1 -0
  58. package/x/shapes/2d/circle.d.ts +18 -0
  59. package/x/shapes/2d/circle.js +34 -0
  60. package/x/shapes/2d/circle.js.map +1 -0
  61. package/x/shapes/2d/edge.d.ts +1 -0
  62. package/x/shapes/2d/edge.js +3 -0
  63. package/x/shapes/2d/edge.js.map +1 -0
  64. package/x/shapes/2d/index.d.ts +4 -0
  65. package/x/shapes/2d/index.js +5 -0
  66. package/x/shapes/2d/index.js.map +1 -0
  67. package/x/shapes/2d/pill.d.ts +1 -0
  68. package/x/shapes/2d/pill.js +3 -0
  69. package/x/shapes/2d/pill.js.map +1 -0
  70. package/x/shapes/2d/rect.d.ts +23 -0
  71. package/x/shapes/2d/rect.js +59 -0
  72. package/x/shapes/2d/rect.js.map +1 -0
  73. package/x/shapes/3d/box.d.ts +24 -0
  74. package/x/shapes/3d/box.js +68 -0
  75. package/x/shapes/3d/box.js.map +1 -0
  76. package/x/shapes/3d/capsule.d.ts +1 -0
  77. package/x/shapes/3d/capsule.js +3 -0
  78. package/x/shapes/3d/capsule.js.map +1 -0
  79. package/x/shapes/3d/index.d.ts +4 -0
  80. package/x/shapes/3d/index.js +5 -0
  81. package/x/shapes/3d/index.js.map +1 -0
  82. package/x/shapes/3d/segment.d.ts +13 -0
  83. package/x/shapes/3d/segment.js +37 -0
  84. package/x/shapes/3d/segment.js.map +1 -0
  85. package/x/shapes/3d/sphere.d.ts +1 -0
  86. package/x/shapes/3d/sphere.js +3 -0
  87. package/x/shapes/3d/sphere.js.map +1 -0
  88. package/x/{concepts → tools}/angles.d.ts +3 -13
  89. package/x/tools/angles.js +41 -0
  90. package/x/tools/angles.js.map +1 -0
  91. package/x/{concepts → tools}/circular.js +4 -3
  92. package/x/tools/circular.js.map +1 -0
  93. package/x/tools/noise.js.map +1 -0
  94. package/x/{concepts → tools}/randy.d.ts +0 -8
  95. package/x/{concepts → tools}/randy.js +0 -10
  96. package/x/tools/randy.js.map +1 -0
  97. package/x/{concepts → tools}/scalar.d.ts +4 -4
  98. package/x/{concepts → tools}/scalar.js +11 -11
  99. package/x/tools/scalar.js.map +1 -0
  100. package/x/{concepts → tools}/spline.d.ts +3 -3
  101. package/x/{concepts → tools}/spline.js +3 -1
  102. package/x/tools/spline.js.map +1 -0
  103. package/s/concepts/angles.ts +0 -74
  104. package/x/concepts/angles.js +0 -62
  105. package/x/concepts/angles.js.map +0 -1
  106. package/x/concepts/circular.js.map +0 -1
  107. package/x/concepts/noise.js.map +0 -1
  108. package/x/concepts/quat.js.map +0 -1
  109. package/x/concepts/randy.js.map +0 -1
  110. package/x/concepts/scalar.js.map +0 -1
  111. package/x/concepts/spline.js.map +0 -1
  112. package/x/concepts/vec2.js.map +0 -1
  113. package/x/concepts/vec3.js.map +0 -1
  114. package/x/concepts/vec4.js.map +0 -1
  115. /package/s/{concepts → tools}/noise.ts +0 -0
  116. /package/x/{concepts → tools}/circular.d.ts +0 -0
  117. /package/x/{concepts → tools}/noise.d.ts +0 -0
  118. /package/x/{concepts → tools}/noise.js +0 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"vec2.js","sourceRoot":"","sources":["../../s/core/vec2.ts"],"names":[],"mappings":"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"}
@@ -1,40 +1,38 @@
1
- export type Vec3Array = [number, number, number];
1
+ export type XyzArray = [x: number, y: number, z: number];
2
2
  export type Xyz = {
3
3
  x: number;
4
4
  y: number;
5
5
  z: number;
6
6
  };
7
- /** https://github.com/microsoft/TypeScript/issues/5863 */
8
- type TsHack<T> = {
9
- new (...a: ConstructorParameters<typeof Vec3>): T;
10
- };
11
7
  export declare class Vec3 {
12
8
  x: number;
13
9
  y: number;
14
10
  z: number;
15
11
  constructor(x: number, y: number, z: number);
16
- static new<T extends Vec3>(this: TsHack<T>, x: number, y: number, z: number): T;
17
- static zero<T extends Vec3>(this: TsHack<T>): T;
18
- static all<T extends Vec3>(this: TsHack<T>, value: number): T;
19
- static array<T extends Vec3>(this: TsHack<T>, v: Vec3Array): T;
20
- static import<T extends Vec3>(this: TsHack<T>, { x, y, z }: Xyz): Vec3;
21
- static from(v: Vec3Array | Xyz): Vec3;
12
+ static new(x: number, y: number, z: number): Vec3;
13
+ static zero(): Vec3;
14
+ static all(value: number): Vec3;
15
+ static from(v: XyzArray | Xyz): Vec3;
22
16
  static magnitudeSquared(x: number, y: number, z: number): number;
23
17
  static magnitude(x: number, y: number, z: number): number;
24
18
  static average(...vecs: Xyz[]): Vec3;
25
- static min(...vecs: Vec3[]): Vec3;
26
- static max(...vecs: Vec3[]): Vec3;
27
- static hexColor(hex: string): Vec3;
19
+ static min(...vecs: Xyz[]): Vec3;
20
+ static max(...vecs: Xyz[]): Vec3;
21
+ static fromHex(hex: string): Vec3;
28
22
  clone(): Vec3;
29
- array(): Vec3Array;
23
+ [Symbol.iterator](): Generator<number, void, unknown>;
24
+ toJSON(): XyzArray;
30
25
  toString(): string;
31
26
  set_(x: number, y: number, z: number): this;
32
27
  set({ x, y, z }: Xyz): this;
33
28
  magnitudeSquared(): number;
34
29
  magnitude(): number;
35
- hexColor(): string;
30
+ /** rgb values from 0-1 */
31
+ toHex(): string;
36
32
  equals_(x: number, y: number, z: number): boolean;
37
33
  equals(...vecs: Xyz[]): boolean;
34
+ near_(x: number, y: number, z: number, epsilon?: number): boolean;
35
+ near({ x, y, z }: Xyz, epsilon?: number): boolean;
38
36
  distanceSquared_(x: number, y: number, z: number): number;
39
37
  distanceSquared({ x, y, z }: Xyz): number;
40
38
  distance_(x: number, y: number, z: number): number;
@@ -56,11 +54,11 @@ export declare class Vec3 {
56
54
  /** mutator */
57
55
  multiply_(x: number, y: number, z: number): this;
58
56
  /** mutator */
59
- multiply(...vecs: Vec3[]): this;
57
+ multiply(...vecs: Xyz[]): this;
60
58
  /** mutator */
61
59
  divide_(x: number, y: number, z: number): this;
62
60
  /** mutator */
63
- divide(...vecs: Vec3[]): this;
61
+ divide(...vecs: Xyz[]): this;
64
62
  /** mutator */
65
63
  half(): this;
66
64
  /** mutator */
@@ -74,6 +72,8 @@ export declare class Vec3 {
74
72
  /** mutator */
75
73
  addBy(delta: number): this;
76
74
  /** mutator */
75
+ subtractBy(delta: number): this;
76
+ /** mutator */
77
77
  multiplyBy(delta: number): this;
78
78
  /** mutator */
79
79
  divideBy(divisor: number): this;
@@ -100,7 +100,7 @@ export declare class Vec3 {
100
100
  /** mutator */
101
101
  projectOnto_(x: number, y: number, z: number): this;
102
102
  /** mutator */
103
- projectOnto({ x, y, z }: Vec3): this;
103
+ projectOnto({ x, y, z }: Xyz): this;
104
104
  /** mutator */
105
105
  reflect_(x: number, y: number, z: number): this;
106
106
  /** mutator */
@@ -114,4 +114,3 @@ export declare class Vec3 {
114
114
  /** mutator */
115
115
  smooth({ x, y, z }: Xyz, smoothing: number): this;
116
116
  }
117
- export {};
@@ -1,4 +1,4 @@
1
- import { Scalar } from "./scalar.js";
1
+ import { Scalar } from "../tools/scalar.js";
2
2
  export class Vec3 {
3
3
  x;
4
4
  y;
@@ -8,7 +8,6 @@ export class Vec3 {
8
8
  this.y = y;
9
9
  this.z = z;
10
10
  }
11
- ///////////////////////////////////////////////////////////////////////
12
11
  static new(x, y, z) {
13
12
  return new this(x, y, z);
14
13
  }
@@ -18,16 +17,10 @@ export class Vec3 {
18
17
  static all(value) {
19
18
  return new this(value, value, value);
20
19
  }
21
- static array(v) {
22
- return new this(...v);
23
- }
24
- static import({ x, y, z }) {
25
- return new this(x, y, z);
26
- }
27
20
  static from(v) {
28
21
  return Array.isArray(v)
29
- ? this.array(v)
30
- : this.import(v);
22
+ ? new this(...v)
23
+ : new this(v.x, v.y, v.z);
31
24
  }
32
25
  static magnitudeSquared(x, y, z) {
33
26
  return (x ** 2) + (y ** 2) + (z ** 2);
@@ -41,12 +34,12 @@ export class Vec3 {
41
34
  .divideBy(vecs.length);
42
35
  }
43
36
  static min(...vecs) {
44
- return new Vec3(Math.min(...vecs.map(v => v.x)), Math.min(...vecs.map(v => v.y)), Math.min(...vecs.map(v => v.z)));
37
+ return new this(Math.min(...vecs.map(v => v.x)), Math.min(...vecs.map(v => v.y)), Math.min(...vecs.map(v => v.z)));
45
38
  }
46
39
  static max(...vecs) {
47
- return new Vec3(Math.max(...vecs.map(v => v.x)), Math.max(...vecs.map(v => v.y)), Math.max(...vecs.map(v => v.z)));
40
+ return new this(Math.max(...vecs.map(v => v.x)), Math.max(...vecs.map(v => v.y)), Math.max(...vecs.map(v => v.z)));
48
41
  }
49
- static hexColor(hex) {
42
+ static fromHex(hex) {
50
43
  if (hex.startsWith("#") && hex.length === 7) {
51
44
  const r = parseInt(hex.slice(1, 3), 16) / 255;
52
45
  const g = parseInt(hex.slice(3, 5), 16) / 255;
@@ -57,11 +50,15 @@ export class Vec3 {
57
50
  throw new Error("invalid hex color format");
58
51
  }
59
52
  }
60
- ///////////////////////////////////////////////////////////////////////
61
53
  clone() {
62
54
  return new Vec3(this.x, this.y, this.z);
63
55
  }
64
- array() {
56
+ *[Symbol.iterator]() {
57
+ yield this.x;
58
+ yield this.y;
59
+ yield this.z;
60
+ }
61
+ toJSON() {
65
62
  return [this.x, this.y, this.z];
66
63
  }
67
64
  toString() {
@@ -79,26 +76,33 @@ export class Vec3 {
79
76
  this.z = z;
80
77
  return this;
81
78
  }
82
- ///////////////////////////////////////////////////////////////////////
83
79
  magnitudeSquared() {
84
80
  return Vec3.magnitudeSquared(this.x, this.y, this.z);
85
81
  }
86
82
  magnitude() {
87
83
  return Vec3.magnitude(this.x, this.y, this.z);
88
84
  }
89
- hexColor() {
90
- const to255 = (val) => Math.round(val * 255);
85
+ /** rgb values from 0-1 */
86
+ toHex() {
87
+ const to255 = (val) => Math.round(Scalar.clamp(val * 255, 0, 255));
91
88
  const toHex = (val) => to255(val).toString(16).padStart(2, '0');
92
89
  return `#${toHex(this.x)}${toHex(this.y)}${toHex(this.z)}`;
93
90
  }
94
- ///////////////////////////////////////////////////////////////////////
95
91
  equals_(x, y, z) {
96
92
  return (this.x === x &&
97
93
  this.y === y &&
98
94
  this.z === z);
99
95
  }
100
96
  equals(...vecs) {
101
- return vecs.every(v => this.equals_(v.x, v.y, v.z));
97
+ return vecs.every(({ x, y, z }) => this.equals_(x, y, z));
98
+ }
99
+ near_(x, y, z, epsilon = 1e-6) {
100
+ return (Math.abs(this.x - x) <= epsilon &&
101
+ Math.abs(this.y - y) <= epsilon &&
102
+ Math.abs(this.z - z) <= epsilon);
103
+ }
104
+ near({ x, y, z }, epsilon = 1e-6) {
105
+ return this.near_(x, y, z, epsilon);
102
106
  }
103
107
  distanceSquared_(x, y, z) {
104
108
  const dx = this.x - x;
@@ -130,13 +134,15 @@ export class Vec3 {
130
134
  }
131
135
  angleBetween_(x, y, z) {
132
136
  const dotProduct = this.dot_(x, y, z);
133
- const magnitudes = this.magnitude() * Vec3.new(x, y, z).magnitude();
134
- return Math.acos(dotProduct / magnitudes);
137
+ const magnitudes = this.magnitude() * Vec3.magnitude(x, y, z);
138
+ if (magnitudes === 0)
139
+ return 0;
140
+ const ratio = Scalar.clamp(dotProduct / magnitudes, -1, 1);
141
+ return Math.acos(ratio);
135
142
  }
136
143
  angleBetween({ x, y, z }) {
137
144
  return this.angleBetween_(x, y, z);
138
145
  }
139
- ///////////////////////////////////////////////////////////////////////
140
146
  /** mutator */
141
147
  add_(x, y, z) {
142
148
  this.x += x;
@@ -178,9 +184,12 @@ export class Vec3 {
178
184
  }
179
185
  /** mutator */
180
186
  divide_(x, y, z) {
181
- this.x /= x;
182
- this.y /= y;
183
- this.z /= z;
187
+ if (x !== 0)
188
+ this.x /= x;
189
+ if (y !== 0)
190
+ this.y /= y;
191
+ if (z !== 0)
192
+ this.z /= z;
184
193
  return this;
185
194
  }
186
195
  /** mutator */
@@ -224,6 +233,13 @@ export class Vec3 {
224
233
  return this;
225
234
  }
226
235
  /** mutator */
236
+ subtractBy(delta) {
237
+ this.x -= delta;
238
+ this.y -= delta;
239
+ this.z -= delta;
240
+ return this;
241
+ }
242
+ /** mutator */
227
243
  multiplyBy(delta) {
228
244
  this.x *= delta;
229
245
  this.y *= delta;
@@ -306,7 +322,10 @@ export class Vec3 {
306
322
  }
307
323
  /** mutator */
308
324
  projectOnto_(x, y, z) {
309
- const scalar = this.dot_(x, y, z) / Vec3.magnitudeSquared(x, y, z);
325
+ const m2 = Vec3.magnitudeSquared(x, y, z);
326
+ if (!m2)
327
+ return this;
328
+ const scalar = this.dot_(x, y, z) / m2;
310
329
  this.x = scalar * x;
311
330
  this.y = scalar * y;
312
331
  this.z = scalar * z;
@@ -0,0 +1 @@
1
+ {"version":3,"file":"vec3.js","sourceRoot":"","sources":["../../s/core/vec3.ts"],"names":[],"mappings":"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"}
@@ -1,5 +1,4 @@
1
- import { Xyzw } from "./quat.js";
2
- export type Vec4Array = [number, number, number, number];
1
+ import { Xyzw, XyzwArray } from "./quat.js";
3
2
  export declare class Vec4 {
4
3
  x: number;
5
4
  y: number;
@@ -8,12 +7,11 @@ export declare class Vec4 {
8
7
  constructor(x: number, y: number, z: number, w: number);
9
8
  static new(x: number, y: number, z: number, w: number): Vec4;
10
9
  static zero(): Vec4;
11
- static array(v: Vec4Array): Vec4;
12
- static import({ x, y, z, w }: Xyzw): Vec4;
13
- static from(v: Vec4Array | Xyzw): Vec4;
14
- array(): Vec4Array;
15
- toString(): string;
10
+ static from(v: XyzwArray | Xyzw): Vec4;
16
11
  clone(): Vec4;
12
+ [Symbol.iterator](): Generator<number, void, unknown>;
13
+ toJSON(): XyzwArray;
14
+ toString(): string;
17
15
  set_(x: number, y: number, z: number, w: number): this;
18
16
  set({ x, y, z, w }: Xyzw): this;
19
17
  /** mutator */
@@ -15,27 +15,27 @@ export class Vec4 {
15
15
  static zero() {
16
16
  return new this(0, 0, 0, 0);
17
17
  }
18
- static array(v) {
19
- return new this(...v);
20
- }
21
- static import({ x, y, z, w }) {
22
- return new this(x, y, z, w);
23
- }
24
18
  static from(v) {
25
19
  return Array.isArray(v)
26
- ? this.array(v)
27
- : this.import(v);
20
+ ? new this(...v)
21
+ : new this(v.x, v.y, v.z, v.w);
22
+ }
23
+ clone() {
24
+ return new Vec4(this.x, this.y, this.z, this.w);
25
+ }
26
+ *[Symbol.iterator]() {
27
+ yield this.x;
28
+ yield this.y;
29
+ yield this.z;
30
+ yield this.w;
28
31
  }
29
- array() {
32
+ toJSON() {
30
33
  const { x, y, z, w } = this;
31
34
  return [x, y, z, w];
32
35
  }
33
36
  toString() {
34
37
  return `(Vec4 x${this.x.toFixed(2)}, y${this.y.toFixed(2)}, z${this.z.toFixed(2)}, w${this.w.toFixed(2)})`;
35
38
  }
36
- clone() {
37
- return new Vec4(...this.array());
38
- }
39
39
  set_(x, y, z, w) {
40
40
  this.x = x;
41
41
  this.y = y;
@@ -0,0 +1 @@
1
+ {"version":3,"file":"vec4.js","sourceRoot":"","sources":["../../s/core/vec4.ts"],"names":[],"mappings":"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"}
package/x/index.d.ts CHANGED
@@ -1,10 +1,21 @@
1
- export * from "./concepts/angles.js";
2
- export * from "./concepts/circular.js";
3
- export * from "./concepts/noise.js";
4
- export * from "./concepts/quat.js";
5
- export * from "./concepts/randy.js";
6
- export * from "./concepts/scalar.js";
7
- export * as spline from "./concepts/spline.js";
8
- export * from "./concepts/vec2.js";
9
- export * from "./concepts/vec3.js";
10
- export * from "./concepts/vec4.js";
1
+ export * from "./core/quat.js";
2
+ export * from "./core/vec2.js";
3
+ export * from "./core/vec3.js";
4
+ export * from "./core/vec4.js";
5
+ export * from "./tools/angles.js";
6
+ export * from "./tools/circular.js";
7
+ export * from "./tools/noise.js";
8
+ export * from "./tools/randy.js";
9
+ export * from "./tools/scalar.js";
10
+ export * as spline from "./tools/spline.js";
11
+ export * from "./optimizers/hash-map.js";
12
+ export * from "./optimizers/hash-set.js";
13
+ export * from "./optimizers/zen.js";
14
+ export * from "./physics/2d/collide2d.js";
15
+ export * as collide2d from "./physics/2d/collide2d.js";
16
+ export * from "./physics/2d/intersect2d.js";
17
+ export * as intersect2d from "./physics/2d/intersect2d.js";
18
+ export * from "./shapes/2d/index.js";
19
+ export * as shapes2d from "./shapes/2d/index.js";
20
+ export * from "./shapes/3d/index.js";
21
+ export * as shapes3d from "./shapes/3d/index.js";
package/x/index.js CHANGED
@@ -1,11 +1,22 @@
1
- export * from "./concepts/angles.js";
2
- export * from "./concepts/circular.js";
3
- export * from "./concepts/noise.js";
4
- export * from "./concepts/quat.js";
5
- export * from "./concepts/randy.js";
6
- export * from "./concepts/scalar.js";
7
- export * as spline from "./concepts/spline.js";
8
- export * from "./concepts/vec2.js";
9
- export * from "./concepts/vec3.js";
10
- export * from "./concepts/vec4.js";
1
+ export * from "./core/quat.js";
2
+ export * from "./core/vec2.js";
3
+ export * from "./core/vec3.js";
4
+ export * from "./core/vec4.js";
5
+ export * from "./tools/angles.js";
6
+ export * from "./tools/circular.js";
7
+ export * from "./tools/noise.js";
8
+ export * from "./tools/randy.js";
9
+ export * from "./tools/scalar.js";
10
+ export * as spline from "./tools/spline.js";
11
+ export * from "./optimizers/hash-map.js";
12
+ export * from "./optimizers/hash-set.js";
13
+ export * from "./optimizers/zen.js";
14
+ export * from "./physics/2d/collide2d.js";
15
+ export * as collide2d from "./physics/2d/collide2d.js";
16
+ export * from "./physics/2d/intersect2d.js";
17
+ export * as intersect2d from "./physics/2d/intersect2d.js";
18
+ export * from "./shapes/2d/index.js";
19
+ export * as shapes2d from "./shapes/2d/index.js";
20
+ export * from "./shapes/3d/index.js";
21
+ export * as shapes3d from "./shapes/3d/index.js";
11
22
  //# sourceMappingURL=index.js.map
package/x/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../s/index.ts"],"names":[],"mappings":"AACA,cAAc,sBAAsB,CAAA;AACpC,cAAc,wBAAwB,CAAA;AACtC,cAAc,qBAAqB,CAAA;AACnC,cAAc,oBAAoB,CAAA;AAClC,cAAc,qBAAqB,CAAA;AACnC,cAAc,sBAAsB,CAAA;AACpC,OAAO,KAAK,MAAM,MAAM,sBAAsB,CAAA;AAC9C,cAAc,oBAAoB,CAAA;AAClC,cAAc,oBAAoB,CAAA;AAClC,cAAc,oBAAoB,CAAA"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../s/index.ts"],"names":[],"mappings":"AACA,cAAc,gBAAgB,CAAA;AAC9B,cAAc,gBAAgB,CAAA;AAC9B,cAAc,gBAAgB,CAAA;AAC9B,cAAc,gBAAgB,CAAA;AAE9B,cAAc,mBAAmB,CAAA;AACjC,cAAc,qBAAqB,CAAA;AACnC,cAAc,kBAAkB,CAAA;AAChC,cAAc,kBAAkB,CAAA;AAChC,cAAc,mBAAmB,CAAA;AACjC,OAAO,KAAK,MAAM,MAAM,mBAAmB,CAAA;AAE3C,cAAc,0BAA0B,CAAA;AACxC,cAAc,0BAA0B,CAAA;AACxC,cAAc,qBAAqB,CAAA;AAEnC,cAAc,2BAA2B,CAAA;AACzC,OAAO,KAAK,SAAS,MAAM,2BAA2B,CAAA;AACtD,cAAc,6BAA6B,CAAA;AAC3C,OAAO,KAAK,WAAW,MAAM,6BAA6B,CAAA;AAE1D,cAAc,sBAAsB,CAAA;AACpC,OAAO,KAAK,QAAQ,MAAM,sBAAsB,CAAA;AAChD,cAAc,sBAAsB,CAAA;AACpC,OAAO,KAAK,QAAQ,MAAM,sBAAsB,CAAA"}
@@ -0,0 +1,17 @@
1
+ export declare class HashMap<Key, Value> {
2
+ #private;
3
+ private hash;
4
+ constructor(hash: (x: Key) => string, entries?: [Key, Value][]);
5
+ get size(): number;
6
+ get(key: Key): Value | undefined;
7
+ require(key: Key): Value;
8
+ has(key: Key): boolean;
9
+ set(key: Key, value: Value): this;
10
+ delete(...keys: Key[]): this;
11
+ entries(): MapIterator<[Key, Value]>;
12
+ [Symbol.iterator](): MapIterator<[Key, Value]>;
13
+ keys(): Generator<Key, void, unknown>;
14
+ values(): Generator<Value, void, unknown>;
15
+ array(): [Key, Value][];
16
+ guarantee(key: Key, fn: () => Value): Value;
17
+ }
@@ -0,0 +1,55 @@
1
+ import { MapG } from "@e280/stz";
2
+ export class HashMap {
3
+ hash;
4
+ #map = new MapG;
5
+ constructor(hash, entries = []) {
6
+ this.hash = hash;
7
+ for (const [key, value] of entries)
8
+ this.set(key, value);
9
+ }
10
+ get size() {
11
+ return this.#map.size;
12
+ }
13
+ get(key) {
14
+ const result = this.#map.get(this.hash(key));
15
+ if (result)
16
+ return result[1];
17
+ }
18
+ require(key) {
19
+ return this.#map.require(this.hash(key))[1];
20
+ }
21
+ has(key) {
22
+ return this.#map.has(this.hash(key));
23
+ }
24
+ set(key, value) {
25
+ this.#map.set(this.hash(key), [key, value]);
26
+ return this;
27
+ }
28
+ delete(...keys) {
29
+ for (const key of keys)
30
+ this.#map.delete(this.hash(key));
31
+ return this;
32
+ }
33
+ entries() {
34
+ return this.#map.values();
35
+ }
36
+ [Symbol.iterator]() {
37
+ return this.entries();
38
+ }
39
+ *keys() {
40
+ for (const [key] of this.#map.values())
41
+ yield key;
42
+ }
43
+ *values() {
44
+ for (const [, value] of this.#map.values())
45
+ yield value;
46
+ }
47
+ array() {
48
+ return [...this.entries()];
49
+ }
50
+ guarantee(key, fn) {
51
+ const [, value] = this.#map.guarantee(this.hash(key), () => [key, fn()]);
52
+ return value;
53
+ }
54
+ }
55
+ //# sourceMappingURL=hash-map.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hash-map.js","sourceRoot":"","sources":["../../s/optimizers/hash-map.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,IAAI,EAAC,MAAM,WAAW,CAAA;AAE9B,MAAM,OAAO,OAAO;IAIT;IAHV,IAAI,GAAG,IAAI,IAA0B,CAAA;IAErC,YACU,IAAwB,EAChC,UAA0B,EAAE;QADpB,SAAI,GAAJ,IAAI,CAAoB;QAGjC,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,OAAO;YACjC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,KAAK,CAAC,CAAA;IACtB,CAAC;IAED,IAAI,IAAI;QACP,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAA;IACtB,CAAC;IAED,GAAG,CAAC,GAAQ;QACX,MAAM,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAA;QAC5C,IAAI,MAAM;YACT,OAAO,MAAM,CAAC,CAAC,CAAC,CAAA;IAClB,CAAC;IAED,OAAO,CAAC,GAAQ;QACf,OAAO,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;IAC5C,CAAC;IAED,GAAG,CAAC,GAAQ;QACX,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAA;IACrC,CAAC;IAED,GAAG,CAAC,GAAQ,EAAE,KAAY;QACzB,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC,CAAA;QAC3C,OAAO,IAAI,CAAA;IACZ,CAAC;IAED,MAAM,CAAC,GAAG,IAAW;QACpB,KAAK,MAAM,GAAG,IAAI,IAAI;YACrB,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAA;QACjC,OAAO,IAAI,CAAA;IACZ,CAAC;IAED,OAAO;QACN,OAAO,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAA;IAC1B,CAAC;IAED,CAAC,MAAM,CAAC,QAAQ,CAAC;QAChB,OAAO,IAAI,CAAC,OAAO,EAAE,CAAA;IACtB,CAAC;IAED,CAAC,IAAI;QACJ,KAAK,MAAM,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YACrC,MAAM,GAAG,CAAA;IACX,CAAC;IAED,CAAC,MAAM;QACN,KAAK,MAAM,CAAC,EAAC,KAAK,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YACxC,MAAM,KAAK,CAAA;IACb,CAAC;IAED,KAAK;QACJ,OAAO,CAAC,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC,CAAA;IAC3B,CAAC;IAED,SAAS,CAAC,GAAQ,EAAE,EAAe;QAClC,MAAM,CAAC,EAAC,KAAK,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC,GAAG,EAAE,EAAE,EAAE,CAAC,CAAC,CAAA;QACvE,OAAO,KAAK,CAAA;IACb,CAAC;CACD"}
@@ -0,0 +1,13 @@
1
+ export declare class HashSet<Value> {
2
+ #private;
3
+ private hash;
4
+ constructor(hash: (value: Value) => string, values?: Value[]);
5
+ get size(): number;
6
+ get(value: Value): Value | undefined;
7
+ has(value: Value): boolean;
8
+ add(...values: Value[]): this;
9
+ delete(...values: Value[]): this;
10
+ array(): Value[];
11
+ values(): MapIterator<Value>;
12
+ [Symbol.iterator](): MapIterator<Value>;
13
+ }
@@ -0,0 +1,39 @@
1
+ export class HashSet {
2
+ hash;
3
+ #map = new Map;
4
+ constructor(hash, values = []) {
5
+ this.hash = hash;
6
+ this.add(...values);
7
+ }
8
+ get size() {
9
+ return this.#map.size;
10
+ }
11
+ get(value) {
12
+ return this.#map.get(this.hash(value));
13
+ }
14
+ has(value) {
15
+ return this.#map.has(this.hash(value));
16
+ }
17
+ add(...values) {
18
+ for (const value of values) {
19
+ const key = this.hash(value);
20
+ this.#map.set(key, value);
21
+ }
22
+ return this;
23
+ }
24
+ delete(...values) {
25
+ for (const value of values)
26
+ this.#map.delete(this.hash(value));
27
+ return this;
28
+ }
29
+ array() {
30
+ return [...this.#map.values()];
31
+ }
32
+ values() {
33
+ return this.#map.values();
34
+ }
35
+ [Symbol.iterator]() {
36
+ return this.values();
37
+ }
38
+ }
39
+ //# sourceMappingURL=hash-set.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hash-set.js","sourceRoot":"","sources":["../../s/optimizers/hash-set.ts"],"names":[],"mappings":"AACA,MAAM,OAAO,OAAO;IAIT;IAHV,IAAI,GAAG,IAAI,GAAkB,CAAA;IAE7B,YACU,IAA8B,EACtC,SAAkB,EAAE;QADZ,SAAI,GAAJ,IAAI,CAA0B;QAGvC,IAAI,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,CAAA;IACpB,CAAC;IAED,IAAI,IAAI;QACP,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAA;IACtB,CAAC;IAED,GAAG,CAAC,KAAY;QACf,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAA;IACvC,CAAC;IAED,GAAG,CAAC,KAAY;QACf,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAA;IACvC,CAAC;IAED,GAAG,CAAC,GAAG,MAAe;QACrB,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;YAC5B,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;YAC5B,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,KAAK,CAAC,CAAA;QAC1B,CAAC;QACD,OAAO,IAAI,CAAA;IACZ,CAAC;IAED,MAAM,CAAC,GAAG,MAAe;QACxB,KAAK,MAAM,KAAK,IAAI,MAAM;YACzB,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAA;QACnC,OAAO,IAAI,CAAA;IACZ,CAAC;IAED,KAAK;QACJ,OAAO,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAA;IAC/B,CAAC;IAED,MAAM;QACL,OAAO,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAA;IAC1B,CAAC;IAED,CAAC,MAAM,CAAC,QAAQ,CAAC;QAChB,OAAO,IAAI,CAAC,MAAM,EAAE,CAAA;IACrB,CAAC;CACD"}
@@ -0,0 +1,33 @@
1
+ import { Vec2 } from "../core/vec2.js";
2
+ import { Rect } from "../shapes/2d/rect.js";
3
+ export declare class Zen<X> {
4
+ grid: ZenGrid<X>;
5
+ rect: Rect;
6
+ item: X;
7
+ zones: Set<ZenZone<X>>;
8
+ constructor(grid: ZenGrid<X>, rect: Rect, item: X);
9
+ update(): void;
10
+ delete(): void;
11
+ }
12
+ export declare class ZenZone<X> {
13
+ hash: string;
14
+ rect: Rect;
15
+ zens: Set<Zen<X>>;
16
+ constructor(hash: string, center: Vec2, size: Vec2);
17
+ }
18
+ export declare class ZenGrid<X> {
19
+ #private;
20
+ private zoneExtent;
21
+ constructor(zoneExtent: Vec2);
22
+ count(): number;
23
+ create(rect: Rect, item: X): Zen<X>;
24
+ update(zen: Zen<X>): void;
25
+ delete(zen: Zen<X>): void;
26
+ check(rect: Rect): boolean;
27
+ /** return set of zens that touch the given rect */
28
+ query(rect: Rect): Set<Zen<X>>;
29
+ /** return all zen items that touch the given rect */
30
+ queryItems(rect: Rect): X[];
31
+ /** return all zen rects that touch the given rect */
32
+ queryRects(rect: Rect): Rect[];
33
+ }