1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18 package org.orekit.estimation.common;
19
20 import java.util.Map;
21
22 import org.orekit.estimation.measurements.ObservableSatellite;
23 import org.orekit.estimation.measurements.Range;
24 import org.orekit.estimation.measurements.RangeRate;
25 import org.orekit.estimation.measurements.modifiers.Bias;
26
27
28
29
30 class RangeRateParser extends MeasurementsParser<RangeRate> {
31
32 @Override
33 public RangeRate parseFields(final String[] fields,
34 final Map<String, StationData> stations,
35 final PVData pvData,
36 final ObservableSatellite satellite,
37 final Bias<Range> satRangeBias,
38 final Weights weights,
39 final String line,
40 final int lineNumber,
41 final String fileName) {
42 checkFields(4, fields, line, lineNumber, fileName);
43 final StationData stationData = getStationData(fields[2], stations, line, lineNumber, fileName);
44 final RangeRate rangeRate = new RangeRate(stationData.getStation(),
45 getDate(fields[0], line, lineNumber, fileName),
46 Double.parseDouble(fields[3]) * 1000.0,
47 stationData.getRangeRateSigma(),
48 weights.getRangeRateBaseWeight(),
49 true, satellite);
50 if (stationData.getRangeRateBias() != null) {
51 rangeRate.addModifier(stationData.getRangeRateBias());
52 }
53 return rangeRate;
54 }
55 }