SatelliteSystem.java
- /* Copyright 2002-2025 CS GROUP
- * Licensed to CS GROUP (CS) under one or more
- * contributor license agreements. See the NOTICE file distributed with
- * this work for additional information regarding copyright ownership.
- * CS licenses this file to You under the Apache License, Version 2.0
- * (the "License"); you may not use this file except in compliance with
- * the License. You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
- package org.orekit.gnss;
- import java.util.HashMap;
- import java.util.Map;
- import org.orekit.errors.OrekitIllegalArgumentException;
- import org.orekit.errors.OrekitMessages;
- /**
- * Enumerate for satellite system.
- *
- * @author Luc Maisonobe
- * @since 9.2
- */
- public enum SatelliteSystem {
- /** User-defined system A.
- * @since 12.0
- */
- USER_DEFINED_A('A', null),
- /** User-defined system B.
- * @since 12.0
- */
- USER_DEFINED_B('B', null),
- /** Beidou system. */
- BEIDOU('C', ObservationTimeScale.BDT),
- /** User-defined system D.
- * @since 12.0
- */
- USER_DEFINED_D('D', null),
- /** Galileo system. */
- GALILEO('E', ObservationTimeScale.GAL),
- /** User-defined system F.
- * @since 12.0
- */
- USER_DEFINED_F('F', null),
- /** GPS system. */
- GPS('G', ObservationTimeScale.GPS),
- /** User-defined system H.
- * @since 12.0
- */
- USER_DEFINED_H('H', null),
- /** Navigation with Indian Constellation (NavIC).
- * <p>
- * This system was known as Indian Regional Navigation Satellite System (IRNSS).
- * </p>
- * @since 13.0
- */
- NAVIC('I', ObservationTimeScale.IRN),
- /** Quasi-Zenith Satellite System system. */
- QZSS('J', ObservationTimeScale.QZS),
- /** User-defined system K.
- * @since 12.0
- */
- USER_DEFINED_K('K', null),
- /** User-defined system L.
- * @since 12.0
- */
- USER_DEFINED_L('L', null),
- /** Mixed system. */
- MIXED('M', null),
- /** User-defined system N.
- * @since 12.0
- */
- USER_DEFINED_N('N', null),
- /** User-defined system O.
- * @since 12.0
- */
- USER_DEFINED_O('O', null),
- /** User-defined system P.
- * @since 12.0
- */
- USER_DEFINED_P('P', null),
- /** User-defined system Q.
- * @since 12.0
- */
- USER_DEFINED_Q('Q', null),
- /** GLONASS system. */
- GLONASS('R', ObservationTimeScale.GLO),
- /** SBAS system. */
- SBAS('S', null),
- /** User-defined system T.
- * @since 12.0
- */
- USER_DEFINED_T('T', null),
- /** User-defined system U.
- * @since 12.0
- */
- USER_DEFINED_U('U', null),
- /** User-defined system V.
- * @since 12.0
- */
- USER_DEFINED_V('V', null),
- /** User-defined system W.
- * @since 12.0
- */
- USER_DEFINED_W('W', null),
- /** User-defined system X.
- * @since 12.0
- */
- USER_DEFINED_X('X', null),
- /** User-defined system Y.
- * @since 12.0
- */
- USER_DEFINED_Y('Y', null),
- /** User-defined system Z.
- * @since 12.0
- */
- USER_DEFINED_Z('Z', null);
- /** Parsing map. */
- private static final Map<Character, SatelliteSystem> KEYS_MAP = new HashMap<>();
- static {
- for (final SatelliteSystem satelliteSystem : values()) {
- KEYS_MAP.put(satelliteSystem.getKey(), satelliteSystem);
- }
- }
- /** Key for the system. */
- private final char key;
- /** Observation time scale.
- * @since 12.0
- */
- private final ObservationTimeScale observationTimeScale;
- /** Simple constructor.
- * @param key key letter
- * @param observationTimeScale observation time scale (may be null)
- */
- SatelliteSystem(final char key, final ObservationTimeScale observationTimeScale) {
- this.key = key;
- this.observationTimeScale = observationTimeScale;
- }
- /** Get the key for the system.
- * @return key for the system
- */
- public char getKey() {
- return key;
- }
- /** Parse a string to get the satellite system.
- * <p>
- * The string first character must be the satellite system.
- * </p>
- * @param s string to parse
- * @return the satellite system
- * @exception OrekitIllegalArgumentException if the string does not correspond to a satellite system key
- */
- public static SatelliteSystem parseSatelliteSystem(final String s)
- throws OrekitIllegalArgumentException {
- final SatelliteSystem satelliteSystem = KEYS_MAP.get(s.charAt(0));
- if (satelliteSystem == null) {
- throw new OrekitIllegalArgumentException(OrekitMessages.UNKNOWN_SATELLITE_SYSTEM, s.charAt(0));
- }
- return satelliteSystem;
- }
- /** Parse a string to get the satellite system.
- * <p>
- * The string first character must be the satellite system, or empty to get GPS as default
- * </p>
- * @param s string to parse
- * @return the satellite system
- * @since 12.0
- */
- public static SatelliteSystem parseSatelliteSystemWithGPSDefault(final String s) {
- return s.isEmpty() ? SatelliteSystem.GPS : parseSatelliteSystem(s);
- }
- /** Get observation time scale for satellite system.
- * @return observation time scale, null if there are not
- * @since 12.0
- */
- public ObservationTimeScale getObservationTimeScale() {
- return observationTimeScale;
- }
- }