1   /* Copyright 2002-2025 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  
18  package org.orekit.frames;
19  
20  import org.hipparchus.CalculusFieldElement;
21  import org.orekit.time.AbsoluteDate;
22  import org.orekit.time.FieldAbsoluteDate;
23  
24  /** Utility for Transform providers.
25   * @author Luc Maisonobe
26   * @since 9.2
27   */
28  public class TransformProviderUtils {
29  
30      /** Identity provider.
31       * <p>
32       * The transforms generated by this providers are always {@link Transform#IDENTITY}.
33       * </p>
34       */
35      public static final TransformProvider IDENTITY_PROVIDER = new TransformProvider() {
36  
37          /** {@inheritDoc}
38           * <p>
39           * Always returns {@link Transform#IDENTITY}
40           * </p>
41           */
42          @Override
43          public Transform getTransform(final AbsoluteDate date) {
44              return Transform.IDENTITY;
45          }
46  
47          /** {@inheritDoc} */
48          @Override
49          public StaticTransform getStaticTransform(final AbsoluteDate date) {
50              return StaticTransform.getIdentity();
51          }
52  
53          /** {@inheritDoc}
54           * <p>
55           * Always returns {@link FieldTransform#getIdentity(org.hipparchus.Field)}
56           * </p>
57           */
58          @Override
59          public <T extends CalculusFieldElement<T>> FieldTransform<T> getTransform(final FieldAbsoluteDate<T> date) {
60              return FieldTransform.getIdentity(date.getField());
61          }
62  
63          /** {@inheritDoc} */
64          @Override
65          public <T extends CalculusFieldElement<T>> FieldStaticTransform<T> getStaticTransform(final FieldAbsoluteDate<T> date) {
66              return FieldStaticTransform.getIdentity(date.getField());
67          }
68      };
69  
70      /** Private constructor.
71       * <p>This class is a utility class, it should neither have a public
72       * nor a default constructor. This private constructor prevents
73       * the compiler from generating one automatically.</p>
74       */
75      private TransformProviderUtils() {
76      }
77  
78      /** Reverse a transform provider.
79       * @param provider provider to reverse
80       * @return a new provider which provide a transform similar to
81       * {@code provider.getTransform(date).getInverse()}
82       */
83      public static TransformProvider getReversedProvider(final TransformProvider provider) {
84          return new TransformProvider() {
85  
86              /** {@inheritDoc} */
87              @Override
88              public Transform getTransform(final AbsoluteDate date) {
89                  return provider.getTransform(date).getInverse();
90              }
91  
92              @Override
93              public KinematicTransform getKinematicTransform(final AbsoluteDate date) {
94                  return provider.getKinematicTransform(date).getInverse();
95              }
96  
97              @Override
98              public StaticTransform getStaticTransform(final AbsoluteDate date) {
99                  return provider.getStaticTransform(date).getInverse();
100             }
101 
102             /** {@inheritDoc} */
103             @Override
104             public <T extends CalculusFieldElement<T>> FieldTransform<T> getTransform(final FieldAbsoluteDate<T> date) {
105                 return provider.getTransform(date).getInverse();
106             }
107 
108             /** {@inheritDoc} */
109             @Override
110             public <T extends CalculusFieldElement<T>> FieldKinematicTransform<T> getKinematicTransform(final FieldAbsoluteDate<T> date) {
111                 return provider.getKinematicTransform(date).getInverse();
112             }
113 
114             /** {@inheritDoc} */
115             @Override
116             public <T extends CalculusFieldElement<T>> FieldStaticTransform<T> getStaticTransform(final FieldAbsoluteDate<T> date) {
117                 return provider.getStaticTransform(date).getInverse();
118             }
119 
120         };
121     }
122 
123     /** Combine two transform providers.
124      * @param first first provider to apply
125      * @param second second provider to apply
126      * @return a new provider which provide a transform similar to
127      * {@code new Transform(date, first.getTransform(date), second.getTransform(date))}
128      */
129     public static TransformProvider getCombinedProvider(final TransformProvider first,
130                                                         final TransformProvider second) {
131         return new TransformProvider() {
132             /** {@inheritDoc} */
133             @Override
134             public Transform getTransform(final AbsoluteDate date) {
135                 return new Transform(date, first.getTransform(date), second.getTransform(date));
136             }
137 
138             /** {@inheritDoc} */
139             @Override
140             public StaticTransform getStaticTransform(final AbsoluteDate date) {
141                 return StaticTransform.compose(
142                         date,
143                         first.getStaticTransform(date),
144                         second.getStaticTransform(date)
145                 );
146             }
147 
148             /** {@inheritDoc} */
149             @Override
150             public KinematicTransform getKinematicTransform(final AbsoluteDate date) {
151                 return KinematicTransform.compose(
152                         date,
153                         first.getKinematicTransform(date),
154                         second.getKinematicTransform(date)
155                 );
156             }
157 
158             /** {@inheritDoc} */
159             @Override
160             public <T extends CalculusFieldElement<T>> FieldTransform<T> getTransform(final FieldAbsoluteDate<T> date) {
161                 return new FieldTransform<>(date, first.getTransform(date), second.getTransform(date));
162             }
163 
164             /** {@inheritDoc} */
165             @Override
166             public <T extends CalculusFieldElement<T>> FieldKinematicTransform<T> getKinematicTransform(final FieldAbsoluteDate<T> date) {
167                 return FieldKinematicTransform.compose(
168                         date,
169                         first.getKinematicTransform(date),
170                         second.getKinematicTransform(date)
171                 );
172             }
173 
174             /** {@inheritDoc} */
175             @Override
176             public <T extends CalculusFieldElement<T>> FieldStaticTransform<T> getStaticTransform(final FieldAbsoluteDate<T> date) {
177                 return FieldStaticTransform.compose(
178                         date,
179                         first.getStaticTransform(date),
180                         second.getStaticTransform(date)
181                 );
182             }
183 
184         };
185     }
186 
187 }