@interstellar-tools/equations 0.1.2 → 0.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 (191) hide show
  1. package/dist/__tests__/circular-speed.spec.d.ts +2 -0
  2. package/dist/__tests__/circular-speed.spec.d.ts.map +1 -0
  3. package/dist/__tests__/circular-speed.spec.js +69 -0
  4. package/dist/__tests__/circular-speed.spec.js.map +1 -0
  5. package/dist/__tests__/compute-angle.int.spec.js +2 -2
  6. package/dist/__tests__/compute-angle.int.spec.js.map +1 -1
  7. package/dist/__tests__/eccentric-to-true-anomaly.spec.js +1 -1
  8. package/dist/__tests__/eccentric-to-true-anomaly.spec.js.map +1 -1
  9. package/dist/__tests__/escape-speed.spec.d.ts +2 -0
  10. package/dist/__tests__/escape-speed.spec.d.ts.map +1 -0
  11. package/dist/__tests__/escape-speed.spec.js +79 -0
  12. package/dist/__tests__/escape-speed.spec.js.map +1 -0
  13. package/dist/__tests__/gravitational-acceleration-on1-by2.int.spec.d.ts +2 -0
  14. package/dist/__tests__/gravitational-acceleration-on1-by2.int.spec.d.ts.map +1 -0
  15. package/dist/__tests__/gravitational-acceleration-on1-by2.int.spec.js +86 -0
  16. package/dist/__tests__/gravitational-acceleration-on1-by2.int.spec.js.map +1 -0
  17. package/dist/__tests__/gravitational-force-on1-by2.int.spec.d.ts +2 -0
  18. package/dist/__tests__/gravitational-force-on1-by2.int.spec.d.ts.map +1 -0
  19. package/dist/__tests__/gravitational-force-on1-by2.int.spec.js +106 -0
  20. package/dist/__tests__/gravitational-force-on1-by2.int.spec.js.map +1 -0
  21. package/dist/__tests__/gravitational-force.spec.d.ts +2 -0
  22. package/dist/__tests__/gravitational-force.spec.d.ts.map +1 -0
  23. package/dist/__tests__/gravitational-force.spec.js +105 -0
  24. package/dist/__tests__/gravitational-force.spec.js.map +1 -0
  25. package/dist/__tests__/gravitational-parameters.spec.d.ts +2 -0
  26. package/dist/__tests__/gravitational-parameters.spec.d.ts.map +1 -0
  27. package/dist/__tests__/gravitational-parameters.spec.js +75 -0
  28. package/dist/__tests__/gravitational-parameters.spec.js.map +1 -0
  29. package/dist/__tests__/helpers/index.d.ts +9 -0
  30. package/dist/__tests__/helpers/index.d.ts.map +1 -0
  31. package/dist/__tests__/helpers/index.js +31 -0
  32. package/dist/__tests__/helpers/index.js.map +1 -0
  33. package/dist/__tests__/kepler-period.spec.d.ts +2 -0
  34. package/dist/__tests__/kepler-period.spec.d.ts.map +1 -0
  35. package/dist/__tests__/kepler-period.spec.js +72 -0
  36. package/dist/__tests__/kepler-period.spec.js.map +1 -0
  37. package/dist/__tests__/mean-to-eccentric-anomaly.spec.d.ts +2 -0
  38. package/dist/__tests__/mean-to-eccentric-anomaly.spec.d.ts.map +1 -0
  39. package/dist/__tests__/{compute-mean-anomaly.int.spec.js → mean-to-eccentric-anomaly.spec.js} +49 -27
  40. package/dist/__tests__/mean-to-eccentric-anomaly.spec.js.map +1 -0
  41. package/dist/__tests__/peri-apoapsis-radii.spec.d.ts +2 -0
  42. package/dist/__tests__/peri-apoapsis-radii.spec.d.ts.map +1 -0
  43. package/dist/__tests__/peri-apoapsis-radii.spec.js +74 -0
  44. package/dist/__tests__/peri-apoapsis-radii.spec.js.map +1 -0
  45. package/dist/__tests__/solve-kepler-bisection.spec.js +1 -1
  46. package/dist/__tests__/solve-kepler-bisection.spec.js.map +1 -1
  47. package/dist/__tests__/solve-kepler-high-eccentricity.spec.js +1 -1
  48. package/dist/__tests__/solve-kepler-high-eccentricity.spec.js.map +1 -1
  49. package/dist/__tests__/solve-kepler-newton-raphson.spec.js +1 -1
  50. package/dist/__tests__/solve-kepler-newton-raphson.spec.js.map +1 -1
  51. package/dist/__tests__/solve-kepler.int.spec.js +1 -1
  52. package/dist/__tests__/solve-kepler.int.spec.js.map +1 -1
  53. package/dist/__tests__/specific-angular-momentum-from-elements.spec.d.ts +2 -0
  54. package/dist/__tests__/specific-angular-momentum-from-elements.spec.d.ts.map +1 -0
  55. package/dist/__tests__/specific-angular-momentum-from-elements.spec.js +86 -0
  56. package/dist/__tests__/specific-angular-momentum-from-elements.spec.js.map +1 -0
  57. package/dist/__tests__/specific-angular-momentum.spec.d.ts +2 -0
  58. package/dist/__tests__/specific-angular-momentum.spec.d.ts.map +1 -0
  59. package/dist/__tests__/specific-angular-momentum.spec.js +84 -0
  60. package/dist/__tests__/specific-angular-momentum.spec.js.map +1 -0
  61. package/dist/__tests__/specific-mechanical-energy.spec.d.ts +2 -0
  62. package/dist/__tests__/specific-mechanical-energy.spec.d.ts.map +1 -0
  63. package/dist/__tests__/specific-mechanical-energy.spec.js +81 -0
  64. package/dist/__tests__/specific-mechanical-energy.spec.js.map +1 -0
  65. package/dist/__tests__/true-to-mean-anomaly.spec.d.ts +2 -0
  66. package/dist/__tests__/true-to-mean-anomaly.spec.d.ts.map +1 -0
  67. package/dist/__tests__/{true-anomaly-to-mean-anomaly.int.spec.js → true-to-mean-anomaly.spec.js} +13 -13
  68. package/dist/__tests__/true-to-mean-anomaly.spec.js.map +1 -0
  69. package/dist/__tests__/vis-viva-speed.spec.d.ts +2 -0
  70. package/dist/__tests__/vis-viva-speed.spec.d.ts.map +1 -0
  71. package/dist/__tests__/vis-viva-speed.spec.js +80 -0
  72. package/dist/__tests__/vis-viva-speed.spec.js.map +1 -0
  73. package/dist/__tests__/wrap-angle.spec.js +1 -1
  74. package/dist/__tests__/wrap-angle.spec.js.map +1 -1
  75. package/dist/{compute-angle.d.ts → categories/angle/compute-angle.d.ts} +1 -1
  76. package/dist/categories/angle/compute-angle.d.ts.map +1 -0
  77. package/dist/{compute-angle.js → categories/angle/compute-angle.js} +5 -5
  78. package/dist/categories/angle/compute-angle.js.map +1 -0
  79. package/dist/{wrap-angle.d.ts → categories/angle/wrap-angle.d.ts} +1 -1
  80. package/dist/categories/angle/wrap-angle.d.ts.map +1 -0
  81. package/dist/{wrap-angle.js → categories/angle/wrap-angle.js} +1 -1
  82. package/dist/categories/angle/wrap-angle.js.map +1 -0
  83. package/dist/{eccentric-to-true-anomaly.d.ts → categories/anomalies/eccentric-to-true-anomaly.d.ts} +2 -2
  84. package/dist/categories/anomalies/eccentric-to-true-anomaly.d.ts.map +1 -0
  85. package/dist/{eccentric-to-true-anomaly.js → categories/anomalies/eccentric-to-true-anomaly.js} +2 -2
  86. package/dist/categories/anomalies/eccentric-to-true-anomaly.js.map +1 -0
  87. package/dist/{compute-mean-anomaly.d.ts → categories/anomalies/mean-to-eccentric-anomaly.d.ts} +6 -6
  88. package/dist/categories/anomalies/mean-to-eccentric-anomaly.d.ts.map +1 -0
  89. package/dist/{compute-mean-anomaly.js → categories/anomalies/mean-to-eccentric-anomaly.js} +12 -21
  90. package/dist/categories/anomalies/mean-to-eccentric-anomaly.js.map +1 -0
  91. package/dist/{true-anomaly-to-mean-anomaly.d.ts → categories/anomalies/true-to-mean-anomaly.d.ts} +6 -6
  92. package/dist/categories/anomalies/true-to-mean-anomaly.d.ts.map +1 -0
  93. package/dist/{true-anomaly-to-mean-anomaly.js → categories/anomalies/true-to-mean-anomaly.js} +7 -7
  94. package/dist/categories/anomalies/true-to-mean-anomaly.js.map +1 -0
  95. package/dist/categories/anomalies/utils/are-equal.d.ts +10 -0
  96. package/dist/categories/anomalies/utils/are-equal.d.ts.map +1 -0
  97. package/dist/categories/anomalies/utils/are-equal.js +13 -0
  98. package/dist/categories/anomalies/utils/are-equal.js.map +1 -0
  99. package/dist/categories/gravity/acceleration-on1-by2.d.ts +66 -0
  100. package/dist/categories/gravity/acceleration-on1-by2.d.ts.map +1 -0
  101. package/dist/categories/gravity/acceleration-on1-by2.js +75 -0
  102. package/dist/categories/gravity/acceleration-on1-by2.js.map +1 -0
  103. package/dist/categories/gravity/force-on1-by2.d.ts +87 -0
  104. package/dist/categories/gravity/force-on1-by2.d.ts.map +1 -0
  105. package/dist/categories/gravity/force-on1-by2.js +96 -0
  106. package/dist/categories/gravity/force-on1-by2.js.map +1 -0
  107. package/dist/categories/gravity/gravitational-force.d.ts +94 -0
  108. package/dist/categories/gravity/gravitational-force.d.ts.map +1 -0
  109. package/dist/categories/gravity/gravitational-force.js +119 -0
  110. package/dist/categories/gravity/gravitational-force.js.map +1 -0
  111. package/dist/categories/gravity/gravitational-parameter.d.ts +49 -0
  112. package/dist/categories/gravity/gravitational-parameter.d.ts.map +1 -0
  113. package/dist/categories/gravity/gravitational-parameter.js +61 -0
  114. package/dist/categories/gravity/gravitational-parameter.js.map +1 -0
  115. package/dist/{solve-kepler-bisection.d.ts → categories/kepler/solve-kepler-bisection.d.ts} +1 -1
  116. package/dist/categories/kepler/solve-kepler-bisection.d.ts.map +1 -0
  117. package/dist/{solve-kepler-bisection.js → categories/kepler/solve-kepler-bisection.js} +1 -1
  118. package/dist/categories/kepler/solve-kepler-bisection.js.map +1 -0
  119. package/dist/{solve-kepler-high-eccentricity.d.ts → categories/kepler/solve-kepler-high-eccentricity.d.ts} +2 -8
  120. package/dist/categories/kepler/solve-kepler-high-eccentricity.d.ts.map +1 -0
  121. package/dist/{solve-kepler-high-eccentricity.js → categories/kepler/solve-kepler-high-eccentricity.js} +5 -9
  122. package/dist/categories/kepler/solve-kepler-high-eccentricity.js.map +1 -0
  123. package/dist/{solve-kepler-newton-raphson.d.ts → categories/kepler/solve-kepler-newton-raphson.d.ts} +1 -1
  124. package/dist/categories/kepler/solve-kepler-newton-raphson.d.ts.map +1 -0
  125. package/dist/{solve-kepler-newton-raphson.js → categories/kepler/solve-kepler-newton-raphson.js} +1 -1
  126. package/dist/categories/kepler/solve-kepler-newton-raphson.js.map +1 -0
  127. package/dist/{solve-kepler.d.ts → categories/kepler/solve-kepler.d.ts} +1 -1
  128. package/dist/categories/kepler/solve-kepler.d.ts.map +1 -0
  129. package/dist/{solve-kepler.js → categories/kepler/solve-kepler.js} +2 -2
  130. package/dist/categories/kepler/solve-kepler.js.map +1 -0
  131. package/dist/categories/orbits/circular-speed.d.ts +42 -0
  132. package/dist/categories/orbits/circular-speed.d.ts.map +1 -0
  133. package/dist/categories/orbits/circular-speed.js +50 -0
  134. package/dist/categories/orbits/circular-speed.js.map +1 -0
  135. package/dist/categories/orbits/escape-speed.d.ts +50 -0
  136. package/dist/categories/orbits/escape-speed.d.ts.map +1 -0
  137. package/dist/categories/orbits/escape-speed.js +58 -0
  138. package/dist/categories/orbits/escape-speed.js.map +1 -0
  139. package/dist/categories/orbits/kepler-period.d.ts +45 -0
  140. package/dist/categories/orbits/kepler-period.d.ts.map +1 -0
  141. package/dist/categories/orbits/kepler-period.js +54 -0
  142. package/dist/categories/orbits/kepler-period.js.map +1 -0
  143. package/dist/categories/orbits/peri-apoapsis-radii.d.ts +46 -0
  144. package/dist/categories/orbits/peri-apoapsis-radii.d.ts.map +1 -0
  145. package/dist/categories/orbits/peri-apoapsis-radii.js +85 -0
  146. package/dist/categories/orbits/peri-apoapsis-radii.js.map +1 -0
  147. package/dist/categories/orbits/specific-angular-momentum-from-elements.d.ts +60 -0
  148. package/dist/categories/orbits/specific-angular-momentum-from-elements.d.ts.map +1 -0
  149. package/dist/categories/orbits/specific-angular-momentum-from-elements.js +76 -0
  150. package/dist/categories/orbits/specific-angular-momentum-from-elements.js.map +1 -0
  151. package/dist/categories/orbits/specific-angular-momentum.d.ts +55 -0
  152. package/dist/categories/orbits/specific-angular-momentum.d.ts.map +1 -0
  153. package/dist/categories/orbits/specific-angular-momentum.js +76 -0
  154. package/dist/categories/orbits/specific-angular-momentum.js.map +1 -0
  155. package/dist/categories/orbits/specific-mechanical-energy.d.ts +49 -0
  156. package/dist/categories/orbits/specific-mechanical-energy.d.ts.map +1 -0
  157. package/dist/categories/orbits/specific-mechanical-energy.js +57 -0
  158. package/dist/categories/orbits/specific-mechanical-energy.js.map +1 -0
  159. package/dist/categories/orbits/vis-viva-speed.d.ts +42 -0
  160. package/dist/categories/orbits/vis-viva-speed.d.ts.map +1 -0
  161. package/dist/categories/orbits/vis-viva-speed.js +70 -0
  162. package/dist/categories/orbits/vis-viva-speed.js.map +1 -0
  163. package/dist/index.d.ts +20 -10
  164. package/dist/index.d.ts.map +1 -1
  165. package/dist/index.js +25 -10
  166. package/dist/index.js.map +1 -1
  167. package/package.json +77 -5
  168. package/dist/__tests__/compute-mean-anomaly.int.spec.d.ts +0 -2
  169. package/dist/__tests__/compute-mean-anomaly.int.spec.d.ts.map +0 -1
  170. package/dist/__tests__/compute-mean-anomaly.int.spec.js.map +0 -1
  171. package/dist/__tests__/true-anomaly-to-mean-anomaly.int.spec.d.ts +0 -2
  172. package/dist/__tests__/true-anomaly-to-mean-anomaly.int.spec.d.ts.map +0 -1
  173. package/dist/__tests__/true-anomaly-to-mean-anomaly.int.spec.js.map +0 -1
  174. package/dist/compute-angle.d.ts.map +0 -1
  175. package/dist/compute-angle.js.map +0 -1
  176. package/dist/compute-mean-anomaly.d.ts.map +0 -1
  177. package/dist/compute-mean-anomaly.js.map +0 -1
  178. package/dist/eccentric-to-true-anomaly.d.ts.map +0 -1
  179. package/dist/eccentric-to-true-anomaly.js.map +0 -1
  180. package/dist/solve-kepler-bisection.d.ts.map +0 -1
  181. package/dist/solve-kepler-bisection.js.map +0 -1
  182. package/dist/solve-kepler-high-eccentricity.d.ts.map +0 -1
  183. package/dist/solve-kepler-high-eccentricity.js.map +0 -1
  184. package/dist/solve-kepler-newton-raphson.d.ts.map +0 -1
  185. package/dist/solve-kepler-newton-raphson.js.map +0 -1
  186. package/dist/solve-kepler.d.ts.map +0 -1
  187. package/dist/solve-kepler.js.map +0 -1
  188. package/dist/true-anomaly-to-mean-anomaly.d.ts.map +0 -1
  189. package/dist/true-anomaly-to-mean-anomaly.js.map +0 -1
  190. package/dist/wrap-angle.d.ts.map +0 -1
  191. package/dist/wrap-angle.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"solve-kepler.int.spec.js","sourceRoot":"","sources":["../../src/__tests__/solve-kepler.int.spec.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"solve-kepler.int.spec.js","sourceRoot":"","sources":["../../src/__tests__/solve-kepler.int.spec.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=specific-angular-momentum-from-elements.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"specific-angular-momentum-from-elements.spec.d.ts","sourceRoot":"","sources":["../../src/__tests__/specific-angular-momentum-from-elements.spec.ts"],"names":[],"mappings":""}
