1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17 package org.orekit.estimation.measurements.modifiers;
18
19 import java.util.List;
20
21 import org.hipparchus.CalculusFieldElement;
22 import org.orekit.attitudes.FrameAlignedProvider;
23 import org.orekit.estimation.measurements.EstimatedMeasurement;
24 import org.orekit.estimation.measurements.EstimatedMeasurementBase;
25 import org.orekit.estimation.measurements.EstimationModifier;
26 import org.orekit.estimation.measurements.GroundStation;
27 import org.orekit.estimation.measurements.TDOA;
28 import org.orekit.frames.TopocentricFrame;
29 import org.orekit.models.earth.ionosphere.IonosphericModel;
30 import org.orekit.propagation.FieldSpacecraftState;
31 import org.orekit.propagation.SpacecraftState;
32 import org.orekit.utils.Constants;
33 import org.orekit.utils.ParameterDriver;
34
35
36
37
38
39
40
41
42
43
44
45 public class TDOAIonosphericDelayModifier implements EstimationModifier<TDOA> {
46
47
48 private final IonosphericModel ionoModel;
49
50
51 private final double frequency;
52
53
54
55
56
57
58 public TDOAIonosphericDelayModifier(final IonosphericModel model,
59 final double freq) {
60 ionoModel = model;
61 frequency = freq;
62 }
63
64
65
66
67
68
69 private double timeErrorIonosphericModel(final GroundStation station,
70 final SpacecraftState state) {
71
72 final TopocentricFrame baseFrame = station.getBaseFrame();
73
74 final double delay = ionoModel.pathDelay(state, baseFrame, frequency, ionoModel.getParameters(state.getDate()));
75
76 return delay / Constants.SPEED_OF_LIGHT;
77 }
78
79
80
81
82
83
84
85
86 private <T extends CalculusFieldElement<T>> T timeErrorIonosphericModel(final GroundStation station,
87 final FieldSpacecraftState<T> state,
88 final T[] parameters) {
89
90 final TopocentricFrame baseFrame = station.getBaseFrame();
91
92 final T delay = ionoModel.pathDelay(state, baseFrame, frequency, parameters);
93
94 return delay.divide(Constants.SPEED_OF_LIGHT);
95 }
96
97
98 @Override
99 public List<ParameterDriver> getParametersDrivers() {
100 return ionoModel.getParametersDrivers();
101 }
102
103 @Override
104 public void modifyWithoutDerivatives(final EstimatedMeasurementBase<TDOA> estimated) {
105
106 final TDOA measurement = estimated.getObservedMeasurement();
107 final GroundStation primeStation = measurement.getPrimeStation();
108 final GroundStation secondStation = measurement.getSecondStation();
109
110 TDOAModifierUtil.modifyWithoutDerivatives(estimated, primeStation, secondStation,
111 this::timeErrorIonosphericModel,
112 this);
113
114 }
115
116 @Override
117 public void modify(final EstimatedMeasurement<TDOA> estimated) {
118
119 final TDOA measurement = estimated.getObservedMeasurement();
120 final GroundStation primeStation = measurement.getPrimeStation();
121 final GroundStation secondStation = measurement.getSecondStation();
122 final SpacecraftState state = estimated.getStates()[0];
123
124 TDOAModifierUtil.modify(estimated, ionoModel,
125 new ModifierGradientConverter(state, 6, new FrameAlignedProvider(state.getFrame())),
126 primeStation, secondStation,
127 this::timeErrorIonosphericModel,
128 this::timeErrorIonosphericModel,
129 this);
130
131 }
132
133 }