1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17 package org.orekit.propagation.conversion.averaging.converters;
18
19 import org.orekit.forces.gravity.potential.UnnormalizedSphericalHarmonicsProvider;
20 import org.orekit.orbits.CircularOrbit;
21 import org.orekit.orbits.Orbit;
22 import org.orekit.propagation.analytical.EcksteinHechlerPropagator;
23 import org.orekit.propagation.conversion.averaging.EcksteinHechlerOrbitalState;
24 import org.orekit.propagation.conversion.averaging.elements.AveragedCircularWithMeanAngle;
25
26
27
28
29
30
31
32
33
34 public class OsculatingToEcksteinHechlerConverter
35 extends FixedPointOsculatingToAveragedConverter<EcksteinHechlerOrbitalState> {
36
37
38 private static final int HARMONICS_ORDER = 0;
39
40
41 private final UnnormalizedSphericalHarmonicsProvider harmonicsProvider;
42
43
44
45
46
47 public OsculatingToEcksteinHechlerConverter(final UnnormalizedSphericalHarmonicsProvider harmonicsProvider) {
48 this(DEFAULT_EPSILON, DEFAULT_MAX_ITERATIONS, harmonicsProvider);
49 }
50
51
52
53
54
55
56
57 public OsculatingToEcksteinHechlerConverter(final double epsilon, final int maxIterations,
58 final UnnormalizedSphericalHarmonicsProvider harmonicsProvider) {
59 super(epsilon, maxIterations);
60 this.harmonicsProvider = harmonicsProvider;
61 }
62
63
64 @Override
65 public EcksteinHechlerOrbitalState convertToAveraged(final Orbit osculatingOrbit) {
66 final CircularOrbit averagedOrbit = createAveragedOrbit(osculatingOrbit);
67 final AveragedCircularWithMeanAngle elements = buildElements(averagedOrbit);
68 return new EcksteinHechlerOrbitalState(averagedOrbit.getDate(), elements,
69 averagedOrbit.getFrame(), harmonicsProvider);
70 }
71
72
73
74
75
76
77 private CircularOrbit createAveragedOrbit(final Orbit osculatingOrbit) {
78 final UnnormalizedSphericalHarmonicsProvider.UnnormalizedSphericalHarmonics harmonics =
79 harmonicsProvider.onDate(osculatingOrbit.getDate());
80 return EcksteinHechlerPropagator.computeMeanOrbit(osculatingOrbit,
81 harmonicsProvider.getAe(), harmonicsProvider.getMu(),
82 harmonics.getUnnormalizedCnm(2, HARMONICS_ORDER),
83 harmonics.getUnnormalizedCnm(3, HARMONICS_ORDER),
84 harmonics.getUnnormalizedCnm(4, HARMONICS_ORDER),
85 harmonics.getUnnormalizedCnm(5, HARMONICS_ORDER),
86 harmonics.getUnnormalizedCnm(6, HARMONICS_ORDER),
87 getEpsilon(), getMaxIterations());
88 }
89
90
91
92
93
94
95 private AveragedCircularWithMeanAngle buildElements(final CircularOrbit averagedOrbit) {
96 return new AveragedCircularWithMeanAngle(averagedOrbit.getA(),
97 averagedOrbit.getCircularEx(), averagedOrbit.getCircularEy(), averagedOrbit.getI(),
98 averagedOrbit.getRightAscensionOfAscendingNode(), averagedOrbit.getAlphaM());
99 }
100
101 }