DelaunayArguments.java

  1. /* Copyright 2002-2024 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.data;

  18. import java.io.Serializable;

  19. import org.orekit.time.AbsoluteDate;
  20. import org.orekit.time.TimeStamped;

  21. /** Delaunay arguments used for nutation or tides.
  22.  * <p>This class is a simple placeholder,
  23.  * it does not provide any processing method.</p>
  24.  * @author Luc Maisonobe
  25.  * @since 6.1
  26.  */
  27. public class DelaunayArguments implements TimeStamped, Serializable {

  28.     /** Serializable UID. */
  29.     private static final long serialVersionUID = 20170106L;

  30.     /** Date. */
  31.     private final AbsoluteDate date;

  32.     /** Offset in Julian centuries. */
  33.     private final double tc;

  34.     /** Tide parameter γ = GMST + π. */
  35.     private final double gamma;

  36.     /** Tide parameter γ = GMST + π time derivative. */
  37.     private final double gammaDot;

  38.     /** Mean anomaly of the Moon. */
  39.     private final double l;

  40.     /** Mean anomaly of the Moon time derivative. */
  41.     private final double lDot;

  42.     /** Mean anomaly of the Sun. */
  43.     private final double lPrime;

  44.     /** Mean anomaly of the Sun time derivative. */
  45.     private final double lPrimeDot;

  46.     /** L - Ω where L is the mean longitude of the Moon. */
  47.     private final double f;

  48.     /** L - Ω where L is the mean longitude of the Moon time derivative. */
  49.     private final double fDot;

  50.     /** Mean elongation of the Moon from the Sun. */
  51.     private final double d;

  52.     /** Mean elongation of the Moon from the Sun time derivative. */
  53.     private final double dDot;

  54.     /** Mean longitude of the ascending node of the Moon. */
  55.     private final double omega;

  56.     /** Mean longitude of the ascending node of the Moon time derivative. */
  57.     private final double omegaDot;

  58.     /** Simple constructor.
  59.      * @param date current date
  60.      * @param tc offset in Julian centuries
  61.      * @param gamma tide parameter γ = GMST + π
  62.      * @param gammaDot tide parameter γ = GMST + π time derivative
  63.      * @param l mean anomaly of the Moon
  64.      * @param lDot mean anomaly of the Moon time derivative
  65.      * @param lPrime mean anomaly of the Sun
  66.      * @param lPrimeDot mean anomaly of the Sun time derivative
  67.      * @param f L - Ω where L is the mean longitude of the Moon
  68.      * @param fDot L - Ω where L is the mean longitude of the Moon time derivative
  69.      * @param d mean elongation of the Moon from the Sun
  70.      * @param dDot mean elongation of the Moon from the Sun time derivative
  71.      * @param omega mean longitude of the ascending node of the Moon
  72.      * @param omegaDot mean longitude of the ascending node of the Moon time derivative
  73.      */
  74.     public DelaunayArguments(final AbsoluteDate date, final double tc, final double gamma, final double gammaDot,
  75.                              final double l, final double lDot, final double lPrime, final double lPrimeDot,
  76.                              final double f, final double fDot, final double d, final double dDot,
  77.                              final double omega, final double omegaDot) {
  78.         this.date      = date;
  79.         this.tc        = tc;
  80.         this.gamma     = gamma;
  81.         this.gammaDot  = gammaDot;
  82.         this.l         = l;
  83.         this.lDot      = lDot;
  84.         this.lPrime    = lPrime;
  85.         this.lPrimeDot = lPrimeDot;
  86.         this.f         = f;
  87.         this.fDot      = fDot;
  88.         this.d         = d;
  89.         this.dDot      = dDot;
  90.         this.omega     = omega;
  91.         this.omegaDot  = omegaDot;
  92.     }

  93.     /** {@inheritDoc} */
  94.     public AbsoluteDate getDate() {
  95.         return date;
  96.     }

  97.     /** Get the offset in Julian centuries.
  98.      * @return offset in Julian centuries
  99.      */
  100.     public double getTC() {
  101.         return tc;
  102.     }

  103.     /** Get the tide parameter γ = GMST + π.
  104.      * @return tide parameter γ = GMST + π
  105.      */
  106.     public double getGamma() {
  107.         return gamma;
  108.     }

  109.     /** Get the tide parameter γ = GMST + π time derivative.
  110.      * @return tide parameter γ = GMST + π time derivative
  111.      */
  112.     public double getGammaDot() {
  113.         return gammaDot;
  114.     }

  115.     /** Get the mean anomaly of the Moon.
  116.      * @return mean anomaly of the Moon
  117.      */
  118.     public double getL() {
  119.         return l;
  120.     }

  121.     /** Get the mean anomaly of the Moon time derivative.
  122.      * @return mean anomaly of the Moon time derivative
  123.      */
  124.     public double getLDot() {
  125.         return lDot;
  126.     }

  127.     /** Get the mean anomaly of the Sun.
  128.      * @return mean anomaly of the Sun.
  129.      */
  130.     public double getLPrime() {
  131.         return lPrime;
  132.     }

  133.     /** Get the mean anomaly of the Sun time derivative.
  134.      * @return mean anomaly of the Sun time derivative.
  135.      */
  136.     public double getLPrimeDot() {
  137.         return lPrimeDot;
  138.     }

  139.     /** Get L - Ω where L is the mean longitude of the Moon.
  140.      * @return L - Ω
  141.      */
  142.     public double getF() {
  143.         return f;
  144.     }

  145.     /** Get L - Ω where L is the mean longitude of the Moon time derivative.
  146.      * @return L - Ω time derivative
  147.      */
  148.     public double getFDot() {
  149.         return fDot;
  150.     }

  151.     /** Get the mean elongation of the Moon from the Sun.
  152.      * @return mean elongation of the Moon from the Sun.
  153.      */
  154.     public double getD() {
  155.         return d;
  156.     }

  157.     /** Get the mean elongation of the Moon from the Sun time derivative.
  158.      * @return mean elongation of the Moon from the Sun time derivative.
  159.      */
  160.     public double getDDot() {
  161.         return dDot;
  162.     }

  163.     /** Get the mean longitude of the ascending node of the Moon.
  164.      * @return mean longitude of the ascending node of the Moon.
  165.      */
  166.     public double getOmega() {
  167.         return omega;
  168.     }

  169.     /** Get the mean longitude of the ascending node of the Moon time derivative.
  170.      * @return mean longitude of the ascending node of the Moon time derivative.
  171.      */
  172.     public double getOmegaDot() {
  173.         return omegaDot;
  174.     }

  175. }