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.KeplerianOrbit;
21 import org.orekit.orbits.Orbit;
22 import org.orekit.propagation.analytical.BrouwerLyddanePropagator;
23 import org.orekit.propagation.conversion.averaging.BrouwerLyddaneOrbitalState;
24 import org.orekit.propagation.conversion.averaging.elements.AveragedKeplerianWithMeanAngle;
25
26
27
28
29
30
31
32
33
34
35 public class OsculatingToBrouwerLyddaneConverter
36 extends FixedPointOsculatingToAveragedConverter<BrouwerLyddaneOrbitalState> {
37
38
39 private static final double M2 = 0.;
40
41 private static final int HARMONICS_ORDER = 0;
42
43
44 private final UnnormalizedSphericalHarmonicsProvider harmonicsProvider;
45
46
47
48
49
50 public OsculatingToBrouwerLyddaneConverter(final UnnormalizedSphericalHarmonicsProvider harmonicsProvider) {
51 this(DEFAULT_EPSILON, DEFAULT_MAX_ITERATIONS, harmonicsProvider);
52 }
53
54
55
56
57
58
59
60 public OsculatingToBrouwerLyddaneConverter(final double epsilon, final int maxIterations,
61 final UnnormalizedSphericalHarmonicsProvider harmonicsProvider) {
62 super(epsilon, maxIterations);
63 this.harmonicsProvider = harmonicsProvider;
64 }
65
66
67 @Override
68 public BrouwerLyddaneOrbitalState convertToAveraged(final Orbit osculatingOrbit) {
69 final KeplerianOrbit averagedOrbit = createAveragedOrbit(osculatingOrbit);
70 final AveragedKeplerianWithMeanAngle averagedElements = buildElements(averagedOrbit);
71 return new BrouwerLyddaneOrbitalState(averagedOrbit.getDate(), averagedElements,
72 averagedOrbit.getFrame(), harmonicsProvider);
73 }
74
75
76
77
78
79
80 private KeplerianOrbit createAveragedOrbit(final Orbit osculatingOrbit) {
81 final UnnormalizedSphericalHarmonicsProvider.UnnormalizedSphericalHarmonics harmonics =
82 harmonicsProvider.onDate(osculatingOrbit.getDate());
83 return BrouwerLyddanePropagator.computeMeanOrbit(osculatingOrbit,
84 harmonicsProvider.getAe(), harmonicsProvider.getMu(),
85 harmonics.getUnnormalizedCnm(2, HARMONICS_ORDER),
86 harmonics.getUnnormalizedCnm(3, HARMONICS_ORDER),
87 harmonics.getUnnormalizedCnm(4, HARMONICS_ORDER),
88 harmonics.getUnnormalizedCnm(5, HARMONICS_ORDER),
89 M2, getEpsilon(), getMaxIterations());
90 }
91
92
93
94
95
96
97 private AveragedKeplerianWithMeanAngle buildElements(final KeplerianOrbit averagedOrbit) {
98 return new AveragedKeplerianWithMeanAngle(averagedOrbit.getA(), averagedOrbit.getE(),
99 averagedOrbit.getI(), averagedOrbit.getPerigeeArgument(),
100 averagedOrbit.getRightAscensionOfAscendingNode(), averagedOrbit.getMeanAnomaly());
101 }
102
103 }