@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
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=circular-speed.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"circular-speed.spec.d.ts","sourceRoot":"","sources":["../../src/__tests__/circular-speed.spec.ts"],"names":[],"mappings":""}
@@ -0,0 +1,69 @@
1
+ import assert from 'node:assert/strict';
2
+ import test, { describe } from 'node:test';
3
+ import { absClose, relClose } from './helpers';
4
+ import { circularSpeed } from '../categories/orbits/circular-speed';
5
+ describe('circularSpeed', () => {
6
+ test('LEO (~400 km) around Earth: v ≈ 7.67 km/s', () => {
7
+ const mu = 3.986004418e14; // m^3/s^2
8
+ const r = 6378e3 + 400e3; // m
9
+ const v = circularSpeed(r, mu);
10
+ const expected = Math.sqrt(mu / r);
11
+ relClose(v, expected, 1e-12);
12
+ assert.ok(v > 7400 && v < 7900, `unexpected LEO speed: ${v} m/s`);
13
+ });
14
+ test('GEO (~42,164 km): v ≈ 3074 m/s', () => {
15
+ const mu = 3.986004418e14;
16
+ const r = 42164e3;
17
+ const v = circularSpeed(r, mu);
18
+ const expected = Math.sqrt(mu / r);
19
+ relClose(v, expected, 1e-12);
20
+ // loose real-world check
21
+ const ref = 3074; // m/s
22
+ relClose(v, ref, 0.02); // within 2%
23
+ });
24
+ test('Heliocentric at 1 AU: v ≈ 29.78 km/s', () => {
25
+ const muSun = 1.32712440018e20; // m^3/s^2
26
+ const AU = 149597870700; // m
27
+ const v = circularSpeed(AU, muSun);
28
+ const ref = 29780; // m/s
29
+ relClose(v, ref, 0.01); // within 1%
30
+ });
31
+ test('Scaling with μ: doubling μ increases v by √2 (same r)', () => {
32
+ const r = 7000e3;
33
+ const mu = 3.986004418e14;
34
+ const v1 = circularSpeed(r, mu);
35
+ const v2 = circularSpeed(r, 2 * mu);
36
+ relClose(v2 / v1, Math.SQRT2, 1e-12);
37
+ });
38
+ test('Scaling with r: quadrupling r halves v (same μ)', () => {
39
+ const mu = 3.986004418e14;
40
+ const r1 = 7000e3;
41
+ const r2 = 4 * r1;
42
+ const v1 = circularSpeed(r1, mu);
43
+ const v2 = circularSpeed(r2, mu);
44
+ relClose(v2 / v1, 0.5, 1e-12);
45
+ });
46
+ test('Degenerate case: μ = 0 → v = 0', () => {
47
+ const r = 7000e3;
48
+ const v = circularSpeed(r, 0);
49
+ absClose(v, 0, 1e-15);
50
+ });
51
+ test('Input validation: r<=0, non-finite r; μ<0, non-finite μ', () => {
52
+ const r = 7000e3;
53
+ const mu = 3.986004418e14;
54
+ // r invalid
55
+ assert.throws(() => circularSpeed(0, mu), /positive/);
56
+ assert.throws(() => circularSpeed(-1, mu), /positive/);
57
+ assert.throws(() => circularSpeed(Number.NaN, mu), /finite/);
58
+ // μ invalid
59
+ assert.throws(() => circularSpeed(r, -1), /non-negative/);
60
+ assert.throws(() => circularSpeed(r, Number.NaN), /finite/);
61
+ });
62
+ test('Numerical sanity: extremely large/small-but-valid values remain finite', () => {
63
+ const v1 = circularSpeed(1e3, 1e9); // small r, large μ
64
+ const v2 = circularSpeed(1e12, 1e6); // huge r, small μ
65
+ assert.ok(Number.isFinite(v1) && v1 > 0);
66
+ assert.ok(Number.isFinite(v2) && v2 > 0);
67
+ });
68
+ });
69
+ //# sourceMappingURL=circular-speed.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"circular-speed.spec.js","sourceRoot":"","sources":["../../src/__tests__/circular-speed.spec.ts"],"names":[],"mappings":"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"}
@@ -1,7 +1,7 @@
1
1
  import assert from 'node:assert/strict';
2
2
  import test, { describe } from 'node:test';
