GalileoAlmanac.java

  1. /* Copyright 2002-2020 CS GROUP
  2.  * Licensed to CS GROUP (CS) under one or more
  3.  * contributor license agreements.  See the NOTICE file distributed with
  4.  * this work for additional information regarding copyright ownership.
  5.  * CS licenses this file to You under the Apache License, Version 2.0
  6.  * (the "License"); you may not use this file except in compliance with
  7.  * the License.  You may obtain a copy of the License at
  8.  *
  9.  *   http://www.apache.org/licenses/LICENSE-2.0
  10.  *
  11.  * Unless required by applicable law or agreed to in writing, software
  12.  * distributed under the License is distributed on an "AS IS" BASIS,
  13.  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  14.  * See the License for the specific language governing permissions and
  15.  * limitations under the License.
  16.  */
  17. package org.orekit.gnss;

  18. import org.hipparchus.util.FastMath;
  19. import org.orekit.annotation.DefaultDataContext;
  20. import org.orekit.data.DataContext;
  21. import org.orekit.propagation.analytical.gnss.GalileoOrbitalElements;
  22. import org.orekit.time.AbsoluteDate;
  23. import org.orekit.time.GNSSDate;

  24. /**
  25.  * Class for Galileo almanac.
  26.  *
  27.  * @see "European GNSS (Galileo) Open Service, Signal In Space,
  28.  *      Interface Control Document, Table 75"
  29.  *
  30.  * @author Bryan Cazabonne
  31.  * @since 10.0
  32.  *
  33.  */
  34. public class GalileoAlmanac implements GalileoOrbitalElements {

  35.     // Nominal parameters
  36.     /** Nominal inclination (Ref: Galileo ICD - Table 75). */
  37.     private static final double I0 = FastMath.toRadians(56.0);

  38.     /** Nominal semi-major axis in meters (Ref: Galileo ICD - Table 75). */
  39.     private static final double A0 = 29600000;

  40.     /** PRN number. */
  41.     private final int prn;

  42.     /** Satellite E5a signal health status. */
  43.     private final int healthE5a;

  44.     /** Satellite E5b signal health status. */
  45.     private final int healthE5b;

  46.     /** Satellite E1-B/C signal health status. */
  47.     private final int healthE1;

  48.     /** Galileo week. */
  49.     private final int week;

  50.     /** Time of applicability. */
  51.     private final double toa;

  52.     /** Semi-major axis. */
  53.     private final double sma;

  54.     /** Eccentricity. */
  55.     private final double ecc;

  56.     /** Inclination. */
  57.     private final double inc;

  58.     /** Longitude of Orbital Plane. */
  59.     private final double om0;

  60.     /** Rate of Right Ascension. */
  61.     private final double dom;

  62.     /** Argument of perigee. */
  63.     private final double aop;

  64.     /** Mean anomaly. */
  65.     private final double anom;

  66.     /** Zeroth order clock correction. */
  67.     private final double af0;

  68.     /** First order clock correction. */
  69.     private final double af1;

  70.     /** Almanac Issue Of Data. */
  71.     private final int iod;

  72.     /** Date of validity. */
  73.     private final AbsoluteDate date;

  74.     /**
  75.      * Build a new almanac.
  76.      *
  77.      * <p>This method uses the {@link DataContext#getDefault() default data context}.
  78.      *
  79.      * @param prn the PRN number
  80.      * @param week the Galileo week
  81.      * @param toa the Almanac Time of Applicability (s)
  82.      * @param dsqa difference between the square root of the semi-major axis
  83.      *        and the square root of the nominal semi-major axis
  84.      * @param ecc the eccentricity
  85.      * @param dinc the correction of orbit reference inclination at reference time (rad)
  86.      * @param iod the issue of data
  87.      * @param om0 the geographic longitude of the orbital plane at the weekly epoch (rad)
  88.      * @param dom the Rate of Right Ascension (rad/s)
  89.      * @param aop the Argument of Perigee (rad)
  90.      * @param anom the Mean Anomaly (rad)
  91.      * @param af0 the Zeroth Order Clock Correction (s)
  92.      * @param af1 the First Order Clock Correction (s/s)
  93.      * @param healthE5a the E5a signal health status
  94.      * @param healthE5b the E5b signal health status
  95.      * @param healthE1 the E1-B/C signal health status
  96.      * @see #GalileoAlmanac(int, int, double, double, double, double, int, double, double,
  97.      * double, double, double, double, int, int, int, AbsoluteDate)
  98.      */
  99.     @DefaultDataContext
  100.     public GalileoAlmanac(final int prn, final int week, final double toa,
  101.                           final double dsqa, final double ecc, final double dinc,
  102.                           final int iod, final double om0, final double dom,
  103.                           final double aop, final double anom, final double af0,
  104.                           final double af1, final int healthE5a, final int healthE5b,
  105.                           final int healthE1) {
  106.         this(prn, week, toa, dsqa, ecc, dinc, iod, om0, dom, aop, anom, af0, af1,
  107.                 healthE5a, healthE5b, healthE1,
  108.                 new GNSSDate(week, toa * 1000., SatelliteSystem.GALILEO,
  109.                         DataContext.getDefault().getTimeScales()).getDate());
  110.     }

  111.     /**
  112.      * Build a new almanac.
  113.      *
  114.      * @param prn the PRN number
  115.      * @param week the Galileo week
  116.      * @param toa the Almanac Time of Applicability (s)
  117.      * @param dsqa difference between the square root of the semi-major axis
  118.      *        and the square root of the nominal semi-major axis
  119.      * @param ecc the eccentricity
  120.      * @param dinc the correction of orbit reference inclination at reference time (rad)
  121.      * @param iod the issue of data
  122.      * @param om0 the geographic longitude of the orbital plane at the weekly epoch (rad)
  123.      * @param dom the Rate of Right Ascension (rad/s)
  124.      * @param aop the Argument of Perigee (rad)
  125.      * @param anom the Mean Anomaly (rad)
  126.      * @param af0 the Zeroth Order Clock Correction (s)
  127.      * @param af1 the First Order Clock Correction (s/s)
  128.      * @param healthE5a the E5a signal health status
  129.      * @param healthE5b the E5b signal health status
  130.      * @param healthE1 the E1-B/C signal health status
  131.      * @param date corresponding to {@code week} and {@code toa}.
  132.      * @since 10.1
  133.      */
  134.     public GalileoAlmanac(final int prn, final int week, final double toa,
  135.                           final double dsqa, final double ecc, final double dinc,
  136.                           final int iod, final double om0, final double dom,
  137.                           final double aop, final double anom, final double af0,
  138.                           final double af1, final int healthE5a, final int healthE5b,
  139.                           final int healthE1, final AbsoluteDate date) {
  140.         this.prn = prn;
  141.         this.week = week;
  142.         this.toa = toa;
  143.         this.ecc = ecc;
  144.         this.inc = I0 + dinc;
  145.         this.iod = iod;
  146.         this.om0 = om0;
  147.         this.dom = dom;
  148.         this.aop = aop;
  149.         this.anom = anom;
  150.         this.af0 = af0;
  151.         this.af1 = af1;
  152.         this.healthE1 = healthE1;
  153.         this.healthE5a = healthE5a;
  154.         this.healthE5b = healthE5b;
  155.         this.date = date;

  156.         // semi-major axis computation
  157.         final double sqa = dsqa + FastMath.sqrt(A0);
  158.         this.sma = sqa * sqa;
  159.     }

  160.     @Override
  161.     public AbsoluteDate getDate() {
  162.         return date;
  163.     }

  164.     @Override
  165.     public int getPRN() {
  166.         return prn;
  167.     }

  168.     @Override
  169.     public int getWeek() {
  170.         return week;
  171.     }

  172.     @Override
  173.     public double getTime() {
  174.         return toa;
  175.     }

  176.     @Override
  177.     public double getSma() {
  178.         return sma;
  179.     }

  180.     @Override
  181.     public double getMeanMotion() {
  182.         final double absA = FastMath.abs(sma);
  183.         return FastMath.sqrt(GALILEO_MU / absA) / absA;
  184.     }

  185.     @Override
  186.     public double getE() {
  187.         return ecc;
  188.     }

  189.     @Override
  190.     public double getI0() {
  191.         return inc;
  192.     }

  193.     @Override
  194.     public double getIDot() {
  195.         return 0;
  196.     }

  197.     @Override
  198.     public double getOmega0() {
  199.         return om0;
  200.     }

  201.     @Override
  202.     public double getOmegaDot() {
  203.         return dom;
  204.     }

  205.     @Override
  206.     public double getPa() {
  207.         return aop;
  208.     }

  209.     @Override
  210.     public double getM0() {
  211.         return anom;
  212.     }

  213.     @Override
  214.     public double getCuc() {
  215.         return 0;
  216.     }

  217.     @Override
  218.     public double getCus() {
  219.         return 0;
  220.     }

  221.     @Override
  222.     public double getCrc() {
  223.         return 0;
  224.     }

  225.     @Override
  226.     public double getCrs() {
  227.         return 0;
  228.     }

  229.     @Override
  230.     public double getCic() {
  231.         return 0;
  232.     }

  233.     @Override
  234.     public double getCis() {
  235.         return 0;
  236.     }

  237.     @Override
  238.     public double getAf0() {
  239.         return af0;
  240.     }

  241.     @Override
  242.     public double getAf1() {
  243.         return af1;
  244.     }

  245.     /** Get the Issue of Data (IOD).
  246.      * @return the Issue Of Data
  247.      */
  248.     public int getIOD() {
  249.         return iod;
  250.     }

  251.     /**
  252.      * Gets the E1-B/C signal health status.
  253.      *
  254.      * @return the E1-B/C signal health status
  255.      */
  256.     public int getHealthE1() {
  257.         return healthE1;
  258.     }

  259.     /**
  260.      * Gets the E5a signal health status.
  261.      *
  262.      * @return the E5a signal health status
  263.      */
  264.     public int getHealthE5a() {
  265.         return healthE5a;
  266.     }
  267.     /**
  268.      * Gets the E5b signal health status.
  269.      *
  270.      * @return the E5b signal health status
  271.      */
  272.     public int getHealthE5b() {
  273.         return healthE5b;
  274.     }

  275. }