1   /* Copyright 2022-2025 Romain Serra
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.control.indirect.adjoint.cost;
18  
19  import org.hipparchus.geometry.euclidean.threed.Vector3D;
20  import org.junit.jupiter.api.Assertions;
21  import org.junit.jupiter.api.Test;
22  import org.junit.jupiter.params.ParameterizedTest;
23  import org.junit.jupiter.params.provider.ValueSource;
24  
25  class CartesianFlightDurationCostTest {
26  
27      private static final String ADJOINT_NAME = "adjoint";
28  
29      @Test
30      void testGetHamiltonianContribution() {
31          // GIVEN
32          final CartesianFlightDurationCost cost = new CartesianFlightDurationCost(ADJOINT_NAME, 1, 2);
33          // WHEN
34          final double contribution = cost.getHamiltonianContribution(new double[6], 1);
35          // THEN
36          Assertions.assertEquals(-1, contribution);
37      }
38  
39      @ParameterizedTest
40      @ValueSource(booleans = {false, true})
41      void testUpdateFieldAdjointDerivatives(final boolean withMass) {
42          // GIVEN
43          final double massFlowRateFactor = withMass ? 1 : 0;
44          final CartesianFlightDurationCost cost = new CartesianFlightDurationCost(ADJOINT_NAME, massFlowRateFactor, 2);
45          final double[] adjoint = new double[withMass ? 7 : 6];
46          adjoint[3] = 1;
47          final double[] derivatives = new double[adjoint.length];
48          // WHEN
49          cost.updateAdjointDerivatives(adjoint, 1, derivatives);
50          // THEN
51          for (int i = 0; i < 6; ++i) {
52              Assertions.assertEquals(0., derivatives[i]);
53          }
54          if (withMass) {
55              Assertions.assertNotEquals(0., derivatives[derivatives.length - 1]);
56          } else {
57              Assertions.assertEquals(0., derivatives[derivatives.length - 1]);
58          }
59      }
60  
61      @Test
62      void testGetThrustAccelerationVector() {
63          // GIVEN
64          final CartesianFlightDurationCost cost = new CartesianFlightDurationCost(ADJOINT_NAME, 1, 2);
65          // WHEN
66          final Vector3D contribution = cost.getThrustAccelerationVector(new double[] {0, 0, 0, 1, 2, 3}, 1);
67          // THEN
68          Assertions.assertEquals(new Vector3D(1, 2, 3).normalize().scalarMultiply(cost.getMaximumThrustMagnitude()),
69                  contribution);
70      }
71  }