@@ -0,0 +1,86 @@
1
+ import assert from 'node:assert/strict';
2
+ import test, { describe } from 'node:test';
3
+ import { absClose, relClose } from './helpers';
4
+ import { specificAngularMomentumFromElements } from '../categories/orbits/specific-angular-momentum-from-elements';
5
+ describe('specificAngularMomentumFromElements', () => {
6
+ test('definition (elliptic): h = sqrt(μ a (1-e^2))', () => {
7
+ const mu = 3.986004418e14; // m^3/s^2 (Earth GM)
8
+ const a = 7000e3; // m
9
+ const e = 0.1; // -
10
+ const h = specificAngularMomentumFromElements(a, e, mu);
11
+ const expected = Math.sqrt(mu * a * (1 - e * e));
12
+ relClose(h, expected, 1e-15);
13
+ });
14
+ test('circular limit (e=0): h = sqrt(μ a)', () => {
15
+ const mu = 3.986004418e14;
16
+ const a = 6778e3;
17
+ const e = 0;
18
+ const h = specificAngularMomentumFromElements(a, e, mu);
19
+ const expected = Math.sqrt(mu * a);
20
+ relClose(h, expected, 1e-15);
21
+ });
22
+ test('hyperbolic case (a<0, e>1): radicand positive → valid h', () => {
23
+ const mu = 3.986004418e14;
24
+ const a = -50000000; // m
25
+ const e = 1.2; // -
26
+ const h = specificAngularMomentumFromElements(a, e, mu);
27
+ const expected = Math.sqrt(mu * a * (1 - e * e)); // positive since a<0 and (1-e^2)<0
28
+ relClose(h, expected, 1e-15);
29
+ });
30
+ test('tolerance clamp: tiny negative radicand → returns ~0', () => {
31
+ const mu = 3.986004418e14;
32
+ const a = 7000e3; // m (positive)
33
+ // Function tolerance: tol = |1e-14 * mu * |a||
34
+ const tol = Math.abs(1e-14 * mu * Math.abs(a));
35
+ // Target radicand = -tol/2: μ*a*(1-e^2) = -tol/2 => 1-e^2 = -(tol/2)/(μ*a)
36
+ const oneMinusE2 = -(tol / 2) / (mu * a);
37
+ const e = Math.sqrt(1 - oneMinusE2); // slightly > 1 (physically inconsistent with a>0), used only to hit tolerance path
38
+ const h = specificAngularMomentumFromElements(a, e, mu);
39
+ absClose(h, 0, 1e-12);
40
+ });
41
+ test('invalid: clearly negative radicand throws (a>0, e>1 far from 1)', () => {
42
+ const mu = 3.986004418e14;
43
+ const a = 7000e3; // m
44
+ const e = 1.1; // makes 1 - e^2 < 0 with a>0 → negative radicand
45
+ assert.throws(() => specificAngularMomentumFromElements(a, e, mu), /Invalid \(a,e\).*μ·a·\(1-e²\) < 0/);
46
+ });
47
+ test('μ = 0 → h = 0 (degenerate but mathematically consistent)', () => {
48
+ const mu = 0;
49
+ const a = 7000e3;
50
+ const e = 0.3;
51
+ const h = specificAngularMomentumFromElements(a, e, mu);
52
+ absClose(h, 0, 0);
53
+ });
54
+ test('scaling: for fixed e, h ∝ sqrt(|a|)', () => {
55
+ const mu = 3.986004418e14;
56
+ const e = 0.2;
57
+ const a1 = 8000e3;
58
+ const a2 = 2 * a1;
59
+ const h1 = specificAngularMomentumFromElements(a1, e, mu);
60
+ const h2 = specificAngularMomentumFromElements(a2, e, mu);
61
+ const expectedRatio = Math.sqrt(Math.abs(a2) / Math.abs(a1));
62
+ relClose(h2 / h1, expectedRatio, 1e-12);
63
+ });
64
+ test('input validation: a=0, non-finite a/e/μ, negative e, negative μ', () => {
65
+ const a = 7000e3;
66
+ const e = 0.1;
67
+ const mu = 3.986004418e14;
68
+ // a invalid
69
+ assert.throws(() => specificAngularMomentumFromElements(0, e, mu), /non-zero/);
70
+ assert.throws(() => specificAngularMomentumFromElements(Number.NaN, e, mu), /finite/);
71
+ // e invalid
72
+ assert.throws(() => specificAngularMomentumFromElements(a, -1e-3, mu), /≥ 0/);
73
+ assert.throws(() => specificAngularMomentumFromElements(a, Number.NaN, mu), /finite/);
74
+ // μ invalid
75
+ assert.throws(() => specificAngularMomentumFromElements(a, e, -1), /≥ 0/);
76
+ assert.throws(() => specificAngularMomentumFromElements(a, e, Number.NaN), /finite/);
77
+ });
78
+ test('numerical sanity: very large magnitudes still finite', () => {
79
+ const mu = 1e20;
80
+ const a = 1e9;
81
+ const e = 0.5;
82
+ const h = specificAngularMomentumFromElements(a, e, mu);
83
+ assert.ok(Number.isFinite(h) && h > 0);
84
+ });
85
+ });
86
+ //# sourceMappingURL=specific-angular-momentum-from-elements.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"specific-angular-momentum-from-elements.spec.js","sourceRoot":"","sources":["../../src/__tests__/specific-angular-momentum-from-elements.spec.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=specific-angular-momentum.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"specific-angular-momentum.spec.d.ts","sourceRoot":"","sources":["../../src/__tests__/specific-angular-momentum.spec.ts"],"names":[],"mappings":""}
@@ -0,0 +1,84 @@
1
+ import assert from 'node:assert/strict';
2
+ import test, { describe } from 'node:test';
3
+ import { absClose, dot, norm, relClose } from './helpers';
4
+ import { specificAngularMomentum } from '../categories/orbits/specific-angular-momentum';
5
+ describe('specificAngularMomentum', () => {
6
+ test('orthogonal state: r ⟂ v → h = r * v', () => {
7
+ const r = [6778e3, 0, 0]; // m
8
+ const v = [0, 7.67e3, 0]; // m/s
9
+ const h = specificAngularMomentum(r, v);
10
+ const expected = norm(r) * norm(v); // r*v_perp (since perp)
11
+ relClose(h, expected, 1e-14);
12
+ });
13
+ test('manual cross vs function: ||r×v|| matches', () => {
14
+ const r = [1.2e7, -3.4e6, 5.6e6];
15
+ const v = [-7.8e3, 9.1e3, 2.3e3];
16
+ const hx = r[1] * v[2] - r[2] * v[1];
17
+ const hy = r[2] * v[0] - r[0] * v[2];
18
+ const hz = r[0] * v[1] - r[1] * v[0];
19
+ const expected = Math.hypot(hx, hy, hz);
20
+ const h = specificAngularMomentum(r, v);
21
+ relClose(h, expected, 1e-15);
22
+ });
23
+ test('scalar identity: h = |r| |v| sin(theta)', () => {
24
+ const r = [7e6, 2e6, -1e6];
25
+ const v = [1e3, -7e3, 4e3];
26
+ const rr = norm(r);
27
+ const vv = norm(v);
28
+ const cosT = dot(r, v) / (rr * vv);
29
+ const sinT = Math.sqrt(Math.max(0, 1 - cosT * cosT));
30
+ const expected = rr * vv * sinT;
31
+ const h = specificAngularMomentum(r, v);
32
+ relClose(h, expected, 1e-12);
33
+ });
34
+ test('parallel vectors (purely radial) → h = 0', () => {
35
+ const r = [8e6, -2e6, 4e6];
36
+ const k = 3.5e-3; // arbitrary scale to mimic m/s
37
+ const v = [k * r[0], k * r[1], k * r[2]];
38
+ const h = specificAngularMomentum(r, v);
39
+ absClose(h, 0, 1e-12);
40
+ });
41
+ test('zero velocity → h = 0', () => {
42
+ const r = [7e6, 0, 0];
43
+ const v = [0, 0, 0];
44
+ const h = specificAngularMomentum(r, v);
45
+ absClose(h, 0, 1e-12);
46
+ });
47
+ test('rotation invariance of magnitude (rotate 90° about z)', () => {
48
+ const r = [5e6, 2e6, 0];
49
+ const v = [1e3, 3e3, 0];
50
+ const h1 = specificAngularMomentum(r, v);
51
+ // 90° rotation about z: (x,y) -> (-y, x)
52
+ const r2 = [-r[1], r[0], 0];
53
+ const v2 = [-v[1], v[0], 0];
54
+ const h2 = specificAngularMomentum(r2, v2);
55
+ relClose(h2, h1, 1e-15);
56
+ });
57
+ test('units sanity (circular identity): h ≈ sqrt(mu * r) with v_c = sqrt(mu/r)', () => {
58
+ const mu = 3.986004418e14; // Earth GM
59
+ const r = [6778e3, 0, 0];
60
+ const v = [0, Math.sqrt(mu / r[0]), 0];
61
+ const h = specificAngularMomentum(r, v);
62
+ const expected = Math.sqrt(mu * r[0]);
63
+ relClose(h, expected, 1e-12);
64
+ });
65
+ test('input validation: non-finite components throw', () => {
66
+ const rOK = [7e6, 0, 0];
67
+ const vOK = [0, 7.5e3, 0];
68
+ assert.throws(() => specificAngularMomentum([Number.NaN, 0, 0], vOK), /finite/);
69
+ assert.throws(() => specificAngularMomentum([Infinity, 0, 0], vOK), /finite/);
70
+ assert.throws(() => specificAngularMomentum(rOK, [0, Number.NaN, 0]), /finite/);
71
+ });
72
+ test('input validation: zero-length position vector throws', () => {
73
+ const rZero = [0, 0, 0];
74
+ const v = [1e3, 2e3, 3e3];
75
+ assert.throws(() => specificAngularMomentum(rZero, v), /non-zero/);
76
+ });
77
+ test('numerical stability: very large magnitudes still finite', () => {
78
+ const r = [1e9, 1e9, 1e9];
79
+ const v = [1e5, -2e5, 3e5];
80
+ const h = specificAngularMomentum(r, v);
81
+ assert.ok(Number.isFinite(h) && h >= 0);
82
+ });
83
+ });
84
+ //# sourceMappingURL=specific-angular-momentum.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"specific-angular-momentum.spec.js","sourceRoot":"","sources":["../../src/__tests__/specific-angular-momentum.spec.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=specific-mechanical-energy.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"specific-mechanical-energy.spec.d.ts","sourceRoot":"","sources":["../../src/__tests__/specific-mechanical-energy.spec.ts"],"names":[],"mappings":""}
@@ -0,0 +1,81 @@
1
+ import assert from 'node:assert/strict';
2
+ import test, { describe } from 'node:test';
3
+ import { specificMechanicalEnergy } from '../categories/orbits/specific-mechanical-energy';
4
+ import { absClose, relClose } from './helpers';
5
+ describe('specificMechanicalEnergy', () => {
6
+ test('circular orbit: ε = -μ/(2r) when v = sqrt(μ/r)', () => {
7
+ const mu = 3.986004418e14; // m^3/s^2 (Earth GM)
8
+ const r = 6378e3 + 400e3; // m (LEO-ish)
9
+ const v = Math.sqrt(mu / r); // m/s
10
+ const eps = specificMechanicalEnergy(v, r, mu);
11
+ const expected = -mu / (2 * r);
12
+ relClose(eps, expected, 1e-12);
13
+ });
14
+ test('parabolic case: v = sqrt(2μ/r) → ε ≈ 0', () => {
15
+ const mu = 3.986004418e14; // m^3/s^2
16
+ const r = 7000e3; // m
17
+ const v = Math.sqrt((2 * mu) / r);
18
+ const eps = specificMechanicalEnergy(v, r, mu);
19
+ // Use absolute tolerance because the expected value is 0
20
+ absClose(eps, 0, 1e-9);
21
+ });
22
+ test('hyperbolic case: v slightly above escape → ε > 0', () => {
23
+ const mu = 3.986004418e14;
24
+ const r = 7000e3;
25
+ const v_escape = Math.sqrt((2 * mu) / r);
26
+ const v = 1.01 * v_escape;
27
+ const eps = specificMechanicalEnergy(v, r, mu);
28
+ assert.ok(eps > 0, 'ε should be positive for hyperbolic cases');
29
+ });
30
+ test('elliptic case: v below circular → ε < 0', () => {
31
+ const mu = 3.986004418e14;
32
+ const r = 7000e3;
33
+ const v_circ = Math.sqrt(mu / r);
34
+ const v = 0.95 * v_circ;
35
+ const eps = specificMechanicalEnergy(v, r, mu);
36
+ assert.ok(eps < 0, 'ε should be negative for bound (elliptic) cases');
37
+ });
38
+ test('semi-major axis identity: ε = -μ/(2a) (using vis-viva for v)', () => {
39
+ const mu = 3.986004418e14;
40
+ const a = 10000e3; // m (semi-major axis)
41
+ const r = 8000e3; // m (some point on the ellipse)
42
+ const v = Math.sqrt(mu * (2 / r - 1 / a)); // vis-viva
43
+ const eps = specificMechanicalEnergy(v, r, mu);
44
+ const expected = -mu / (2 * a);
45
+ relClose(eps, expected, 1e-12);
46
+ });
47
+ test('monotonic in speed: increasing v increases ε (same r, μ)', () => {
48
+ const mu = 3.986004418e14;
49
+ const r = 8000e3;
50
+ const v1 = 7000;
51
+ const v2 = 7500;
52
+ const eps1 = specificMechanicalEnergy(v1, r, mu);
53
+ const eps2 = specificMechanicalEnergy(v2, r, mu);
54
+ assert.ok(eps2 > eps1);
55
+ });
56
+ test('increases with radius for fixed v: larger r → larger ε (less negative)', () => {
57
+ const mu = 3.986004418e14;
58
+ const v = 7500;
59
+ const r1 = 7000e3;
60
+ const r2 = 8000e3;
61
+ const eps1 = specificMechanicalEnergy(v, r1, mu);
62
+ const eps2 = specificMechanicalEnergy(v, r2, mu);
63
+ assert.ok(eps2 > eps1);
64
+ });
65
+ test('throws on invalid inputs', () => {
66
+ const mu = 3.986004418e14;
67
+ const r = 7000e3;
68
+ const v = 7500;
69
+ // v invalid
70
+ assert.throws(() => specificMechanicalEnergy(Number.NaN, r, mu), /non-negative/);
71
+ assert.throws(() => specificMechanicalEnergy(-1, r, mu), /non-negative/);
72
+ // r invalid
73
+ assert.throws(() => specificMechanicalEnergy(v, Number.NaN, mu), /positive/);
74
+ assert.throws(() => specificMechanicalEnergy(v, 0, mu), /positive/);
75
+ assert.throws(() => specificMechanicalEnergy(v, -1, mu), /positive/);
76
+ // mu invalid
77
+ assert.throws(() => specificMechanicalEnergy(v, r, Number.NaN), /non-negative/);
78
+ assert.throws(() => specificMechanicalEnergy(v, r, -1), /non-negative/);
79
+ });
80
+ });
81
+ //# sourceMappingURL=specific-mechanical-energy.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"specific-mechanical-energy.spec.js","sourceRoot":"","sources":["../../src/__tests__/specific-mechanical-energy.spec.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=true-to-mean-anomaly.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"true-to-mean-anomaly.spec.d.ts","sourceRoot":"","sources":["../../src/__tests__/true-to-mean-anomaly.spec.ts"],"names":[],"mappings":""}
@@ -1,46 +1,46 @@
1
1
  import assert from 'node:assert/strict';
