@interstellar-tools/equations 0.2.0 → 0.4.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 (189) 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.js +16 -16
  14. package/dist/__tests__/gravitational-acceleration-on1-by2.int.spec.js.map +1 -1
  15. package/dist/__tests__/gravitational-force-on1-by2.int.spec.js +20 -20
  16. package/dist/__tests__/gravitational-force-on1-by2.int.spec.js.map +1 -1
  17. package/dist/__tests__/gravitational-force.spec.js +1 -1
  18. package/dist/__tests__/gravitational-force.spec.js.map +1 -1
  19. package/dist/__tests__/gravitational-parameters.spec.js +1 -1
  20. package/dist/__tests__/gravitational-parameters.spec.js.map +1 -1
  21. package/dist/__tests__/helpers/index.d.ts +2 -1
  22. package/dist/__tests__/helpers/index.d.ts.map +1 -1
  23. package/dist/__tests__/helpers/index.js +6 -0
  24. package/dist/__tests__/helpers/index.js.map +1 -1
  25. package/dist/__tests__/kepler-period.spec.js +1 -1
  26. package/dist/__tests__/kepler-period.spec.js.map +1 -1
  27. package/dist/__tests__/mean-to-eccentric-anomaly.spec.d.ts +2 -0
  28. package/dist/__tests__/mean-to-eccentric-anomaly.spec.d.ts.map +1 -0
  29. package/dist/__tests__/{compute-mean-anomaly.int.spec.js → mean-to-eccentric-anomaly.spec.js} +49 -27
  30. package/dist/__tests__/mean-to-eccentric-anomaly.spec.js.map +1 -0
  31. package/dist/__tests__/peri-apoapsis-radii.spec.d.ts +2 -0
  32. package/dist/__tests__/peri-apoapsis-radii.spec.d.ts.map +1 -0
  33. package/dist/__tests__/peri-apoapsis-radii.spec.js +74 -0
  34. package/dist/__tests__/peri-apoapsis-radii.spec.js.map +1 -0
  35. package/dist/__tests__/solve-kepler-bisection.spec.js +1 -1
  36. package/dist/__tests__/solve-kepler-bisection.spec.js.map +1 -1
  37. package/dist/__tests__/solve-kepler-high-eccentricity.spec.js +1 -1
  38. package/dist/__tests__/solve-kepler-high-eccentricity.spec.js.map +1 -1
  39. package/dist/__tests__/solve-kepler-newton-raphson.spec.js +1 -1
  40. package/dist/__tests__/solve-kepler-newton-raphson.spec.js.map +1 -1
  41. package/dist/__tests__/solve-kepler.int.spec.js +1 -1
  42. package/dist/__tests__/solve-kepler.int.spec.js.map +1 -1
  43. package/dist/__tests__/specific-angular-momentum-from-elements.spec.d.ts +2 -0
  44. package/dist/__tests__/specific-angular-momentum-from-elements.spec.d.ts.map +1 -0
  45. package/dist/__tests__/specific-angular-momentum-from-elements.spec.js +86 -0
  46. package/dist/__tests__/specific-angular-momentum-from-elements.spec.js.map +1 -0
  47. package/dist/__tests__/specific-angular-momentum.spec.d.ts +2 -0
  48. package/dist/__tests__/specific-angular-momentum.spec.d.ts.map +1 -0
  49. package/dist/__tests__/specific-angular-momentum.spec.js +84 -0
  50. package/dist/__tests__/specific-angular-momentum.spec.js.map +1 -0
  51. package/dist/__tests__/specific-mechanical-energy.spec.js +1 -1
  52. package/dist/__tests__/specific-mechanical-energy.spec.js.map +1 -1
  53. package/dist/__tests__/true-to-mean-anomaly.spec.d.ts +2 -0
  54. package/dist/__tests__/true-to-mean-anomaly.spec.d.ts.map +1 -0
  55. package/dist/__tests__/{true-anomaly-to-mean-anomaly.int.spec.js → true-to-mean-anomaly.spec.js} +13 -13
  56. package/dist/__tests__/true-to-mean-anomaly.spec.js.map +1 -0
  57. package/dist/__tests__/vis-viva-speed.spec.js +1 -1
  58. package/dist/__tests__/vis-viva-speed.spec.js.map +1 -1
  59. package/dist/__tests__/wrap-angle.spec.js +1 -1
  60. package/dist/__tests__/wrap-angle.spec.js.map +1 -1
  61. package/dist/{compute-angle.d.ts → categories/angle/compute-angle.d.ts} +1 -1
  62. package/dist/categories/angle/compute-angle.d.ts.map +1 -0
  63. package/dist/{compute-angle.js → categories/angle/compute-angle.js} +5 -5
  64. package/dist/categories/angle/compute-angle.js.map +1 -0
  65. package/dist/{wrap-angle.d.ts → categories/angle/wrap-angle.d.ts} +1 -1
  66. package/dist/categories/angle/wrap-angle.d.ts.map +1 -0
  67. package/dist/{wrap-angle.js → categories/angle/wrap-angle.js} +1 -1
  68. package/dist/categories/angle/wrap-angle.js.map +1 -0
  69. package/dist/{eccentric-to-true-anomaly.d.ts → categories/anomalies/eccentric-to-true-anomaly.d.ts} +1 -1
  70. package/dist/categories/anomalies/eccentric-to-true-anomaly.d.ts.map +1 -0
  71. package/dist/{eccentric-to-true-anomaly.js → categories/anomalies/eccentric-to-true-anomaly.js} +1 -1
  72. package/dist/categories/anomalies/eccentric-to-true-anomaly.js.map +1 -0
  73. package/dist/{compute-mean-anomaly.d.ts → categories/anomalies/mean-to-eccentric-anomaly.d.ts} +5 -5
  74. package/dist/categories/anomalies/mean-to-eccentric-anomaly.d.ts.map +1 -0
  75. package/dist/{compute-mean-anomaly.js → categories/anomalies/mean-to-eccentric-anomaly.js} +11 -20
  76. package/dist/categories/anomalies/mean-to-eccentric-anomaly.js.map +1 -0
  77. package/dist/{true-anomaly-to-mean-anomaly.d.ts → categories/anomalies/true-to-mean-anomaly.d.ts} +6 -6
  78. package/dist/categories/anomalies/true-to-mean-anomaly.d.ts.map +1 -0
  79. package/dist/{true-anomaly-to-mean-anomaly.js → categories/anomalies/true-to-mean-anomaly.js} +7 -7
  80. package/dist/categories/anomalies/true-to-mean-anomaly.js.map +1 -0
  81. package/dist/categories/anomalies/utils/are-equal.d.ts +10 -0
  82. package/dist/categories/anomalies/utils/are-equal.d.ts.map +1 -0
  83. package/dist/categories/anomalies/utils/are-equal.js +13 -0
  84. package/dist/categories/anomalies/utils/are-equal.js.map +1 -0
  85. package/dist/categories/gravity/acceleration-on1-by2.d.ts +66 -0
  86. package/dist/categories/gravity/acceleration-on1-by2.d.ts.map +1 -0
  87. package/dist/categories/gravity/acceleration-on1-by2.js +75 -0
  88. package/dist/categories/gravity/acceleration-on1-by2.js.map +1 -0
  89. package/dist/categories/gravity/force-on1-by2.d.ts +87 -0
  90. package/dist/categories/gravity/force-on1-by2.d.ts.map +1 -0
  91. package/dist/categories/gravity/force-on1-by2.js +96 -0
  92. package/dist/categories/gravity/force-on1-by2.js.map +1 -0
  93. package/dist/categories/gravity/gravitational-force.d.ts +94 -0
  94. package/dist/categories/gravity/gravitational-force.d.ts.map +1 -0
  95. package/dist/categories/gravity/gravitational-force.js +119 -0
  96. package/dist/categories/gravity/gravitational-force.js.map +1 -0
  97. package/dist/{gravitational-parameter.d.ts → categories/gravity/gravitational-parameter.d.ts} +1 -1
  98. package/dist/categories/gravity/gravitational-parameter.d.ts.map +1 -0
  99. package/dist/{gravitational-parameter.js → categories/gravity/gravitational-parameter.js} +1 -1
  100. package/dist/categories/gravity/gravitational-parameter.js.map +1 -0
  101. package/dist/{solve-kepler-bisection.d.ts → categories/kepler/solve-kepler-bisection.d.ts} +1 -1
  102. package/dist/categories/kepler/solve-kepler-bisection.d.ts.map +1 -0
  103. package/dist/{solve-kepler-bisection.js → categories/kepler/solve-kepler-bisection.js} +1 -1
  104. package/dist/categories/kepler/solve-kepler-bisection.js.map +1 -0
  105. package/dist/{solve-kepler-high-eccentricity.d.ts → categories/kepler/solve-kepler-high-eccentricity.d.ts} +2 -8
  106. package/dist/categories/kepler/solve-kepler-high-eccentricity.d.ts.map +1 -0
  107. package/dist/{solve-kepler-high-eccentricity.js → categories/kepler/solve-kepler-high-eccentricity.js} +5 -9
  108. package/dist/categories/kepler/solve-kepler-high-eccentricity.js.map +1 -0
  109. package/dist/{solve-kepler-newton-raphson.d.ts → categories/kepler/solve-kepler-newton-raphson.d.ts} +1 -1
  110. package/dist/categories/kepler/solve-kepler-newton-raphson.d.ts.map +1 -0
  111. package/dist/{solve-kepler-newton-raphson.js → categories/kepler/solve-kepler-newton-raphson.js} +1 -1
  112. package/dist/categories/kepler/solve-kepler-newton-raphson.js.map +1 -0
  113. package/dist/{solve-kepler.d.ts → categories/kepler/solve-kepler.d.ts} +1 -1
  114. package/dist/categories/kepler/solve-kepler.d.ts.map +1 -0
  115. package/dist/{solve-kepler.js → categories/kepler/solve-kepler.js} +2 -2
  116. package/dist/categories/kepler/solve-kepler.js.map +1 -0
  117. package/dist/categories/orbits/circular-speed.d.ts +42 -0
  118. package/dist/categories/orbits/circular-speed.d.ts.map +1 -0
  119. package/dist/categories/orbits/circular-speed.js +50 -0
  120. package/dist/categories/orbits/circular-speed.js.map +1 -0
  121. package/dist/categories/orbits/escape-speed.d.ts +50 -0
  122. package/dist/categories/orbits/escape-speed.d.ts.map +1 -0
  123. package/dist/categories/orbits/escape-speed.js +58 -0
  124. package/dist/categories/orbits/escape-speed.js.map +1 -0
  125. package/dist/{kepler-period.d.ts → categories/orbits/kepler-period.d.ts} +1 -1
  126. package/dist/categories/orbits/kepler-period.d.ts.map +1 -0
  127. package/dist/{kepler-period.js → categories/orbits/kepler-period.js} +1 -1
  128. package/dist/categories/orbits/kepler-period.js.map +1 -0
  129. package/dist/categories/orbits/peri-apoapsis-radii.d.ts +46 -0
  130. package/dist/categories/orbits/peri-apoapsis-radii.d.ts.map +1 -0
  131. package/dist/categories/orbits/peri-apoapsis-radii.js +85 -0
  132. package/dist/categories/orbits/peri-apoapsis-radii.js.map +1 -0
  133. package/dist/categories/orbits/specific-angular-momentum-from-elements.d.ts +60 -0
  134. package/dist/categories/orbits/specific-angular-momentum-from-elements.d.ts.map +1 -0
  135. package/dist/categories/orbits/specific-angular-momentum-from-elements.js +76 -0
  136. package/dist/categories/orbits/specific-angular-momentum-from-elements.js.map +1 -0
  137. package/dist/categories/orbits/specific-angular-momentum.d.ts +55 -0
  138. package/dist/categories/orbits/specific-angular-momentum.d.ts.map +1 -0
  139. package/dist/categories/orbits/specific-angular-momentum.js +76 -0
  140. package/dist/categories/orbits/specific-angular-momentum.js.map +1 -0
  141. package/dist/{specific-mechanical-energy.d.ts → categories/orbits/specific-mechanical-energy.d.ts} +1 -1
  142. package/dist/categories/orbits/specific-mechanical-energy.d.ts.map +1 -0
  143. package/dist/{specific-mechanical-energy.js → categories/orbits/specific-mechanical-energy.js} +1 -1
  144. package/dist/categories/orbits/specific-mechanical-energy.js.map +1 -0
  145. package/dist/{vis-viva-speed.d.ts → categories/orbits/vis-viva-speed.d.ts} +1 -1
  146. package/dist/categories/orbits/vis-viva-speed.d.ts.map +1 -0
  147. package/dist/{vis-viva-speed.js → categories/orbits/vis-viva-speed.js} +1 -1
  148. package/dist/categories/orbits/vis-viva-speed.js.map +1 -0
  149. package/dist/index.d.ts +20 -15
  150. package/dist/index.d.ts.map +1 -1
  151. package/dist/index.js +25 -15
  152. package/dist/index.js.map +1 -1
  153. package/package.json +3 -3
  154. package/dist/__tests__/compute-mean-anomaly.int.spec.d.ts +0 -2
  155. package/dist/__tests__/compute-mean-anomaly.int.spec.d.ts.map +0 -1
  156. package/dist/__tests__/compute-mean-anomaly.int.spec.js.map +0 -1
  157. package/dist/__tests__/true-anomaly-to-mean-anomaly.int.spec.d.ts +0 -2
  158. package/dist/__tests__/true-anomaly-to-mean-anomaly.int.spec.d.ts.map +0 -1
  159. package/dist/__tests__/true-anomaly-to-mean-anomaly.int.spec.js.map +0 -1
  160. package/dist/compute-angle.d.ts.map +0 -1
  161. package/dist/compute-angle.js.map +0 -1
  162. package/dist/compute-mean-anomaly.d.ts.map +0 -1
  163. package/dist/compute-mean-anomaly.js.map +0 -1
  164. package/dist/eccentric-to-true-anomaly.d.ts.map +0 -1
  165. package/dist/eccentric-to-true-anomaly.js.map +0 -1
  166. package/dist/gravitational-parameter.d.ts.map +0 -1
  167. package/dist/gravitational-parameter.js.map +0 -1
  168. package/dist/kepler-period.d.ts.map +0 -1
  169. package/dist/kepler-period.js.map +0 -1
  170. package/dist/law-of-gravitation.d.ts +0 -243
  171. package/dist/law-of-gravitation.d.ts.map +0 -1
  172. package/dist/law-of-gravitation.js +0 -284
  173. package/dist/law-of-gravitation.js.map +0 -1
  174. package/dist/solve-kepler-bisection.d.ts.map +0 -1
  175. package/dist/solve-kepler-bisection.js.map +0 -1
  176. package/dist/solve-kepler-high-eccentricity.d.ts.map +0 -1
  177. package/dist/solve-kepler-high-eccentricity.js.map +0 -1
  178. package/dist/solve-kepler-newton-raphson.d.ts.map +0 -1
  179. package/dist/solve-kepler-newton-raphson.js.map +0 -1
  180. package/dist/solve-kepler.d.ts.map +0 -1
  181. package/dist/solve-kepler.js.map +0 -1
  182. package/dist/specific-mechanical-energy.d.ts.map +0 -1
  183. package/dist/specific-mechanical-energy.js.map +0 -1
  184. package/dist/true-anomaly-to-mean-anomaly.d.ts.map +0 -1
  185. package/dist/true-anomaly-to-mean-anomaly.js.map +0 -1
  186. package/dist/vis-viva-speed.d.ts.map +0 -1
  187. package/dist/vis-viva-speed.js.map +0 -1
  188. package/dist/wrap-angle.d.ts.map +0 -1
  189. package/dist/wrap-angle.js.map +0 -1