3
- import { computeAngle } from '../compute-angle';
4
- import { wrapAngle } from '../wrap-angle';
3
+ import { computeAngle } from '../categories/angle/compute-angle';
4
+ import { wrapAngle } from '../categories/angle/wrap-angle';
5
5
  describe('computeAngle', () => {
6
6
  // Test cases
7
7
  const testCases = [
@@ -1 +1 @@
1
- {"version":3,"file":"compute-angle.int.spec.js","sourceRoot":"","sources":["../../src/__tests__/compute-angle.int.spec.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"compute-angle.int.spec.js","sourceRoot":"","sources":["../../src/__tests__/compute-angle.int.spec.ts"],"names":[],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  import assert from 'node:assert/strict';
2
2
  import test, { describe } from 'node:test';
3
- import { eccentricToTrueAnomaly } from '../eccentric-to-true-anomaly';
3
+ import { eccentricToTrueAnomaly } from '../categories/anomalies/eccentric-to-true-anomaly';
4
4
  describe('eccentricToTrueAnomaly', () => {
5
5
  // Test cases for eccentricToTrueAnomaly
6
6
  const testCases = [
@@ -1 +1 @@
1
- {"version":3,"file":"eccentric-to-true-anomaly.spec.js","sourceRoot":"","sources":["../../src/__tests__/eccentric-to-true-anomaly.spec.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"eccentric-to-true-anomaly.spec.js","sourceRoot":"","sources":["../../src/__tests__/eccentric-to-true-anomaly.spec.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=escape-speed.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"escape-speed.spec.d.ts","sourceRoot":"","sources":["../../src/__tests__/escape-speed.spec.ts"],"names":[],"mappings":""}
@@ -0,0 +1,79 @@
1
+ import assert from 'node:assert/strict';
2
+ import test, { describe } from 'node:test';
3
+ import { escapeSpeed } from '../categories/orbits/escape-speed';
4
+ import { absClose, relClose } from './helpers';
5
+ describe('escapeSpeed', () => {
6
+ test('definition check: v_esc = sqrt(2μ/r)', () => {
7
+ const mu = 3.986004418e14; // m^3/s^2 (Earth GM)
8
+ const r = 7000e3; // m
9
+ const v = escapeSpeed(r, mu);
10
+ const expected = Math.sqrt((2 * mu) / r);
11
+ relClose(v, expected, 1e-15);
12
+ });
13
+ test('relationship to circular speed: v_esc = √2 * √(μ/r)', () => {
14
+ const mu = 3.986004418e14;
15
+ const r = 7000e3;
16
+ const vEsc = escapeSpeed(r, mu);
17
+ const vCirc = Math.sqrt(mu / r);
18
+ relClose(vEsc / vCirc, Math.SQRT2, 1e-15);
19
+ });
20
+ test('Earth surface ~6378 km: v_esc ≈ 11.186 km/s', () => {
21
+ const mu = 3.986004418e14;
22
+ const rSurface = 6378e3;
23
+ const v = escapeSpeed(rSurface, mu);
24
+ const ref = 11186; // m/s
25
+ relClose(v, ref, 0.01); // within 1%
26
+ });
27
+ test('LEO (~400 km): v_esc ≈ 10.86 km/s', () => {
28
+ const mu = 3.986004418e14;
29
+ const rLeo = 6378e3 + 400e3;
30
+ const v = escapeSpeed(rLeo, mu);
31
+ const ref = 10860; // m/s
32
+ relClose(v, ref, 0.02); // within 2%
33
+ });
34
+ test('scaling with μ: doubling μ → v scales by √2 (same r)', () => {
35
+ const r = 7000e3;
36
+ const mu = 3.986004418e14;
37
+ const v1 = escapeSpeed(r, mu);
38
+ const v2 = escapeSpeed(r, 2 * mu);
39
+ relClose(v2 / v1, Math.SQRT2, 1e-15);
40
+ });
41
+ test('scaling with r: quadrupling r → v halves (same μ)', () => {
42
+ const mu = 3.986004418e14;
43
+ const r1 = 7000e3;
44
+ const r2 = 4 * r1;
45
+ const v1 = escapeSpeed(r1, mu);
46
+ const v2 = escapeSpeed(r2, mu);
47
+ relClose(v2 / v1, 0.5, 1e-15);
48
+ });
49
+ test('dimensionless identity: (v^2 * r) / (2μ) ≈ 1', () => {
50
+ const mu = 1.2345e12;
51
+ const r = 3.21e7;
52
+ const v = escapeSpeed(r, mu);
53
+ const ratio = (v * v * r) / (2 * mu);
54
+ relClose(ratio, 1, 1e-12);
55
+ });
56
+ test('degenerate case μ = 0 → v_esc = 0', () => {
57
+ const r = 7000e3;
58
+ const v = escapeSpeed(r, 0);
59
+ absClose(v, 0, 1e-15);
60
+ });
61
+ test('input validation: r<=0, non-finite r; μ<0, non-finite μ throw', () => {
62
+ const r = 7000e3;
63
+ const mu = 3.986004418e14;
64
+ // r invalid
65
+ assert.throws(() => escapeSpeed(0, mu), /positive/);
66
+ assert.throws(() => escapeSpeed(-1, mu), /positive/);
67
+ assert.throws(() => escapeSpeed(Number.NaN, mu), /finite/);
68
+ // μ invalid
69
+ assert.throws(() => escapeSpeed(r, -1), /non-negative/);
70
+ assert.throws(() => escapeSpeed(r, Number.NaN), /finite/);
71
+ });
72
+ test('numerical sanity: extreme but valid values remain finite and positive', () => {
73
+ const v1 = escapeSpeed(1e3, 1e9); // small r, large μ
74
+ const v2 = escapeSpeed(1e12, 1e6); // large r, small μ
75
+ assert.ok(Number.isFinite(v1) && v1 > 0);
76
+ assert.ok(Number.isFinite(v2) && v2 > 0);
77
+ });
78
+ });
79
+ //# sourceMappingURL=escape-speed.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"escape-speed.spec.js","sourceRoot":"","sources":["../../src/__tests__/escape-speed.spec.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=gravitational-acceleration-on1-by2.int.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"gravitational-acceleration-on1-by2.int.spec.d.ts","sourceRoot":"","sources":["../../src/__tests__/gravitational-acceleration-on1-by2.int.spec.ts"],"names":[],"mappings":""}
@@ -0,0 +1,86 @@
1
+ import assert from 'node:assert/strict';
2
+ import test, { describe } from 'node:test';
3
+ import { accelerationOn1By2 } from '../categories/gravity/acceleration-on1-by2';
4
+ import { norm, relClose, scale, sub, vecRelClose } from './helpers';
5
+ import { G_SI } from '@interstellar-tools/constants';
6
+ describe('accelerationOn1By2', () => {
7
+ test('1D sanity (+x): ||a|| = G*m2/r^2 and points +x', () => {
8
+ const G = 1;
9
+ const m2 = 3;
10
+ const r1 = [0, 0, 0];
11
+ const r2 = [10, 0, 0];
12
+ const a = accelerationOn1By2(m2, r1, r2, G);
13
+ // Expected magnitude: 1*3/10^2 = 0.03, direction +x
14
+ relClose(norm(a), 0.03, 1e-14);
15
+ vecRelClose(a, [0.03, 0, 0], 1e-14);
16
+ });
17
+ test('1D sanity (-x): points toward body 2 at negative x', () => {
18
+ const G = 1;
19
+ const m2 = 3;
20
+ const r1 = [0, 0, 0];
21
+ const r2 = [-10, 0, 0];
22
+ const a = accelerationOn1By2(m2, r1, r2, G);
23
+ relClose(norm(a), 0.03, 1e-14);
24
+ vecRelClose(a, [-0.03, 0, 0], 1e-14);
25
+ });
26
+ test('direction equals r-hat for arbitrary 3D positions', () => {
27
+ const G = 2.5;
28
+ const m2 = 11;
29
+ const r1 = [0.2, -3, 5.5];
30
+ const r2 = [4.2, 1, -1];
31
+ const a = accelerationOn1By2(m2, r1, r2, G);
32
+ const dr = sub(r2, r1);
33
+ const r = Math.hypot(...dr);
34
+ const rhat = [dr[0] / r, dr[1] / r, dr[2] / r];
35
+ const ahat = scale(a, 1 / norm(a));
36
+ vecRelClose(ahat, rhat, 1e-12);
37
+ });
38
+ test('inverse-square scaling: doubling r → quarter acceleration', () => {
39
+ const G = 10;
40
+ const m2 = 5;
41
+ const r1 = [0, 0, 0];
42
+ const r2a = [2, 0, 0]; // r = 2
43
+ const r2b = [4, 0, 0]; // r = 4 (double → quarter a)
44
+ const aA = accelerationOn1By2(m2, r1, r2a, G);
45
+ const aB = accelerationOn1By2(m2, r1, r2b, G);
46
+ relClose(norm(aB), norm(aA) / 4, 1e-14);
47
+ });
48
+ test('linearity: scaling m2 or G scales a accordingly', () => {
49
+ const G = 3;
50
+ const m2 = 5;
51
+ const r1 = [1, 2, 3];
52
+ const r2 = [4, -1, 0];
53
+ const a = accelerationOn1By2(m2, r1, r2, G);
54
+ const a_m2x2 = accelerationOn1By2(2 * m2, r1, r2, G);
55
+ const a_Gx2 = accelerationOn1By2(m2, r1, r2, 2 * G);
56
+ vecRelClose(a_m2x2, scale(a, 2));
57
+ vecRelClose(a_Gx2, scale(a, 2));
58
+ });
59
+ test('real-world sanity: Earth due to Sun at 1 AU (~5.93e-3 m/s^2)', () => {
60
+ const mSun = 1.9885e30; // kg
61
+ const rEarth = [0, 0, 0];
62
+ const rSun = [1.495978707e11, 0, 0]; // m
63
+ const a = accelerationOn1By2(mSun, rEarth, rSun, G_SI);
64
+ // Closed-form expectation GM_sun / r^2
65
+ const dr = sub(rSun, rEarth);
66
+ const r = Math.hypot(...dr);
67
+ const expected = (G_SI * mSun) / (r * r);
68
+ relClose(norm(a), expected, 1e-12);
69
+ // Also within ~0.5% of commonly cited value
70
+ const ref = 5.93e-3;
71
+ assert.ok(Math.abs(norm(a) - ref) / ref < 5e-3, `|a| ${norm(a)} differs from ~${ref}`);
72
+ });
73
+ test('error propagation: invalid inputs cause throws', () => {
74
+ const r1 = [0, 0, 0];
75
+ const r2 = [1, 0, 0];
76
+ // negative / non-finite m2
77
+ assert.throws(() => accelerationOn1By2(-1, r1, r2, 1), /non-negative|finite/);
78
+ assert.throws(() => accelerationOn1By2(Number.NaN, r1, r2, 1), /finite/);
79
+ // coincident positions
80
+ assert.throws(() => accelerationOn1By2(1, r1, r1, 1), /singular \(r = 0\)/);
81
+ // invalid G
82
+ assert.throws(() => accelerationOn1By2(1, r1, r2, 0), /positive/);
83
+ assert.throws(() => accelerationOn1By2(1, r1, r2, Number.NaN), /finite/);
84
+ });
85
+ });
86
+ //# sourceMappingURL=gravitational-acceleration-on1-by2.int.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"gravitational-acceleration-on1-by2.int.spec.js","sourceRoot":"","sources":["../../src/__tests__/gravitational-acceleration-on1-by2.int.spec.ts"],"names":[],"mappings":"AAAA,OAAO,MAAM,MAAM,oBAAoB,CAAC;AACxC,OAAO,IAAI,EAAE,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC;AAC3C,OAAO,EAAE,kBAAkB,EAAE,MAAM,4CAA4C,CAAC;AAChF,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,GAAG,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AACpE,OAAO,EAAE,IAAI,EAAE,MAAM,+BAA+B,CAAC;AAGrD,QAAQ,CAAC,oBAAoB,EAAE,GAAG,EAAE;IAClC,IAAI,CAAC,gDAAgD,EAAE,GAAG,EAAE;QAC1D,MAAM,CAAC,GAAG,CAAC,CAAC;QACZ,MAAM,EAAE,GAAG,CAAC,CAAC;QACb,MAAM,EAAE,GAAsB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QACxC,MAAM,EAAE,GAAsB,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAEzC,MAAM,CAAC,GAAG,kBAAkB,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;QAE5C,oDAAoD;QACpD,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;QAC/B,WAAW,CAAC,CAAC,EAAE,CAAC,IAAI,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC;IACtC,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,oDAAoD,EAAE,GAAG,EAAE;QAC9D,MAAM,CAAC,GAAG,CAAC,CAAC;QACZ,MAAM,EAAE,GAAG,CAAC,CAAC;QACb,MAAM,EAAE,GAAsB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QACxC,MAAM,EAAE,GAAsB,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAE1C,MAAM,CAAC,GAAG,kBAAkB,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;QAE5C,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;QAC/B,WAAW,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC;IACvC,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,mDAAmD,EAAE,GAAG,EAAE;QAC7D,MAAM,CAAC,GAAG,GAAG,CAAC;QACd,MAAM,EAAE,GAAG,EAAE,CAAC;QACd,MAAM,EAAE,GAAsB,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;QAC7C,MAAM,EAAE,GAAsB,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAE3C,MAAM,CAAC,GAAG,kBAAkB,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;QAC5C,MAAM,EAAE,GAAG,GAAG,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;QACvB,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC;QAC5B,MAAM,IAAI,GAAsB,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QAElE,MAAM,IAAI,GAAG,KAAK,CAAC,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,CAAsB,CAAC;QACxD,WAAW,CAAC,IAAI,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;IACjC,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,2DAA2D,EAAE,GAAG,EAAE;QACrE,MAAM,CAAC,GAAG,EAAE,CAAC;QACb,MAAM,EAAE,GAAG,CAAC,CAAC;QACb,MAAM,EAAE,GAAsB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAExC,MAAM,GAAG,GAAsB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,QAAQ;QAClD,MAAM,GAAG,GAAsB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,6BAA6B;QAEvE,MAAM,EAAE,GAAG,kBAAkB,CAAC,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC;QAC9C,MAAM,EAAE,GAAG,kBAAkB,CAAC,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC;QAE9C,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,KAAK,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,iDAAiD,EAAE,GAAG,EAAE;QAC3D,MAAM,CAAC,GAAG,CAAC,CAAC;QACZ,MAAM,EAAE,GAAG,CAAC,CAAC;QACb,MAAM,EAAE,GAAsB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QACxC,MAAM,EAAE,GAAsB,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAEzC,MAAM,CAAC,GAAG,kBAAkB,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;QAC5C,MAAM,MAAM,GAAG,kBAAkB,CAAC,CAAC,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;QACrD,MAAM,KAAK,GAAG,kBAAkB,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;QAEpD,WAAW,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACjC,WAAW,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IAClC,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,8DAA8D,EAAE,GAAG,EAAE;QACxE,MAAM,IAAI,GAAG,SAAS,CAAC,CAAC,KAAK;QAC7B,MAAM,MAAM,GAAsB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAC5C,MAAM,IAAI,GAAsB,CAAC,cAAc,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI;QAE5D,MAAM,CAAC,GAAG,kBAAkB,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;QAEvD,uCAAuC;QACvC,MAAM,EAAE,GAAG,GAAG,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;QAC7B,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC;QAC5B,MAAM,QAAQ,GAAG,CAAC,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QAEzC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,KAAK,CAAC,CAAC;QAEnC,4CAA4C;QAC5C,MAAM,GAAG,GAAG,OAAO,CAAC;QACpB,MAAM,CAAC,EAAE,CACP,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,GAAG,GAAG,IAAI,EACpC,OAAO,IAAI,CAAC,CAAC,CAAC,kBAAkB,GAAG,EAAE,CACtC,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,gDAAgD,EAAE,GAAG,EAAE;QAC1D,MAAM,EAAE,GAAsB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QACxC,MAAM,EAAE,GAAsB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAExC,2BAA2B;QAC3B,MAAM,CAAC,MAAM,CACX,GAAG,EAAE,CAAC,kBAAkB,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,EACvC,qBAAqB,CACtB,CAAC;QACF,MAAM,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,kBAAkB,CAAC,MAAM,CAAC,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC;QAEzE,uBAAuB;QACvB,MAAM,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,kBAAkB,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,oBAAoB,CAAC,CAAC;QAE5E,YAAY;QACZ,MAAM,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,kBAAkB,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC;QAClE,MAAM,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,kBAAkB,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,MAAM,CAAC,GAAG,CAAC,EAAE,QAAQ,CAAC,CAAC;IAC3E,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=gravitational-force-on1-by2.int.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"gravitational-force-on1-by2.int.spec.d.ts","sourceRoot":"","sources":["../../src/__tests__/gravitational-force-on1-by2.int.spec.ts"],"names":[],"mappings":""}
@@ -0,0 +1,106 @@
1
+ import assert from 'node:assert/strict';
2
+ import test, { describe } from 'node:test';
3
+ import { norm, relClose, scale, sub, vecRelClose } from './helpers';
4
+ import { G_SI } from '@interstellar-tools/constants';
5
+ import { forceOn1By2 } from '../categories/gravity/force-on1-by2';
6
+ describe('forceOn1By2', () => {
7
+ test('1D sanity (+x): |F| = G*m1*m2/r^2 and points +x', () => {
8
+ const G = 1;
9
+ const m1 = 2;
10
+ const m2 = 3;
11
+ const r1 = [0, 0, 0];
12
+ const r2 = [10, 0, 0];
13
+ const F = forceOn1By2(m1, m2, r1, r2, G);
14
+ // Expected magnitude and direction
15
+ const expectedMag = (G * m1 * m2) / 10 ** 2; // 0.06
16
+ relClose(norm(F), expectedMag, 1e-14);
17
+ vecRelClose(F, [expectedMag, 0, 0], 1e-14);
18
+ });
19
+ test('1D sanity (-x): points toward body 2 (at -x)', () => {
20
+ const G = 1;
21
+ const m1 = 2;
22
+ const m2 = 3;
23
+ const r1 = [0, 0, 0];
24
+ const r2 = [-10, 0, 0];
25
+ const F = forceOn1By2(m1, m2, r1, r2, G);
26
+ relClose(norm(F), 0.06, 1e-14);
27
+ vecRelClose(F, [-0.06, 0, 0], 1e-14);
28
+ });
29
+ test('direction equals r-hat for arbitrary 3D positions', () => {
30
+ const G = 2.5;
31
+ const m1 = 7;
32
+ const m2 = 11;
33
+ const r1 = [0.2, -3, 5.5];
34
+ const r2 = [4.2, 1, -1];
35
+ const F = forceOn1By2(m1, m2, r1, r2, G);
36
+ const dr = sub(r2, r1);
37
+ const r = Math.hypot(...dr);
38
+ const rhat = [dr[0] / r, dr[1] / r, dr[2] / r];
39
+ // Normalize F and compare to rhat
40
+ const Fhat = scale(F, 1 / norm(F));
41
+ vecRelClose(Fhat, rhat, 1e-12);
42
+ });
43
+ test('Newton’s 3rd law: F_1<-2 = - F_2<-1', () => {
44
+ const G = 9.87;
45
+ const m1 = 7;
46
+ const m2 = 11;
47
+ const r1 = [0, -2, 5];
48
+ const r2 = [3, 1, -1];
49
+ const F12 = forceOn1By2(m1, m2, r1, r2, G);
50
+ const F21 = forceOn1By2(m2, m1, r2, r1, G);
51
+ vecRelClose(F12, [-F21[0], -F21[1], -F21[2]]);
52
+ });
53
+ test('inverse-square scaling: doubling r → quarter force', () => {
54
+ const G = 10;
55
+ const m1 = 2;
56
+ const m2 = 5;
57
+ const r1 = [0, 0, 0];
58
+ const r2a = [2, 0, 0]; // r = 2
59
+ const r2b = [4, 0, 0]; // r = 4 (double → quarter force)
60
+ const Fa = forceOn1By2(m1, m2, r1, r2a, G);
61
+ const Fb = forceOn1By2(m1, m2, r1, r2b, G);
62
+ relClose(norm(Fb), norm(Fa) / 4, 1e-14);
63
+ });
64
+ test('linearity: scaling m1, m2, or G scales F accordingly', () => {
65
+ const G = 3;
66
+ const m1 = 2;
67
+ const m2 = 5;
68
+ const r1 = [1, 2, 3];
69
+ const r2 = [4, -1, 0];
70
+ const F = forceOn1By2(m1, m2, r1, r2, G);
71
+ const F_m1x2 = forceOn1By2(2 * m1, m2, r1, r2, G);
72
+ const F_m2x2 = forceOn1By2(m1, 2 * m2, r1, r2, G);
73
+ const F_Gx2 = forceOn1By2(m1, m2, r1, r2, 2 * G);
74
+ // Doubling any of m1, m2, or G doubles the force vector
75
+ vecRelClose(F_m1x2, scale(F, 2));
76
+ vecRelClose(F_m2x2, scale(F, 2));
77
+ vecRelClose(F_Gx2, scale(F, 2));
78
+ });
79
+ test('real-world sanity: Earth–Sun at ~1 AU (~3.54e22 N)', () => {
80
+ const mEarth = 5.972e24; // kg
81
+ const mSun = 1.9885e30; // kg
82
+ const rEarth = [0, 0, 0];
83
+ const rSun = [1.495978707e11, 0, 0]; // m
84
+ const F = forceOn1By2(mEarth, mSun, rEarth, rSun, G_SI);
85
+ const r = Math.hypot(rSun[0] - rEarth[0], rSun[1] - rEarth[1], rSun[2] - rEarth[2]);
86
+ const expectedMag = (G_SI * mEarth * mSun) / (r * r);
87
+ relClose(norm(F), expectedMag, 1e-12);
88
+ // also within ~0.5% of the commonly quoted magnitude
89
+ const ref = 3.542e22;
90
+ assert.ok(Math.abs(norm(F) - ref) / ref < 5e-3, `|F| ${norm(F)} differs from ~${ref}`);
91
+ });
92
+ test('error propagation: invalid inputs cause throws', () => {
93
+ const r1 = [0, 0, 0];
94
+ const r2 = [1, 0, 0];
95
+ // negative / non-finite masses
96
+ assert.throws(() => forceOn1By2(-1, 1, r1, r2, 1), /non-negative|finite/);
97
+ assert.throws(() => forceOn1By2(1, -1, r1, r2, 1), /non-negative|finite/);
98
+ assert.throws(() => forceOn1By2(Number.NaN, 1, r1, r2, 1), /finite/);
99
+ // coincident positions
100
+ assert.throws(() => forceOn1By2(1, 1, r1, r1, 1), /singular \(r = 0\)/);
101
+ // invalid G
102
+ assert.throws(() => forceOn1By2(1, 1, r1, r2, 0), /positive/);
103
+ assert.throws(() => forceOn1By2(1, 1, r1, r2, Number.NaN), /finite/);
104
+ });
105
+ });
106
+ //# sourceMappingURL=gravitational-force-on1-by2.int.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"gravitational-force-on1-by2.int.spec.js","sourceRoot":"","sources":["../../src/__tests__/gravitational-force-on1-by2.int.spec.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=gravitational-force.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"gravitational-force.spec.d.ts","sourceRoot":"","sources":["../../src/__tests__/gravitational-force.spec.ts"],"names":[],"mappings":""}
@@ -0,0 +1,105 @@
1
+ import assert from 'node:assert/strict';
2
+ import test, { describe } from 'node:test';
3
+ import { G_SI } from '@interstellar-tools/constants';
4
+ import { norm, relClose, vecRelClose } from './helpers';
5
+ import { gravitationalForce } from '../categories/gravity/gravitational-force';
6
+ describe('gravitationalForce', () => {
7
+ test('computes simple 1D case (+x) with custom G', () => {
8
+ const G = 1; // simple numbers to check algebra
9
+ const m1 = 2;
10
+ const m2 = 3;
11
+ const r1 = [0, 0, 0];
12
+ const r2 = [10, 0, 0];
13
+ const res = gravitationalForce(m1, m2, r1, r2, G);
14
+ // Expected: |F| = G m1 m2 / r^2 = 6 / 100 = 0.06; direction = +x
15
+ relClose(res.magnitude, 0.06);
16
+ vecRelClose(res.vector, [0.06, 0, 0]);
17
+ // invariants
18
+ relClose(norm(res.vector), res.magnitude);
19
+ relClose(norm(res.direction), 1);
20
+ vecRelClose(res.vector, [
21
+ res.magnitude * res.direction[0],
22
+ res.magnitude * res.direction[1],
23
+ res.magnitude * res.direction[2]
24
+ ]);
25
+ });
26
+ test('direction points from body 1 toward body 2 (arbitrary 3D)', () => {
27
+ const G = 1.23;
28
+ const m1 = 1;
29
+ const m2 = 4;
30
+ const r1 = [1, 2, 3];
31
+ const r2 = [-2, 6, 3]; // displacement = (-3, 4, 0)
32
+ const res = gravitationalForce(m1, m2, r1, r2, G);
33
+ // direction should align with normalized (r2 - r1)
34
+ const dr = [
35
+ r2[0] - r1[0],
36
+ r2[1] - r1[1],
37
+ r2[2] - r1[2]
38
+ ];
39
+ const r = Math.hypot(...dr);
40
+ const rhat = [dr[0] / r, dr[1] / r, dr[2] / r];
41
+ vecRelClose(res.direction, rhat, 1e-12);
42
+ // vector == magnitude * rhat
43
+ vecRelClose(res.vector, [
44
+ res.magnitude * rhat[0],
45
+ res.magnitude * rhat[1],
46
+ res.magnitude * rhat[2]
47
+ ]);
48
+ });
49
+ test("Newton's 3rd law: F_1<-2 = - F_2<-1", () => {
50
+ const G = 9.87;
51
+ const m1 = 7;
52
+ const m2 = 11;
53
+ const r1 = [0, -2, 5];
54
+ const r2 = [3, 1, -1];
55
+ const F12 = gravitationalForce(m1, m2, r1, r2, G).vector;
56
+ const F21 = gravitationalForce(m2, m1, r2, r1, G).vector;
57
+ vecRelClose(F12, [-F21[0], -F21[1], -F21[2]]);
58
+ });
59
+ test('real-world sanity: Earth-Sun at ~1 AU (matches known ~3.54e22 N)', () => {
60
+ const mEarth = 5.972e24; // kg
61
+ const mSun = 1.9885e30; // kg
62
+ const r1 = [0, 0, 0];
63
+ const r2 = [1.495978707e11, 0, 0]; // m
64
+ const res = gravitationalForce(mEarth, mSun, r1, r2, G_SI);
65
+ // Compare to closed-form expectation (not using the function's internal dir)
66
+ const r = Math.hypot(r2[0] - r1[0], r2[1] - r1[1], r2[2] - r1[2]);
67
+ const expectedMag = (G_SI * mEarth * mSun) / (r * r);
68
+ // exact equivalence (up to FP)
69
+ relClose(res.magnitude, expectedMag, 1e-15);
70
+ // also compare to the commonly quoted magnitude ~3.542e22 N within 0.5%
71
+ const ref = 3.542e22;
72
+ assert.ok(Math.abs(res.magnitude - ref) / ref < 5e-3, `|F| ${res.magnitude} differs from ~${ref}`);
73
+ });
74
+ test('error: negative or non-finite masses', () => {
75
+ const r1 = [0, 0, 0];
76
+ const r2 = [1, 0, 0];
77
+ assert.throws(() => gravitationalForce(-1, 1, r1, r2, 1), /non-negative/);
78
+ assert.throws(() => gravitationalForce(1, -1, r1, r2, 1), /non-negative/);
79
+ assert.throws(() => gravitationalForce(Number.NaN, 1, r1, r2, 1), /finite/);
80
+ assert.throws(() => gravitationalForce(1, Number.POSITIVE_INFINITY, r1, r2, 1), /finite/);
81
+ });
82
+ test('error: coincident positions (r = 0)', () => {
83
+ const r = [3, -4, 5];
84
+ assert.throws(() => gravitationalForce(1, 1, r, r, 1), /singular \(r = 0\)/);
85
+ });
86
+ test('error: invalid G (non-finite or <= 0)', () => {
87
+ const r1 = [0, 0, 0];
88
+ const r2 = [1, 0, 0];
89
+ assert.throws(() => gravitationalForce(1, 1, r1, r2, 0), /positive/);
90
+ assert.throws(() => gravitationalForce(1, 1, r1, r2, Number.NaN), /finite/);
91
+ assert.throws(() => gravitationalForce(1, 1, r1, r2, -1), /positive/);
92
+ });
93
+ test('scales with 1/r^2', () => {
94
+ const G = 10;
95
+ const m1 = 2;
96
+ const m2 = 5;
97
+ const r1 = [0, 0, 0];
98
+ const r2a = [2, 0, 0]; // r = 2
99
+ const r2b = [4, 0, 0]; // r = 4 (double -> quarter force)
100
+ const Fa = gravitationalForce(m1, m2, r1, r2a, G).magnitude;
101
+ const Fb = gravitationalForce(m1, m2, r1, r2b, G).magnitude;
102
+ relClose(Fb, Fa / 4);
103
+ });
104
+ });
105
+ //# sourceMappingURL=gravitational-force.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"gravitational-force.spec.js","sourceRoot":"","sources":["../../src/__tests__/gravitational-force.spec.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=gravitational-parameters.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"gravitational-parameters.spec.d.ts","sourceRoot":"","sources":["../../src/__tests__/gravitational-parameters.spec.ts"],"names":[],"mappings":""}