Source code for test_jointThrAllocation

#
#  ISC License
#
#  Copyright (c) 2026, Autonomous Vehicle Systems Lab, University of Colorado at Boulder
#
#  Permission to use, copy, modify, and/or distribute this software for any
#  purpose with or without fee is hereby granted, provided that the above
#  copyright notice and this permission notice appear in all copies.
#
#  THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
#  WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
#  MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
#  ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
#  WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
#  ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
#  OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.

import numpy as np

from Basilisk.fswAlgorithms import jointThrAllocation


[docs] def test_map_matrix(): """ **Validation Test Description** This unit test verifies that :func:`jointThrAllocation.mapMatrix` maps thruster force magnitudes into the expected stacked force and torque wrench. **Description of Variables Being Tested** This unit test checks the force block and torque block of the returned wrench mapping matrix. """ rVec_B = np.array([[1.0, 0.0, 0.0], [0.0, 1.0, 0.0]]) # [m] fHatVec_B = np.array([[0.0, 1.0, 0.0], [0.0, 0.0, 1.0]]) r_ComB_B = np.array([0.0, 0.0, 0.0]) # [m] mapping = jointThrAllocation.mapMatrix(rVec_B, fHatVec_B, r_ComB_B) expected = np.array( [ [0.0, 0.0], [1.0, 0.0], [0.0, 1.0], [0.0, 1.0], [0.0, 0.0], [1.0, 0.0], ] ) np.testing.assert_allclose(mapping, expected)
[docs] def test_allocation_configuration_helpers(): """ **Validation Test Description** This unit test verifies that :class:`jointThrAllocation.JointThrAllocation` can be constructed from the standard ``Basilisk.fswAlgorithms`` import path and that the helper methods resolve scalar and vector configuration values. **Description of Variables Being Tested** This unit test checks the resolved thrust force bounds, thrust weights, and initial decision vector shape. """ allocation = jointThrAllocation.JointThrAllocation() allocation.nJoint = 2 allocation.nThr = 2 allocation.setThrForceMax(4.0) # [N] np.testing.assert_allclose(allocation.resolveThrForceMax(), np.array([4.0, 4.0])) # [N] allocation.setWf(1.0e-5) allocation.resolveWf() np.testing.assert_allclose(allocation.Wf, np.array([1.0e-5, 1.0e-5])) allocation.initialGuesses() assert allocation.x0.shape == (5, 4) bounds = allocation.bounds() assert bounds[0] == (-np.pi, np.pi) assert bounds[1] == (-np.pi, np.pi) assert bounds[2] == (0.0, 4.0) # [N] assert bounds[3] == (0.0, 4.0) # [N]