@@ -0,0 +1,76 @@
1
+ /**
2
+ * **Specific angular momentum** ($ h $) from **orbital elements**.
3
+ *
4
+ * **Definition**
5
+ *
6
+ * $$
7
+ * h=\sqrt{\mu\,a\,(1-e^2)}
8
+ * $$
9
+ *
10
+ * where ($ a $) is the semi-major axis, ($ e $) the eccentricity, and ($ \mu $) the gravitational parameter.
11
+ *
12
+ * **Validity by conic**
13
+ * - **Elliptic**: ($ a>0,\; 0\le e<1 $) → ($ 1-e^2>0 $) ⇒ radicand ($ >0 $).
14
+ * - **Hyperbolic**: ($ a<0,\; e>1 $) → ($ 1-e^2<0 $) and ($ a<0 $) ⇒ product still ($ >0 $).
15
+ * - **Parabolic**: ($ e=1 $) is not represented by finite ($ a $). Use state vectors or
16
+ * ($ h=\sqrt{2\mu r_p} $) (with periapsis radius ($ r_p $)).
17
+ *
18
+ * **Units**
19
+ * - Inputs: ($ a $) in **m**, ($ e $) dimensionless, ($ \mu $) in **m³/s²**.
20
+ * - Output: ($ h $) in **m²/s**.
21
+ *
22
+ * ::: info
23
+ *
24
+ * - This returns the **magnitude** of ($ \mathbf h = \mathbf r \times \mathbf v $).
25
+ * - For numerical robustness, tiny negative radicands from FP cancellation are clamped to zero.
26
+ *
27
+ * :::
28
+ *
29
+ * @param {number} a Semi-major axis ($ a $) (m). Must be finite and **≠ 0** (elliptic ($ a>0 $), hyperbolic ($ a<0 $)).
30
+ * @param {number} e Eccentricity ($ e $) (dimensionless). Must be finite and **≥ 0**.
31
+ * @param {number} mu Gravitational parameter ($ \mu $) (m³/s²). Must be finite and **≥ 0**.
32
+ * @returns {number} Specific angular momentum ($ h $) (m²/s).
33
+ *
34
+ * @throws {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Error | Error}
35
+ * If ($ a $) is non-finite or zero; if ($ e $) is non-finite or negative; if ($ \mu $) is non-finite or negative; or if
36
+ * ($ \mu\,a\,(1-e^2) < 0 $) beyond a tiny FP tolerance (invalid element set for this formula).
37
+ *
38
+ * @example
39
+ * ```ts
40
+ * // Near-circular LEO-like elements
41
+ * const muEarth = 3.986004418e14; // m^3/s^2
42
+ * const a = 6778e3; // m
43
+ * const e = 0.001;
44
+ * const h = specificAngularMomentumFromElements(a, e, muEarth); // ≈ sqrt(μ a)
45
+ * ```
46
+ *
47
+ * @example
48
+ * ```ts
49
+ * // Hyperbolic flyby example
50
+ * const muEarth = 3.986004418e14; // m^3/s^2
51
+ * const a = -50000e3; // m (negative for hyperbola)
52
+ * const e = 1.2;
53
+ * const h = specificAngularMomentumFromElements(a, e, muEarth);
54
+ * ```
55
+ *
56
+ * @see {@link specificAngularMomentum} - compute ($ h $) from state vectors ($ (\mathbf r,\mathbf v) $).
57
+ * @group Orbits
58
+ */
59
+ export const specificAngularMomentumFromElements = (a, e, mu) => {
60
+ if (!Number.isFinite(a) || a === 0)
61
+ throw new Error('a must be finite and non-zero (meters).');
62
+ if (!Number.isFinite(e) || e < 0)
63
+ throw new Error('e must be finite and ≥ 0.');
64
+ if (!Number.isFinite(mu) || mu < 0)
65
+ throw new Error('mu must be finite and ≥ 0 (m^3/s^2).');
66
+ const radicand = mu * a * (1 - e * e);
67
+ if (radicand < 0) {
68
+ // Allow tiny negatives due to FP cancellation
69
+ const tol = Math.abs(1e-14 * mu * Math.abs(a));
70
+ if (radicand > -tol)
71
+ return 0;
72
+ throw new Error(`Invalid (a,e) for this formula: μ·a·(1-e²) < 0 (μ=${mu}, a=${a}, e=${e}).`);
73
+ }
74
+ return Math.sqrt(radicand);
75
+ };
76
+ //# sourceMappingURL=specific-angular-momentum-from-elements.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"specific-angular-momentum-from-elements.js","sourceRoot":"","sources":["../../../src/categories/orbits/specific-angular-momentum-from-elements.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAyDG;AACH,MAAM,CAAC,MAAM,mCAAmC,GAAG,CACjD,CAAS,EACT,CAAS,EACT,EAAU,EACF,EAAE;IACV,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC;QAChC,MAAM,IAAI,KAAK,CAAC,yCAAyC,CAAC,CAAC;IAE7D,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC;QAC9B,MAAM,IAAI,KAAK,CAAC,2BAA2B,CAAC,CAAC;IAE/C,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,CAAC,IAAI,EAAE,GAAG,CAAC;QAChC,MAAM,IAAI,KAAK,CAAC,sCAAsC,CAAC,CAAC;IAE1D,MAAM,QAAQ,GAAG,EAAE,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC;IAEtC,IAAI,QAAQ,GAAG,CAAC,EAAE,CAAC;QACjB,8CAA8C;QAC9C,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,GAAG,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QAE/C,IAAI,QAAQ,GAAG,CAAC,GAAG;YAAE,OAAO,CAAC,CAAC;QAE9B,MAAM,IAAI,KAAK,CACb,qDAAqD,EAAE,OAAO,CAAC,OAAO,CAAC,IAAI,CAC5E,CAAC;IACJ,CAAC;IAED,OAAO,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;AAC7B,CAAC,CAAC"}
@@ -0,0 +1,55 @@
1
+ import { Vector3DTupleType } from '@interstellar-tools/types';
2
+ /**
3
+ * **Specific angular momentum** ($ h $) (scalar magnitude).
4
+ *
5
+ * **Definitions**
6
+ *
7
+ * $$
8
+ * h = \lVert \mathbf r \times \mathbf v \rVert
9
+ * $$
10
+ *
11
+ * Useful identities:
12
+ *
13
+ * $$
14
+ * h = r\,v_{\perp},\qquad
15
+ * \text{(circular)}\ \ v_\perp=\sqrt{\mu/r}\Rightarrow h=\sqrt{\mu r}
16
+ * $$
17
+ *
18
+ * (For orbital elements, one also has ($ h=\sqrt{\mu\,a\,(1-e^2)} $), not used here.)
19
+ *
20
+ * **Units**
21
+ * - Inputs: ($ \mathbf r $) in **meters (m)**, ($ \mathbf v $) in **m/s**.
22
+ * - Output: ($ h $) in **m²/s**.
23
+ *
24
+ * ::: info
25
+ *
26
+ * - Returns the **magnitude** of ($ \mathbf h = \mathbf r \times \mathbf v $) (not the vector).
27
+ * - ($ h = 0 $) iff ($ \mathbf r \parallel \mathbf v $) (purely radial motion) or ($ \mathbf v=\mathbf 0 $).
28
+ * - In a two-body Keplerian model, ($ h $) is constant along the orbit.
29
+ *
30
+ * :::
31
+ *
32
+ * **Invariants (floating-point tolerance aside)**
33
+ * - ($ h \ge 0 $)
34
+ * - ($ \mathbf h \perp \mathbf r $) and ($ \mathbf h \perp \mathbf v $) (directional property; this function returns only ($ \lVert\mathbf h\rVert $)).
35
+ *
36
+ * @param {Vector3DTupleType} r Inertial position vector ($ \mathbf r=[x,y,z] $) (m).
37
+ * @param {Vector3DTupleType} v Inertial velocity vector ($ \mathbf v=[v_x,v_y,v_z] $) (m/s).
38
+ * @returns {number} Specific angular momentum ($ h $) (m²/s).
39
+ *
40
+ * @throws {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Error | Error} If any component of `r`/`v` is non-finite; if `r` has zero length; or if `v` is invalid (NaN).
41
+ *
42
+ * @example
43
+ * ```ts
44
+ * // LEO-like state: r ⟂ v
45
+ * const r: [number, number, number] = [6778e3, 0, 0]; // m
46
+ * const v: [number, number, number] = [0, 7.67e3, 0]; // m/s
47
+ * const h = specificAngularMomentum(r, v); // ≈ 5.20e10 m^2/s
48
+ * ```
49
+ *
50
+ * @see {@link https://en.wikipedia.org/wiki/Specific_angular_momentum}
51
+ * @see {@link specificAngularMomentumFromElements} (if you compute from ($ a,e,\mu $))
52
+ * @group Orbits
53
+ */
54
+ export declare const specificAngularMomentum: (r: Vector3DTupleType, v: Vector3DTupleType) => number;
55
+ //# sourceMappingURL=specific-angular-momentum.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"specific-angular-momentum.d.ts","sourceRoot":"","sources":["../../../src/categories/orbits/specific-angular-momentum.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AAG9D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAmDG;AAEH,eAAO,MAAM,uBAAuB,GAClC,GAAG,iBAAiB,EACpB,GAAG,iBAAiB,KACnB,MAqBF,CAAC"}
@@ -0,0 +1,76 @@
1
+ /* node:coverage disable */
2
+ /**
3
+ * **Specific angular momentum** ($ h $) (scalar magnitude).
4
+ *
5
+ * **Definitions**
6
+ *
7
+ * $$
8
+ * h = \lVert \mathbf r \times \mathbf v \rVert
9
+ * $$
10
+ *
11
+ * Useful identities:
12
+ *
13
+ * $$
14
+ * h = r\,v_{\perp},\qquad
15
+ * \text{(circular)}\ \ v_\perp=\sqrt{\mu/r}\Rightarrow h=\sqrt{\mu r}
16
+ * $$
17
+ *
18
+ * (For orbital elements, one also has ($ h=\sqrt{\mu\,a\,(1-e^2)} $), not used here.)
19
+ *
20
+ * **Units**
21
+ * - Inputs: ($ \mathbf r $) in **meters (m)**, ($ \mathbf v $) in **m/s**.
22
+ * - Output: ($ h $) in **m²/s**.
23
+ *
24
+ * ::: info
25
+ *
26
+ * - Returns the **magnitude** of ($ \mathbf h = \mathbf r \times \mathbf v $) (not the vector).
27
+ * - ($ h = 0 $) iff ($ \mathbf r \parallel \mathbf v $) (purely radial motion) or ($ \mathbf v=\mathbf 0 $).
28
+ * - In a two-body Keplerian model, ($ h $) is constant along the orbit.
29
+ *
30
+ * :::
31
+ *
32
+ * **Invariants (floating-point tolerance aside)**
33
+ * - ($ h \ge 0 $)
34
+ * - ($ \mathbf h \perp \mathbf r $) and ($ \mathbf h \perp \mathbf v $) (directional property; this function returns only ($ \lVert\mathbf h\rVert $)).
35
+ *
36
+ * @param {Vector3DTupleType} r Inertial position vector ($ \mathbf r=[x,y,z] $) (m).
37
+ * @param {Vector3DTupleType} v Inertial velocity vector ($ \mathbf v=[v_x,v_y,v_z] $) (m/s).
38
+ * @returns {number} Specific angular momentum ($ h $) (m²/s).
39
+ *
40
+ * @throws {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Error | Error} If any component of `r`/`v` is non-finite; if `r` has zero length; or if `v` is invalid (NaN).
41
+ *
42
+ * @example
43
+ * ```ts
44
+ * // LEO-like state: r ⟂ v
45
+ * const r: [number, number, number] = [6778e3, 0, 0]; // m
46
+ * const v: [number, number, number] = [0, 7.67e3, 0]; // m/s
47
+ * const h = specificAngularMomentum(r, v); // ≈ 5.20e10 m^2/s
48
+ * ```
49
+ *
50
+ * @see {@link https://en.wikipedia.org/wiki/Specific_angular_momentum}
51
+ * @see {@link specificAngularMomentumFromElements} (if you compute from ($ a,e,\mu $))
52
+ * @group Orbits
53
+ */
54
+ /* node:coverage enable */
55
+ export const specificAngularMomentum = (r, v) => {
56
+ // Validate inputs
57
+ for (const x of r)
58
+ if (!Number.isFinite(x))
59
+ throw new Error('r must be finite (meters).');
60
+ for (const x of v)
61
+ if (!Number.isFinite(x))
62
+ throw new Error('v must be finite (m/s).');
63
+ const r2 = r[0] * r[0] + r[1] * r[1] + r[2] * r[2];
64
+ const v2 = v[0] * v[0] + v[1] * v[1] + v[2] * v[2];
65
+ if (!(r2 > 0))
66
+ throw new Error('r must be non-zero (meters).');
67
+ if (!(v2 >= 0))
68
+ throw new Error('v must be valid (m/s).');
69
+ // h⃗ = r × v
70
+ const hx = r[1] * v[2] - r[2] * v[1];
71
+ const hy = r[2] * v[0] - r[0] * v[2];
72
+ const hz = r[0] * v[1] - r[1] * v[0];
73
+ const h = Math.hypot(hx, hy, hz); // m^2/s
74
+ return h;
75
+ };
76
+ //# sourceMappingURL=specific-angular-momentum.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"specific-angular-momentum.js","sourceRoot":"","sources":["../../../src/categories/orbits/specific-angular-momentum.ts"],"names":[],"mappings":"AAEA,2BAA2B;AAC3B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAmDG;AACH,0BAA0B;AAC1B,MAAM,CAAC,MAAM,uBAAuB,GAAG,CACrC,CAAoB,EACpB,CAAoB,EACZ,EAAE;IACV,kBAAkB;IAClB,KAAK,MAAM,CAAC,IAAI,CAAC;QACf,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC;YAAE,MAAM,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAC;IACzE,KAAK,MAAM,CAAC,IAAI,CAAC;QACf,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC;YAAE,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;IAEtE,MAAM,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IACnD,MAAM,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IAEnD,IAAI,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;QAAE,MAAM,IAAI,KAAK,CAAC,8BAA8B,CAAC,CAAC;IAE/D,IAAI,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;QAAE,MAAM,IAAI,KAAK,CAAC,wBAAwB,CAAC,CAAC;IAE1D,aAAa;IACb,MAAM,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IACrC,MAAM,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IACrC,MAAM,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IACrC,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ;IAE1C,OAAO,CAAC,CAAC;AACX,CAAC,CAAC"}
@@ -43,7 +43,7 @@
43
43
  * const eps = specificMechanicalEnergy(v, r, muEarth);