2
2
  import test, { describe } from 'node:test';
3
- import { trueAnomalyToMeanAnomaly } from '../true-anomaly-to-mean-anomaly';
4
- import { wrapAngle } from '../wrap-angle';
5
- describe('trueAnomalyToMeanAnomaly', () => {
3
+ import { trueToMeanAnomaly } from '../categories/anomalies/true-to-mean-anomaly';
4
+ import { wrapAngle } from '../categories/angle/wrap-angle';
5
+ describe('trueToMeanAnomaly', () => {
6
6
  const EPSILON = 1e-10; // Floating-point tolerance
7
7
  const assertApproxEqual = (actual, expected) => {
8
8
  assert.ok(Math.abs(actual - expected) < EPSILON, `Expected ~${expected}, got ${actual}`);
9
9
  };
10
10
  test('Circular Orbit (e = 0)', () => {
11
- const result = trueAnomalyToMeanAnomaly(Math.PI / 3, 0); // e = 0 (should be identity)
11
+ const result = trueToMeanAnomaly(Math.PI / 3, 0); // e = 0 (should be identity)
12
12
  assertApproxEqual(result, wrapAngle(Math.PI / 3));
13
13
  });
14
14
  test('Zero True Anomaly (V = 0)', () => {
15
- const result = trueAnomalyToMeanAnomaly(0, 0.5);
15
+ const result = trueToMeanAnomaly(0, 0.5);
16
16
  assertApproxEqual(result, 0);
17
17
  });
18
18
  test('True Anomaly at π/2 (90°)', () => {
19
- const result = trueAnomalyToMeanAnomaly(Math.PI / 2, 0.5);
19
+ const result = trueToMeanAnomaly(Math.PI / 2, 0.5);
20
20
  const expectedM = 0.6141848493043778; // Corrected expected value
21
21
  assertApproxEqual(result, expectedM);
22
22
  });
23
23
  test('True Anomaly at π (Apoapsis)', () => {
24
- const result = trueAnomalyToMeanAnomaly(Math.PI, 0.5);
24
+ const result = trueToMeanAnomaly(Math.PI, 0.5);
25
25
  const expectedM = wrapAngle(Math.PI); // Mean anomaly should be equal to π
26
26
  assertApproxEqual(result, expectedM);
27
27
  });
28
28
  test('True Anomaly at 3π/2 (270°)', () => {
29
- const result = trueAnomalyToMeanAnomaly((3 * Math.PI) / 2, 0.5);
29
+ const result = trueToMeanAnomaly((3 * Math.PI) / 2, 0.5);
30
30
  const expectedM = -0.6141848493043782; // Corrected expected value
31
31
  assertApproxEqual(result, expectedM);
32
32
  });
33
33
  test('True Anomaly at 2π (Periapsis)', () => {
34
- const result = trueAnomalyToMeanAnomaly(2 * Math.PI, 0.5);
34
+ const result = trueToMeanAnomaly(2 * Math.PI, 0.5);
35
35
  assertApproxEqual(result, 0); // Should return to zero
36
36
  });
37
37
  test('Eccentricity Out of Bounds Throws Error', () => {
38
- assert.throws(() => trueAnomalyToMeanAnomaly(Math.PI / 3, -0.1), RangeError);
39
- assert.throws(() => trueAnomalyToMeanAnomaly(Math.PI / 3, 1.1), RangeError);
38
+ assert.throws(() => trueToMeanAnomaly(Math.PI / 3, -0.1), RangeError);
39
+ assert.throws(() => trueToMeanAnomaly(Math.PI / 3, 1.1), RangeError);
40
40
  });
41
41
  test('Large Eccentricity (e close to 1)', () => {
42
- const result = trueAnomalyToMeanAnomaly(Math.PI / 4, 0.99);
42
+ const result = trueToMeanAnomaly(Math.PI / 4, 0.99);
43
43
  assert.ok(result >= 0 && result < 2 * Math.PI, `Expected result in range [0, 2π], got ${result}`);
44
44
  });
45
45
  });
46
- //# sourceMappingURL=true-anomaly-to-mean-anomaly.int.spec.js.map
46
+ //# sourceMappingURL=true-to-mean-anomaly.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"true-to-mean-anomaly.spec.js","sourceRoot":"","sources":["../../src/__tests__/true-to-mean-anomaly.spec.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=vis-viva-speed.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"vis-viva-speed.spec.d.ts","sourceRoot":"","sources":["../../src/__tests__/vis-viva-speed.spec.ts"],"names":[],"mappings":""}
@@ -0,0 +1,80 @@
1
+ import assert from 'node:assert/strict';
2
+ import test, { describe } from 'node:test';
3
+ import { absClose, relClose } from './helpers';
4
+ import { visVivaSpeed } from '../categories/orbits/vis-viva-speed';
5
+ describe('visVivaSpeed', () => {
6
+ test('circular orbit: a = r → v = sqrt(μ/r)', () => {
7
+ const mu = 3.986004418e14; // m^3/s^2 (Earth GM)
8
+ const r = 6778e3; // m (LEO-ish)
9
+ const a = r;
10
+ const v = visVivaSpeed(r, a, mu);
11
+ const expected = Math.sqrt(mu / r);
12
+ relClose(v, expected, 1e-12);
13
+ });
14
+ test('parabolic trajectory: a = Infinity → v = sqrt(2μ/r)', () => {
15
+ const mu = 3.986004418e14;
16
+ const r = 7000e3;
17
+ const v = visVivaSpeed(r, Infinity, mu);
18
+ const expected = Math.sqrt((2 * mu) / r);
19
+ relClose(v, expected, 1e-12);
20
+ });
21
+ test('hyperbolic case: a < 0 uses same formula and yields valid speed', () => {
22
+ const mu = 3.986004418e14;
23
+ const r = 10000e3;
24
+ const a = -15000e3; // negative semi-major axis
25
+ const v = visVivaSpeed(r, a, mu);
26
+ const expected = Math.sqrt(mu * (2 / r - 1 / a));
27
+ relClose(v, expected, 1e-12);
28
+ });
29
+ test('radicand zero boundary: choose a such that 2/r - 1/a = 0 → v = 0', () => {
30
+ const mu = 3.986004418e14;
31
+ const r = 8000e3;
32
+ const a = r / 2; // 1/a = 2/r
33
+ const v = visVivaSpeed(r, a, mu);
34
+ absClose(v, 0, 1e-12);
35
+ });
36
+ test('tiny negative radicand (within tolerance) is clamped to v ≈ 0', () => {
37
+ const mu = 3.986004418e14;
38
+ const r = 8000e3;
39
+ // Function's tolerance: tol = |1e-14 * mu / r|
40
+ const tol = Math.abs((1e-14 * mu) / r);
41
+ const delta = tol / (2 * mu); // makes radicand = μ*(2/r - 1/a) = -tol/2
42
+ // Choose 1/a = 2/r + delta → a = 1 / (2/r + delta)
43
+ const a = 1 / (2 / r + delta);
44
+ const v = visVivaSpeed(r, a, mu);
45
+ absClose(v, 0, 1e-12);
46
+ });
47
+ test('significantly negative radicand throws (physically impossible state)', () => {
48
+ const mu = 3.986004418e14;
49
+ const r = 8000e3;
50
+ const a = r / 4; // 1/a = 4/r -> 2/r - 1/a = -2/r (negative)
51
+ assert.throws(() => visVivaSpeed(r, a, mu), /Invalid state: μ\*\(2\/r - 1\/a\) < 0/);
52
+ });
53
+ test('monotonic with radius for fixed a, μ: larger r → smaller v (ellipse domain)', () => {
54
+ const mu = 3.986004418e14;
55
+ const a = 10000e3; // ellipse: r must be < 2a
56
+ const r1 = 8000e3;
57
+ const r2 = 15000e3; // < 2a = 20000 km
58
+ const v1 = visVivaSpeed(r1, a, mu);
59
+ const v2 = visVivaSpeed(r2, a, mu);
60
+ assert.ok(v1 > v2, 'speed should decrease as radius increases (for fixed a)');
61
+ });
62
+ test('input validation: r<=0, mu<0/NaN, a non-finite (except +Infinity), a=0', () => {
63
+ const mu = 3.986004418e14;
64
+ const r = 7000e3;
65
+ const a = r;
66
+ // r invalid
67
+ assert.throws(() => visVivaSpeed(0, a, mu), /positive/);
68
+ assert.throws(() => visVivaSpeed(-1, a, mu), /positive/);
69
+ assert.throws(() => visVivaSpeed(Number.NaN, a, mu), /finite/);
70
+ // mu invalid
71
+ assert.throws(() => visVivaSpeed(r, a, -1), /non-negative/);
72
+ assert.throws(() => visVivaSpeed(r, a, Number.NaN), /finite/);
73
+ // a invalid (non-finite other than +Infinity)
74
+ assert.throws(() => visVivaSpeed(r, Number.NaN, mu), /finite/);
75
+ assert.throws(() => visVivaSpeed(r, Number.NEGATIVE_INFINITY, mu), /finite/);
76
+ // a = 0 invalid
77
+ assert.throws(() => visVivaSpeed(r, 0, mu), /non-zero/);
78
+ });
79
+ });
80
+ //# sourceMappingURL=vis-viva-speed.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"vis-viva-speed.spec.js","sourceRoot":"","sources":["../../src/__tests__/vis-viva-speed.spec.ts"],"names":[],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  import assert from 'node:assert';
2
2
  import { describe, test } from 'node:test';
3
- import { wrapAngle } from '../wrap-angle';
3
+ import { wrapAngle } from '../categories/angle/wrap-angle';
4
4
  const EPSILON = 1e-10; // Small tolerance for floating-point comparisons
5
5
  const assertApproxEqual = (actual, expected) => {
6
6
  assert.ok(Math.abs(actual - expected) < EPSILON, `Expected ~${expected}, got ${actual}`);
@@ -1 +1 @@
1
- {"version":3,"file":"wrap-angle.spec.js","sourceRoot":"","sources":["../../src/__tests__/wrap-angle.spec.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"wrap-angle.spec.js","sourceRoot":"","sources":["../../src/__tests__/wrap-angle.spec.ts"],"names":[],"mappings":"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"}
@@ -63,7 +63,7 @@ import type { CelestialBodyType, Radians, TimeStepInterface } from '@interstella
63
63
  * @see [True Anomaly (Wikipedia)](https://en.wikipedia.org/wiki/True_anomaly)
64
64
  * @see [Mean Anomaly (Wikipedia)](https://en.wikipedia.org/wiki/Mean_anomaly)
65
65
  * @see [Orbital Mechanics (NASA)](https://solarsystem.nasa.gov/basics/chapter2-2/)
66
- * @category Angle
66
+ * @group Angles
67
67
  */
68
68
  export declare const computeAngle: (body: CelestialBodyType, timeStep: TimeStepInterface) => Radians;
69
69
  //# sourceMappingURL=compute-angle.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"compute-angle.d.ts","sourceRoot":"","sources":["../../../src/categories/angle/compute-angle.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,iBAAiB,EACjB,OAAO,EACP,iBAAiB,EAClB,MAAM,2BAA2B,CAAC;AAMnC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAiEG;AACH,eAAO,MAAM,YAAY,GACvB,MAAM,iBAAiB,EACvB,UAAU,iBAAiB,KAC1B,OASF,CAAC"}
@@ -1,6 +1,6 @@
1
- import { computeMeanAnomaly } from './compute-mean-anomaly';
2
- import { eccentricToTrueAnomaly } from './eccentric-to-true-anomaly';
3
- import { solveKepler } from './solve-kepler';
1
+ import { eccentricToTrueAnomaly } from '../anomalies/eccentric-to-true-anomaly';
2
+ import { meanToEccentricAnomaly } from '../anomalies/mean-to-eccentric-anomaly';
3
+ import { solveKepler } from '../kepler/solve-kepler';
4
4
  /**
5
5
  * Computes the orbital angle (true anomaly, $ν$) of a celestial body for a given date and time step.
6
6
  *
@@ -65,11 +65,11 @@ import { solveKepler } from './solve-kepler';
65
65
  * @see [True Anomaly (Wikipedia)](https://en.wikipedia.org/wiki/True_anomaly)
66
66
  * @see [Mean Anomaly (Wikipedia)](https://en.wikipedia.org/wiki/Mean_anomaly)
67
67
  * @see [Orbital Mechanics (NASA)](https://solarsystem.nasa.gov/basics/chapter2-2/)
68
- * @category Angle
68
+ * @group Angles
69
69
  */
70
70
  export const computeAngle = (body, timeStep) => {
71
71
  // Compute mean anomaly (M) with time step
72
- const M = computeMeanAnomaly(body, timeStep);
72
+ const M = meanToEccentricAnomaly(body, timeStep);
73
73
  // Solve Kepler's equation for eccentric anomaly (E)
74
74
  const E = solveKepler(M, body.e);
75
75
  // Convert eccentric anomaly (E) to true anomaly (ν)
@@ -0,0 +1 @@
1
+ {"version":3,"file":"compute-angle.js","sourceRoot":"","sources":["../../../src/categories/angle/compute-angle.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,sBAAsB,EAAE,MAAM,wCAAwC,CAAC;AAChF,OAAO,EAAE,sBAAsB,EAAE,MAAM,wCAAwC,CAAC;AAChF,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AAErD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAiEG;AACH,MAAM,CAAC,MAAM,YAAY,GAAG,CAC1B,IAAuB,EACvB,QAA2B,EAClB,EAAE;IACX,0CAA0C;IAC1C,MAAM,CAAC,GAAY,sBAAsB,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;IAC1D,oDAAoD;IACpD,MAAM,CAAC,GAAY,WAAW,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC;IAC1C,oDAAoD;IACpD,MAAM,CAAC,GAAY,sBAAsB,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC;IAErD,OAAO,CAAC,CAAC;AACX,CAAC,CAAC"}
@@ -76,7 +76,7 @@
76
76
  * // Preserve negative values under 2π
77
77
  * wrapAngle(-0.1); // → -0.1
78
78
  * ```
79
- * @category Angle
79
+ * @group Angles
80
80
  */
81
81
  export declare const wrapAngle: (angle: number) => number;
82
82
  //# sourceMappingURL=wrap-angle.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"wrap-angle.d.ts","sourceRoot":"","sources":["../../../src/categories/angle/wrap-angle.ts"],"names":[],"mappings":"AAKA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA+EG;AACH,eAAO,MAAM,SAAS,GAAI,OAAO,MAAM,WAgBtC,CAAC"}
@@ -79,7 +79,7 @@ const LARGE_EPSILON = 1e-8; // Higher tolerance for large angles
79
79
  * // Preserve negative values under 2π
80
80
  * wrapAngle(-0.1); // → -0.1
81
81
  * ```
82
- * @category Angle
82
+ * @group Angles
83
83
  */
84
84
  export const wrapAngle = (angle) => {
85
85
  // Reduce angle while preserving sign
@@ -0,0 +1 @@
1
+ {"version":3,"file":"wrap-angle.js","sourceRoot":"","sources":["../../../src/categories/angle/wrap-angle.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,+BAA+B,CAAC;AAEvD,MAAM,OAAO,GAAG,KAAK,CAAC,CAAC,2CAA2C;AAClE,MAAM,aAAa,GAAG,IAAI,CAAC,CAAC,oCAAoC;AAEhE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA+EG;AACH,MAAM,CAAC,MAAM,SAAS,GAAG,CAAC,KAAa,EAAE,EAAE;IACzC,qCAAqC;IACrC,KAAK,GAAG,KAAK,GAAG,MAAM,CAAC;IAEvB,yCAAyC;IACzC,IAAI,IAAI,CAAC,GAAG,CAAC,KAAK,GAAG,MAAM,CAAC,GAAG,OAAO;QAAE,OAAO,CAAC,CAAC;IAEjD,IAAI,IAAI,CAAC,GAAG,CAAC,KAAK,GAAG,MAAM,CAAC,GAAG,OAAO;QAAE,OAAO,CAAC,CAAC;IAEjD,IACE,IAAI,CAAC,GAAG,CAAC,KAAK,GAAG,MAAM,CAAC,GAAG,aAAa;QACxC,IAAI,CAAC,GAAG,CAAC,KAAK,GAAG,MAAM,CAAC,GAAG,aAAa;QAExC,OAAO,CAAC,CAAC;IAEX,OAAO,KAAK,CAAC;AACf,CAAC,CAAC"}