44
44
  * // eps ≈ -mu/(2r)
45
45
  * ```
46
- * @category Dynamics
46
+ * @group Orbits
47
47
  */
48
48
  export declare const specificMechanicalEnergy: (v: number, r: number, mu: number) => number;
49
49
  //# sourceMappingURL=specific-mechanical-energy.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"specific-mechanical-energy.d.ts","sourceRoot":"","sources":["../../../src/categories/orbits/specific-mechanical-energy.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8CG;AACH,eAAO,MAAM,wBAAwB,GACnC,GAAG,MAAM,EACT,GAAG,MAAM,EACT,IAAI,MAAM,KACT,MAWF,CAAC"}
@@ -43,7 +43,7 @@
43
43
  * const eps = specificMechanicalEnergy(v, r, muEarth);
44
44
  * // eps ≈ -mu/(2r)
45
45
  * ```
46
- * @category Dynamics
46
+ * @group Orbits
47
47
  */
48
48
  export const specificMechanicalEnergy = (v, r, mu) => {
49
49
  if (!Number.isFinite(v) || v < 0)
@@ -0,0 +1 @@
1
+ {"version":3,"file":"specific-mechanical-energy.js","sourceRoot":"","sources":["../../../src/categories/orbits/specific-mechanical-energy.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8CG;AACH,MAAM,CAAC,MAAM,wBAAwB,GAAG,CACtC,CAAS,EACT,CAAS,EACT,EAAU,EACF,EAAE;IACV,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC;QAC9B,MAAM,IAAI,KAAK,CAAC,gDAAgD,CAAC,CAAC;IAEpE,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC;QAC/B,MAAM,IAAI,KAAK,CAAC,0CAA0C,CAAC,CAAC;IAE9D,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,CAAC,IAAI,EAAE,GAAG,CAAC;QAChC,MAAM,IAAI,KAAK,CAAC,qDAAqD,CAAC,CAAC;IAEzE,OAAO,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;AAC9B,CAAC,CAAC"}
@@ -36,7 +36,7 @@
36
36
  * const a = r; // circular
37
37
  * const v = visVivaSpeed(r, a, muEarth); // ≈ 7670 m/s
38
38
  * ```
39
- * @category Dynamics
39
+ * @group Orbits
40
40
  */
41
41
  export declare const visVivaSpeed: (r: number, a: number, mu: number) => number;
42
42
  //# sourceMappingURL=vis-viva-speed.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"vis-viva-speed.d.ts","sourceRoot":"","sources":["../../../src/categories/orbits/vis-viva-speed.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAuCG;AACH,eAAO,MAAM,YAAY,GAAI,GAAG,MAAM,EAAE,GAAG,MAAM,EAAE,IAAI,MAAM,KAAG,MAsC/D,CAAC"}
@@ -36,7 +36,7 @@
36
36
  * const a = r; // circular
37
37
  * const v = visVivaSpeed(r, a, muEarth); // ≈ 7670 m/s
38
38
  * ```
39
- * @category Dynamics
39
+ * @group Orbits
40
40
  */
41
41
  export const visVivaSpeed = (r, a, mu) => {
42
42
  if (!Number.isFinite(r) || r <= 0) {
@@ -0,0 +1 @@
1
+ {"version":3,"file":"vis-viva-speed.js","sourceRoot":"","sources":["../../../src/categories/orbits/vis-viva-speed.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAuCG;AACH,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,CAAS,EAAE,CAAS,EAAE,EAAU,EAAU,EAAE;IACvE,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;QAClC,MAAM,IAAI,KAAK,CAAC,0CAA0C,CAAC,CAAC;IAC9D,CAAC;IAED,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,CAAC,IAAI,EAAE,GAAG,CAAC,EAAE,CAAC;QACnC,MAAM,IAAI,KAAK,CAAC,qDAAqD,CAAC,CAAC;IACzE,CAAC;IAED,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC;QACxB,iEAAiE;QACjE,IAAI,CAAC,KAAK,QAAQ,EAAE,CAAC;YACnB,kBAAkB;YAClB,OAAO,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;QACjC,CAAC;QAED,MAAM,IAAI,KAAK,CAAC,0DAA0D,CAAC,CAAC;IAC9E,CAAC;IAED,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;QACZ,MAAM,IAAI,KAAK,CAAC,gDAAgD,CAAC,CAAC;IACpE,CAAC;IAED,MAAM,IAAI,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,gDAAgD;IACpE,MAAM,QAAQ,GAAG,EAAE,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,CAAC;IAErC,oEAAoE;IACpE,IAAI,QAAQ,GAAG,CAAC,EAAE,CAAC;QACjB,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;QAEvC,IAAI,QAAQ,GAAG,CAAC,GAAG;YAAE,OAAO,CAAC,CAAC,CAAC,yBAAyB;QAExD,MAAM,IAAI,KAAK,CACb,uCAAuC,EAAE,OAAO,CAAC,OAAO,CAAC,IAAI,CAC9D,CAAC;IACJ,CAAC;IAED,OAAO,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;AAC7B,CAAC,CAAC"}
package/dist/index.d.ts CHANGED
@@ -1,21 +1,26 @@
1
1
  /**
2
2
  *
3
3
  * Here you will find a set of function that can assist you when calculating orbits, angles, solve for kelper or find true anomalies.
4
- * @showCategories
5
4
  * @module
6
5
  */
7
- export * from './compute-angle';
8
- export * from './compute-mean-anomaly';
9
- export * from './eccentric-to-true-anomaly';
10
- export * from './solve-kepler-bisection';
11
- export * from './solve-kepler-high-eccentricity';
12
- export * from './solve-kepler-newton-raphson';
13
- export * from './solve-kepler';
14
- export * from './true-anomaly-to-mean-anomaly';
15
- export * from './wrap-angle';
16
- export * from './gravitational-parameter';
17
- export * from './law-of-gravitation';
18
- export * from './vis-viva-speed';
19
- export * from './kepler-period';
20
- export * from './specific-mechanical-energy';
6
+ export * from './categories/angle/compute-angle';
7
+ export * from './categories/angle/wrap-angle';
8
+ export * from './categories/anomalies/mean-to-eccentric-anomaly';
9
+ export * from './categories/anomalies/eccentric-to-true-anomaly';
10
+ export * from './categories/anomalies/true-to-mean-anomaly';
11
+ export * from './categories/kepler/solve-kepler';
12
+ export * from './categories/kepler/solve-kepler-newton-raphson';
13
+ export * from './categories/kepler/solve-kepler-bisection';
14
+ export * from './categories/kepler/solve-kepler-high-eccentricity';
15
+ export * from './categories/gravity/gravitational-parameter';
16
+ export * from './categories/gravity/gravitational-force';
17
+ export * from './categories/gravity/force-on1-by2';
18
+ export * from './categories/gravity/acceleration-on1-by2';
19
+ export * from './categories/orbits/vis-viva-speed';
20
+ export * from './categories/orbits/circular-speed';
21
+ export * from './categories/orbits/escape-speed';
22
+ export * from './categories/orbits/kepler-period';
23
+ export * from './categories/orbits/specific-angular-momentum';
24
+ export * from './categories/orbits/specific-angular-momentum-from-elements';
25
+ export * from './categories/orbits/specific-mechanical-energy';
21
26
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,cAAc,iBAAiB,CAAC;AAEhC,cAAc,wBAAwB,CAAC;AAEvC,cAAc,6BAA6B,CAAC;AAE5C,cAAc,0BAA0B,CAAC;AAEzC,cAAc,kCAAkC,CAAC;AAEjD,cAAc,+BAA+B,CAAC;AAE9C,cAAc,gBAAgB,CAAC;AAE/B,cAAc,gCAAgC,CAAC;AAE/C,cAAc,cAAc,CAAC;AAE7B,cAAc,2BAA2B,CAAC;AAE1C,cAAc,sBAAsB,CAAC;AAErC,cAAc,kBAAkB,CAAC;AAEjC,cAAc,iBAAiB,CAAC;AAEhC,cAAc,8BAA8B,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAGH,cAAc,kCAAkC,CAAC;AAEjD,cAAc,+BAA+B,CAAC;AAG9C,cAAc,kDAAkD,CAAC;AAEjE,cAAc,kDAAkD,CAAC;AAEjE,cAAc,6CAA6C,CAAC;AAG5D,cAAc,kCAAkC,CAAC;AAEjD,cAAc,iDAAiD,CAAC;AAEhE,cAAc,4CAA4C,CAAC;AAE3D,cAAc,oDAAoD,CAAC;AAGnE,cAAc,8CAA8C,CAAC;AAE7D,cAAc,0CAA0C,CAAC;AAEzD,cAAc,oCAAoC,CAAC;AAEnD,cAAc,2CAA2C,CAAC;AAG1D,cAAc,oCAAoC,CAAC;AAEnD,cAAc,oCAAoC,CAAC;AAEnD,cAAc,kCAAkC,CAAC;AAEjD,cAAc,mCAAmC,CAAC;AAElD,cAAc,+CAA+C,CAAC;AAE9D,cAAc,6DAA6D,CAAC;AAE5E,cAAc,gDAAgD,CAAC"}
package/dist/index.js CHANGED
@@ -1,21 +1,31 @@
1
1
  /**
2
2
  *
3
3
  * Here you will find a set of function that can assist you when calculating orbits, angles, solve for kelper or find true anomalies.
4
- * @showCategories
5
4
  * @module
6
5
  */
7
- export * from './compute-angle';
8
- export * from './compute-mean-anomaly';
9
- export * from './eccentric-to-true-anomaly';
10
- export * from './solve-kepler-bisection';
11
- export * from './solve-kepler-high-eccentricity';
12
- export * from './solve-kepler-newton-raphson';
13
- export * from './solve-kepler';
14
- export * from './true-anomaly-to-mean-anomaly';
15
- export * from './wrap-angle';
16
- export * from './gravitational-parameter';
17
- export * from './law-of-gravitation';
18
- export * from './vis-viva-speed';
19
- export * from './kepler-period';
20
- export * from './specific-mechanical-energy';
6
+ // categories/angle
7
+ export * from './categories/angle/compute-angle';
8
+ export * from './categories/angle/wrap-angle';
9
+ // categories/anomalies
10
+ export * from './categories/anomalies/mean-to-eccentric-anomaly';
11
+ export * from './categories/anomalies/eccentric-to-true-anomaly';
12
+ export * from './categories/anomalies/true-to-mean-anomaly';
13
+ // categories/kepler (solvers)
14
+ export * from './categories/kepler/solve-kepler';
15
+ export * from './categories/kepler/solve-kepler-newton-raphson';
16
+ export * from './categories/kepler/solve-kepler-bisection';
17
+ export * from './categories/kepler/solve-kepler-high-eccentricity';
18
+ // categories/gravity
19
+ export * from './categories/gravity/gravitational-parameter';
20
+ export * from './categories/gravity/gravitational-force';
21
+ export * from './categories/gravity/force-on1-by2';
22
+ export * from './categories/gravity/acceleration-on1-by2';
23
+ // categories/orbits
24
+ export * from './categories/orbits/vis-viva-speed';
25
+ export * from './categories/orbits/circular-speed';
26
+ export * from './categories/orbits/escape-speed';
27
+ export * from './categories/orbits/kepler-period';
28
+ export * from './categories/orbits/specific-angular-momentum';
29
+ export * from './categories/orbits/specific-angular-momentum-from-elements';
30
+ export * from './categories/orbits/specific-mechanical-energy';
21
31
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,cAAc,iBAAiB,CAAC;AAEhC,cAAc,wBAAwB,CAAC;AAEvC,cAAc,6BAA6B,CAAC;AAE5C,cAAc,0BAA0B,CAAC;AAEzC,cAAc,kCAAkC,CAAC;AAEjD,cAAc,+BAA+B,CAAC;AAE9C,cAAc,gBAAgB,CAAC;AAE/B,cAAc,gCAAgC,CAAC;AAE/C,cAAc,cAAc,CAAC;AAE7B,cAAc,2BAA2B,CAAC;AAE1C,cAAc,sBAAsB,CAAC;AAErC,cAAc,kBAAkB,CAAC;AAEjC,cAAc,iBAAiB,CAAC;AAEhC,cAAc,8BAA8B,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,mBAAmB;AACnB,cAAc,kCAAkC,CAAC;AAEjD,cAAc,+BAA+B,CAAC;AAE9C,uBAAuB;AACvB,cAAc,kDAAkD,CAAC;AAEjE,cAAc,kDAAkD,CAAC;AAEjE,cAAc,6CAA6C,CAAC;AAE5D,8BAA8B;AAC9B,cAAc,kCAAkC,CAAC;AAEjD,cAAc,iDAAiD,CAAC;AAEhE,cAAc,4CAA4C,CAAC;AAE3D,cAAc,oDAAoD,CAAC;AAEnE,qBAAqB;AACrB,cAAc,8CAA8C,CAAC;AAE7D,cAAc,0CAA0C,CAAC;AAEzD,cAAc,oCAAoC,CAAC;AAEnD,cAAc,2CAA2C,CAAC;AAE1D,oBAAoB;AACpB,cAAc,oCAAoC,CAAC;AAEnD,cAAc,oCAAoC,CAAC;AAEnD,cAAc,kCAAkC,CAAC;AAEjD,cAAc,mCAAmC,CAAC;AAElD,cAAc,+CAA+C,CAAC;AAE9D,cAAc,6DAA6D,CAAC;AAE5E,cAAc,gDAAgD,CAAC"}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@interstellar-tools/equations",
3
- "version": "0.2.0",
4
- "description": "equations",
3
+ "version": "0.4.0",
4
+ "description": "Curated, well-tested orbital mechanics and dynamics formulas (e.g., Newtonian gravity, vis-viva, Kepler's 3rd law, escape/circular speeds, specific energy, specific angular momentum, peri/apoapsis radii).",
5
5
  "keywords": [
6
6
  "interstellar",
7
7
  "tools",
@@ -106,7 +106,7 @@
106
106
  "release": "release-it",
107
107
  "test": "tsx --test **/__tests__/**/*.spec.ts",
108
108
  "pretest:ci": "rm -rf coverage && mkdir -p coverage",
109
- "test:ci": "glob -c \"node --import tsx --test --no-warnings --experimental-test-coverage --test-reporter=cobertura --test-reporter-destination=coverage/cobertura-coverage.xml --test-reporter=spec --test-reporter-destination=stdout\" \"**/__tests__/**/*.spec.ts\""
109
+ "test:ci": "glob -c \"node --import tsx --test --no-warnings --experimental-test-coverage --test-coverage-exclude='**/__tests__/helpers/**' --test-reporter=cobertura --test-reporter-destination=coverage/cobertura-coverage.xml --test-reporter=spec --test-reporter-destination=stdout\" \"**/__tests__/**/*.spec.ts\""
110
110
  },
111
111
  "dependencies": {
112
112
  "@interstellar-tools/temporal": "^0.1.0",
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=compute-mean-anomaly.int.spec.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"compute-mean-anomaly.int.spec.d.ts","sourceRoot":"","sources":["../../src/__tests__/compute-mean-anomaly.int.spec.ts"],"names":[],"mappings":""}
@@ -1 +0,0 @@
1
- {"version":3,"file":"compute-mean-anomaly.int.spec.js","sourceRoot":"","sources":["../../src/__tests__/compute-mean-anomaly.int.spec.ts"],"names":[],"mappings":"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"}
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=true-anomaly-to-mean-anomaly.int.spec.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"true-anomaly-to-mean-anomaly.int.spec.d.ts","sourceRoot":"","sources":["../../src/__tests__/true-anomaly-to-mean-anomaly.int.spec.ts"],"names":[],"mappings":""}
@@ -1 +0,0 @@
1
- {"version":3,"file":"true-anomaly-to-mean-anomaly.int.spec.js","sourceRoot":"","sources":["../../src/__tests__/true-anomaly-to-mean-anomaly.int.spec.ts"],"names":[],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"compute-angle.d.ts","sourceRoot":"","sources":["../src/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 +0,0 @@
1
- {"version":3,"file":"compute-angle.js","sourceRoot":"","sources":["../src/compute-angle.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAC5D,OAAO,EAAE,sBAAsB,EAAE,MAAM,6BAA6B,CAAC;AACrE,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAE7C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAiEG;AACH,MAAM,CAAC,MAAM,YAAY,GAAG,CAC1B,IAAuB,EACvB,QAA2B,EAClB,EAAE;IACX,0CAA0C;IAC1C,MAAM,CAAC,GAAY,kBAAkB,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;IACtD,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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"compute-mean-anomaly.d.ts","sourceRoot":"","sources":["../src/compute-mean-anomaly.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EACV,iBAAiB,EACjB,OAAO,EACP,iBAAiB,EAClB,MAAM,2BAA2B,CAAC;AAkBnC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2CG;AACH,eAAO,MAAM,kBAAkB,GAC7B,MAAM,iBAAiB,EACvB,UAAU,iBAAiB,KAC1B,OAoCF,CAAC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"compute-mean-anomaly.js","sourceRoot":"","sources":["../src/compute-mean-anomaly.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,+BAA+B,CAAC;AACvD,OAAO,EAAE,mBAAmB,EAAE,MAAM,8BAA8B,CAAC;AAOnE,OAAO,EAAE,wBAAwB,EAAE,MAAM,gCAAgC,CAAC;AAC1E,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAEzC,MAAM,OAAO,GAAG,KAAK,CAAC,CAAC,4CAA4C;AACnE;;;;;;;GAOG;AACH,MAAM,QAAQ,GAAG,CAAC,CAAS,EAAE,CAAS,EAAE,UAAkB,OAAO,EAAW,EAAE;IAC5E,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;AAC3E,CAAC,CAAC;AAEF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2CG;AACH,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAChC,IAAuB,EACvB,QAA2B,EAClB,EAAE;IACX,MAAM,EAAE,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC;IAElC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;QACpB,MAAM,IAAI,UAAU,CAClB,yBAAyB,CAAC,6CAA6C,CACxE,CAAC;IACJ,CAAC;IAED,iDAAiD;IACjD,MAAM,YAAY,GAAG,mBAAmB,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC,KAAK,CAAC;IAC5D,MAAM,UAAU,GAAG,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;IACnD,6DAA6D;IAC7D,MAAM,EAAE,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,wBAAwB,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;IAEhE,IAAI,QAAQ,CAAC,KAAK,KAAK,CAAC,EAAE,CAAC;QACzB,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,2DAA2D;IAC3D,MAAM,WAAW,GAAG,IAAI,CAAC,CAAC,4BAA4B;IACtD,MAAM,iBAAiB,GAAG,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,6CAA6C;IAC1F,MAAM,aAAa,GAAG,IAAI,CAAC,GAAG,CAC5B,WAAW,EACX,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,KAAK,EAAE,iBAAiB,GAAG,IAAI,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC,CACrE,CAAC;IACF,wEAAwE;IACxE,MAAM,KAAK,GAAG,EAAE,CAAC;IAEjB,IAAI,IAAI,GAAG,SAAS,CAAC,EAAE,GAAG,UAAU,GAAG,aAAa,CAAC,CAAC;IAEtD,IAAI,QAAQ,CAAC,IAAI,EAAE,KAAK,CAAC,EAAE,CAAC;QAC1B,IAAI,GAAG,KAAK,CAAC;IACf,CAAC;IAED,OAAO,IAAI,CAAC;AACd,CAAC,CAAC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"eccentric-to-true-anomaly.d.ts","sourceRoot":"","sources":["../src/eccentric-to-true-anomaly.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAC;AAEpD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAuCG;AACH,eAAO,MAAM,sBAAsB,GAAI,GAAG,OAAO,EAAE,GAAG,MAAM,KAAG,OAiC9D,CAAC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"eccentric-to-true-anomaly.js","sourceRoot":"","sources":["../src/eccentric-to-true-anomaly.ts"],"names":[],"mappings":"AAEA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAuCG;AACH,MAAM,CAAC,MAAM,sBAAsB,GAAG,CAAC,CAAU,EAAE,CAAS,EAAW,EAAE;IACvE,8BAA8B;IAC9B,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC;QACnB,MAAM,IAAI,UAAU,CAClB,yBAAyB,CAAC,6CAA6C,CACxE,CAAC;IACJ,CAAC;IAED,gCAAgC;IAChC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;QACZ,OAAO,CAAC,CAAC,CAAC,4DAA4D;IACxE,CAAC;IAED,iCAAiC;IACjC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;QACZ,OAAO,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,uCAAuC;IACtE,CAAC;IAED,0CAA0C;IAC1C,MAAM,OAAO,GAAG,KAAK,CAAC,CAAC,0CAA0C;IAEjE,IAAI,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,OAAO,EAAE,CAAC;QACxC,OAAO,IAAI,CAAC,EAAE,CAAC,CAAC,+BAA+B;IACjD,CAAC;IAED,0EAA0E;IAC1E,OAAO,CACL,CAAC;QACD,IAAI,CAAC,KAAK,CACR,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,EAClC,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CACnC,CACF,CAAC;AACJ,CAAC,CAAC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"gravitational-parameter.d.ts","sourceRoot":"","sources":["../src/gravitational-parameter.ts"],"names":[],"mappings":"AAEA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8CG;AACH,eAAO,MAAM,sBAAsB,GACjC,GAAG,MAAM,EACT,IAAG,MAAU,EACb,IAAG,MAAa,KACf,MAcF,CAAC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"gravitational-parameter.js","sourceRoot":"","sources":["../src/gravitational-parameter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,+BAA+B,CAAC;AAErD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8CG;AACH,MAAM,CAAC,MAAM,sBAAsB,GAAG,CACpC,CAAS,EACT,IAAY,CAAC,EACb,IAAY,IAAI,EACR,EAAE;IACV,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC;QACjC,MAAM,IAAI,KAAK,CAAC,2CAA2C,CAAC,CAAC;IAC/D,CAAC;IAED,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC;QACjC,MAAM,IAAI,KAAK,CAAC,2CAA2C,CAAC,CAAC;IAC/D,CAAC;IAED,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;QAClC,MAAM,IAAI,KAAK,CAAC,uDAAuD,CAAC,CAAC;IAC3E,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;AACrB,CAAC,CAAC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"kepler-period.d.ts","sourceRoot":"","sources":["../src/kepler-period.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA0CG;AACH,eAAO,MAAM,YAAY,GAAI,GAAG,MAAM,EAAE,IAAI,MAAM,KAAG,MAYpD,CAAC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"kepler-period.js","sourceRoot":"","sources":["../src/kepler-period.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA0CG;AACH,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,CAAS,EAAE,EAAU,EAAU,EAAE;IAC5D,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;QAClC,MAAM,IAAI,KAAK,CAAC,+CAA+C,CAAC,CAAC;IACnE,CAAC;IAED,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC;QACpC,MAAM,IAAI,KAAK,CAAC,iDAAiD,CAAC,CAAC;IACrE,CAAC;IAED,MAAM,EAAE,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM;IAE5B,OAAO,CAAC,GAAG,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC;AAC1C,CAAC,CAAC"}