Skip to main content
Sensors (Basel, Switzerland) logoLink to Sensors (Basel, Switzerland)
. 2021 Nov 5;21(21):7361. doi: 10.3390/s21217361

In-Orbit Attitude Determination of the UVSQ-SAT CubeSat Using TRIAD and MEKF Methods

Adrien Finance 1,2, Christophe Dufour 1, Thomas Boutéraon 1, Alain Sarkissian 1, Antoine Mangin 2, Philippe Keckhut 1, Mustapha Meftah 1,*
Editor: Daniele Mortari
PMCID: PMC8588341  PMID: 34770668

Abstract

Ultraviolet and infrared sensors at high quantum efficiency on-board a small satellite (UVSQ-SAT) is a CubeSat dedicated to the observation of the Earth and the Sun. This satellite has been in orbit since January 2021. It measures the Earth’s outgoing shortwave and longwave radiations. The satellite does not have an active pointing system. To improve the accuracy of the Earth’s radiative measurements and to resolve spatio-temporal fluctuations as much as possible, it is necessary to have a good knowledge of the attitude of the UVSQ-SAT CubeSat. The attitude determination of small satellites remains a challenge, and UVSQ-SAT represents a real and unique example to date for testing and validating different methods to improve the in-orbit attitude determination of a CubeSat. This paper presents the flight results of the UVSQ-SAT’s attitude determination. The Tri-Axial Attitude Determination (TRIAD) method was used, which represents one of the simplest solutions to the spacecraft attitude determination problem. Another method based on the Multiplicative Extended Kalman Filter (MEKF) was used to improve the results obtained with the TRIAD method. In sunlight, the CubeSat attitude is determined at an accuracy better than 3° (at one σ) for both methods. During eclipses, the accuracy of the TRIAD method is 14°, while it reaches 10° (at one σ) for the recursive MEKF method. Many future satellites could benefit from these studies in order to validate methods and configurations before launch.

Keywords: CubeSat attitude determination, TRIAD, Kalman filter, climate

1. Introduction

Ultraviolet and infrared sensors at high quantum efficiency on-board a small satellite (UVSQ-SAT) is a scientific and technological demonstrator dedicated to the observation of essential climate variables [1]. UVSQ-SAT was launched into a Sun-synchronous orbit by the LATMOS with the Falcon 9 rocket on 24 January 2021. After a commissioning phase, the routine phase started on 13 March 2021. Since then, the CubeSat has been fully functional, and first results have been published [2]. The methods used by [1] to obtain these results (maps of the solar radiation reflected by the Earth and of the outgoing longwave radiation at the top of the atmosphere) do not take into account the attitude of the UVSQ-SAT CubeSat. To improve the accuracy of the results, it is highly recommended to have an excellent knowledge of the attitude of the UVSQ-SAT CubeSat. This would allow researchers to obtain the Earth’s incident flux on each UVSQ-SAT face, given that the CubeSat has Earth radiative sensors and photodiodes on all its faces [1].

To determine the attitude of the UVSQ-SAT CubeSat, two methods are used: the Tri-Axial Attitude Determination (TRIAD) method and the Multiplicative Extended Kalman Filter (MEKF) method. TRIAD is a basic method, which is implemented by considering that the instruments’ measurements can be easily related to the information from models in an inertial frame of reference at the satellite’s location. Then, it is necessary to find the perfect rotation matrix to move from one reference frame to another. The MEKF method improves the results obtained with the TRIAD method. It aims to calibrate and correct the data from noise and inaccuracies.

The most commonly used methods in the literature are TRIAD and MEKF. Indeed, there are very few examples of results associated with CubeSat attitude determination in orbit. Table 1 presents a detailed background of the recent studies related to the problem of satellite attitude determination (AD). Simulations show that the restitution of the attitude can be better than 1°. Moreover, the Radio Aurora Explorer satellites 3U CubeSat [3] demonstrated that it was possible to obtain knowledge of a satellite’s attitude with an accuracy better than 1° (sunlight) in orbit. Despite the small size of the CubeSats, it seems possible to accurately determine their attitude in orbit. This is mainly valid when the satellite is aimed at the Sun because several sensors (solar photodiodes, magnetometers, and gyroscopes) are used to perform this task successfully. During eclipses, this determination is more complex. CubeSat attitude determination is still a challenge as they are small, and they still do not have active attitude determination and control systems (ADCS). Furthermore, new miniaturized space-based payloads are becoming increasingly complex and require accurate knowledge of the satellite attitude. One of the objectives of the UVSQ-SAT mission is to obtain knowledge of the CubeSat attitude with an accuracy better than a few degrees in sunlight.

Table 1.

Studies related to attitude determination (simulation and in-orbit observations).

Reference Method (Instruments) Goal Results/Remarks
[4] Simulation Attitude determination (AD) based solely on magnetometer Converges from initial attitude errors of maximum 60° and with an attitude accuracy of 1° (1σ) or better
[5] Observation (Rossi X-ray Timing Explorer satellite calibration maneuvers, Terra and Wide-Field Infrared Explorer mission, Upper Atmosphere Research Satellite (UARS)) On-orbit calibration of satellite gyroscopes Methods comparison (attitude accuracy below 1°). The Delta-bias algorithm gives slightly less accurate results than the Davenport and BICal algorithms
[6] Simulation Absolute alignment calibration of a system comprising two star trackers, an inertial sensor assembly (ISA) of three fiber-optic gyros, and an imaging instrument based on Alignment Kalman Filter (AKF) AKF is effective to estimate absolute misalignments and gyro calibration parameters
[7] Simulation AD using an Extended Kalman Filter (EKF), which applies the albedo model with a magnetometer and sun sensor Attitude accuracy below 1°
[8] Simulation and Observation (Total Ozone Mapping Spectrometer (TOMS)) Modeling the albedo for Sun/Earth sensor used in attitude determination Albedo compensation in attitude estimation, improves the maximum error from 9.9° to 1.9°
[9] Simulation AD using Unscented Kalman Filter (UKF) based only on magnetometer The attitude estimation accuracies are below 0.5° after convergence
[10] Simulation (PROBA-2 Spacecraft scenarios) Navigation system for magnetic-only orbit and attitude estimation using the square-root Unscented filter (MAGSURF) RSS attitude error of less than 1.4° and a time of convergence of less than 2 orbits
[11] Simulation Attitude and rate estimation algorithm using EKF based only on geomagnetic field data Filter converges within the +/−8° range for any initial attitude error
[12] Simulation (Radio Aurora Explorer satellites (3U CubeSat)) AD based on gyros, magnetometers, coarse sun sensors, and an EKF In the sun, the angular uncertainty is between 2° and 3°, and in eclipse, the uncertainty increases to between 7° and 8°
[13] Simulation AD using two-step EKF based on a magnetometer only Attitude accuracies of less than 1°
[3] Observation (Radio Aurora Explorer satellites (3U CubeSat)) Photodiodes calibration and AD from EKF/UKF with albedo model based on the calibrated photodiodes, three-axis magnetometer and gyrometer Angular improvement of 10° in sun vector from the photodiodes, and below 1° accuracy on the attitude determination
[14] Simulation AD via a robust Adaptive Kalman Filter based on magnetometer and gyro measurement Precision of traditional EKF is about 0.2°, and the maximum estimate error of the robust adaptive filter is 0.1°
[15] Simulation and Observation (experimental data with on-ground nano-satellite) Gain-scheduled EKF (GSEKF) to reduce the computational requirement in the nanosatellite attitude determination process Attitude accuracy below 0.2° during the entire orbital period. Computation time could be reduced by 86.29% and 89.45%
[16] Simulation Magnetometer calibration with Hyper least square (HyperLS) estimator for ellipsoid fitting, then utilized for attitude determination via non-linear colored noise filters of EKF, simplex UKF and cubature Kalman filter Attitude accuracy below 1° for simplex UKF
[17] Observation (images taken from International Space Station (ISS)) AD utilizing color earth images taken with visible light camera Attitude accuracy is about few degrees or less
[18] Simulation Heat attitude model for satellite attitude determination Attitude accuracy between 0.2 ° to 5°
[19] Simulation AD method based on an UKF, using a gyrometer, a magnetometer and solar panels as a sun sensor The UKF has shown precision in Euler angles of about 1.1°, which is better than for EKF. UKF has a considerably longer processing time compared to EKF
[20] Simulation and Observation (experimentation on-ground set up) Thermal imaging sensors to determine attitude of the Sun and the horizon by employing a homogeneous array of such detectors Angular accuracy below 1°

This manuscript presents two methods to determine the attitude of the UVSQ-SAT CubeSat. This is an important step in the implementation process of the scientific results of the UVSQ-SAT space-based mission. Section 2 describes the inputs from the satellite along with the models and geometrical considerations of the two methods. Section 3 presents the implementation of the two different methods and how they differ. Section 4 shows the results obtained from the different methods and how the MEKF method has improved the accuracy of the determination of the UVSQ-SAT CubeSat attitude of the TRIAD method. Finally, Section 5 is dedicated to the presentation of conclusions and perspectives.

2. UVSQ-SAT Attitude Determination Considerations

This section presents a description of the sensors of the UVSQ-SAT CubeSat, reference frames and attitude representation, and the theoretical approach of the method.

2.1. Sensors Description

The UVSQ-SAT satellite described by [1] is equipped with different subsystems and sensors, among which some are used to determine its attitude. Those instruments are defined in the spacecraft body frame (B). The different faces of the spacecraft are named after this reference frame. Two opposite faces correspond to one axis. This is shown in Figure 1. The instrumental reference frame is fixed with respect to the satellite. It undergoes only one constant rotation with respect to the satellite reference frame. To simplify this, we apply this rotation and consider the measurements in the spacecraft body frame. We do not mention the instrument frame in the following explanations.

Figure 1.

Figure 1

Spacecraft body frame of the UVSQ-SAT satellite.

The different inputs available to the algorithms are as follows:

  • Three-axis angular velocities. The gyrometer measures the three-axis angular velocities in the sensor frame to the inertial reference frame (I), defined by ωg={ωX,ωY,ωz}B/I, as the calibrated measurement.

  • Three-axis magnetic field. The magnetometer measures the magnetic field along its three axes in the instrument’s reference frame defined by B={BX,BY,BZ}B, as the calibrated measurement.

  • Six photodiodes in the visible domain. They measure solar and outgoing shortwave radiations in the 400–1100 nm wavelength range. They are defined as the calibrated fluxes Φp={Φp+X,ΦpX,Φp+Y,ΦpY,Φp+Z,ΦpZ}. They are used as a Sun sensor.

  • Six Earth radiative sensors (ERS) sensors with an Optical Solar Reflector (OSR). They aim to measure radiation between 0.2 and 3 μm. They are defined as Φosr={Φosr+X,ΦosrX,Φosr+Y,ΦosrY,Φosr+Z,ΦosrZ}. Those sensors are used as an Earth sensor and aimed toward the nadir.

  • Six ERS sensors with carbon nanotubes (CNT). Six sensors aim to measure total radiation between 0.2 and 100 μm. They are defined as Φcnt={Φcnt+X,ΦcntX,Φcnt+Y,ΦcntY,Φcnt+Z,ΦcntZ}. They are used as Earth sensors.

An example of the time series of the UVSQ-SAT inputs is given in Figure 2. Oscillations are present in the magnetometer and gyrometer measurements as the satellite rotates. For the photodiode measurements, sunlight and eclipses periods appear clearly. ERS sensors measure all Earth and solar radiative fluxes. Eclipses periods appear also clearly.

Figure 2.

Figure 2

Time series of the measurements for two orbits on 26 March 2021 from the three-axis magnetometer, the three-axis gyrometer, the photodiodes, and the ERS sensors.

2.2. Orbital Reference Frames and Attitude Representation

2.2.1. Orbital Reference Frames

The following reference frames are required for the in-orbit attitude determination of the UVSQ-SAT CubeSat. They allow us to compute the satellite’s attitude with respect to one of those frames. The reference frames are shown in Figure 3, Figure 4 and Figure 5. We recall that the gyrometer measures an angular velocity in the body frame with respect to an inertial reference frame. Therefore, an essential reference frame defined here is the Earth-centered inertial (ECI) along with the Earth-centered orbit reference frame (OC). The reference frames are described as follows:

  • Earth-centered inertial (ECI). The reference frame is defined in blue in Figure 3 with an origin at the Earth’s center of mass. The X-axis is defined as the vernal equinox axis at J2000, the intersection between the equatorial and the ecliptic planes. The Z-axis is defined as the Earth rotation axis at epoch J2000. Finally, the Y-axis is defined according to the previous directions to create an orthogonal basis.

  • Earth-centered Earth-fixed (ECEF). The reference frame is defined in red in Figure 3 with its origin at the Earth’s center of mass. Its X-axis is defined at the intersection of the Greenwich prime meridian and the equator. Its Y-axis is the intersection of the equatorial plane and the 90° longitude. The Z-axis extends through the true north and south poles and coincides with the Earth’s rotation axis.

  • North East Down (NED). Assuming a WGS84 ellipsoid model of the Earth, the NED, defined in purple in Figure 3, is a local reference frame that moves the body frame’s position in the ECEF. It is defined so that the X–Y plane is tangential to the surface of the ellipsoid at the given location in the ECEF. Given those conditions, the X-axis should point toward true North, the Z-axis toward the interior of the Earth, and the Y-axis will finalize the orthogonal basis.

  • Earth-centered orbit reference frame (OC). The reference frame is defined in blue in Figure 4 and Figure 5 and centered at the Earth’s center, with the X-axis towards the perigee, the Y-axis along the semi-minor axis, and the Z-axis perpendicular to the orbital plane to complete the right-hand system. From the previous reference frame, it is thus necessary to define a local reference frame that will follow the satellite in its center. This reference frame is chosen for its logic with respect to the satellite motion as well as the possibility of taking into account the orbital velocity in order to correct the gyrometer of this frame.

  • Orbit reference frame (O). The reference frame is defined such that its origin is located at the center of the spacecraft. The origin rotates relative to the ECI with an angular velocity of ω0. Its Z-axis points towards the center of the Earth. The X-axis is perpendicular to the previous axis in the spacecraft’s direction of motion. The Y-axis completes the right-hand system.

Figure 3.

Figure 3

Earth-centered inertial (ECI), Earth-centered Earth-fixed (ECEF), and North East Down (NED) reference frames.

Figure 4.

Figure 4

Earth centered orbit reference frame (OC) and orbit (O) reference frames.

Figure 5.

Figure 5

Earth-centered inertial (ECI), Earth-centered Earth-fixed (ECEF), and orbit (O) reference frames.

2.2.2. Attitude Representation

There are different ways to express the satellite attitude in its reference frame. The first basic representations are known as the Euler angles. The orientation of the body with respect to a reference frame is given by three Euler angles. Those angles define three successive rotations around different axes. Roll, pitch, and yaw angles are defined in Figure 6 and are called ϕ, θ, and ψ, respectively.

Figure 6.

Figure 6

Euler angles defined for the satellite.

In order to avoid singularities that come with the choice of using Euler angles for attitude representation, we define the quaternion representation where a quaternion q is defined as

q=q1+q2i+q3j+q4k=q1q2q3q4 (1)

where q1, q2, q3, and q4 are real numbers with 1,i,j,andk as a basis for a 4-dimensional vector space. i2=j2=k2=ijk=1 and as q0. The rotation resulting from the previous quaternion is characterized by its rotation angle α around its axis of coordinates (rx,ry,rz) defined in Equation (2a,b):

α=2atan2q22+q32+q42,q1 (2a)
(rx,ry,rz)=(q2,q3,q4)q22+q32+q42 (2b)

Then, we obtain Equation (3) as follows:

q1q2q3q4=cosα2rxsinα2rysinα2rysinα2 (3)

The quaternions and the Euler angles can be associated as (Equation (4))

q1=cos(α2)q2=sin(α2)cos(αx)q3=sin(α2)cos(αy)q4=sin(α2)cos(αz) (4)

where αx, αy, and αz are the angles between the axis of rotation and the axes X, Y, and Z, respectively. From those two representations, we can create a third tool—the Direction Cosine Matrix (DCM)—that is used in the algorithm. We define the rotation matrix, also called the attitude matrix, which represents the rotation of the body in the body frame (B) with respect to a specified frame—for example, the orbital frame (O)—as follows in Equation (5a,b):

DCMOB(ϕ,θ,ψ)=1000cosϕsinϕ0sinϕcosϕcosθ0sinθ010sinθ0cosθcosψsinψ0sinψcosψ0001 (5a)
DCMOB(q)=12s(q32+q42)2s(q2q3q4q1)2s(q2q4+q3q1)2s(q2q3+q4q1)12s(q22+q42)2s(q3q4q2q1)2s(q2q4q3q1)2s(q3q4+q2q1)12s(q22+q32) (5b)

where s is the quaternion’s norm.

2.3. Theoretical Approach of the Method

The instruments and the reference frames are described in the previous section. It is now possible to present the different inputs required for attitude determination. Those inputs are the nadir direction, the Sun line-of-sight (LOS), the magnetic field vectors, and the gyrometer data. We suppose that those vectors are defined as follows (Equation (6a–c)):

S^(t)=S(t)+ηS(t) (6a)
N^(t)=N(t)+ηN(t) (6b)
B^(t)=B(t)+ηB(t) (6c)

where S^(t), N^(t), and B^(t) are the Sun LOS, the nadir direction, and the magnetic field vectors retrieved from the instruments on-board the satellite, respectively. S(t), N(t) and B(t) are the true Sun LOS, the true nadir direction, and the true magnetic field vectors, respectively. ηS(t), ηN(t), and ηB(t) are the three zero-mean Gaussian noises that we assume for the three vectors. According to Table 1, the use of a nadir direction in an eclipse to determine the satellite attitude is not common. In an eclipse, Table 1 shows that the most common idea is to rely only on magnetometer and gyrometer measurements. Indeed, we know that the gyrometer can be very noisy and inaccurate [21]. However, the UVSQ-SAT is equipped with the infrared sensors presented in Section 2. Thus, those infrared sensors will help to determine the nadir direction from the terrestrial infrared radiations.

The three-axis rate from the gyrometer is defined with ω^(t) as follows (Equation (7a,b)):

ω^(t)=ω(t)+β(t)+ηω(t) (7a)
β˙(t)=ηβ(t) (7b)

where ω(t) is the true rate, β(t) is the drift, and ηω(t) and ηβ(t) are the zero-mean Gaussian noises.

As the measurements from the gyrometer are conducted with respect to an inertial reference frame, this is defined as (Equation 8)

ωB/I=ωB/OC+ωOC/I (8)

where ωOC/I is the rate from the body frame with respect to the inertial frame that is equal to ω0 the orbital angular velocity along the axis orthogonal to the orbital plane. ω0 is computed from the mean motion given at each time. This information is contained in a list of orbital elements for a given point in time called a two-line element set (retrieved by the NORAD). The angular velocity with respect to the orbital frame is computed at each time given the attitude matrix at that time with respect to the orbital frame in Equation (9).

ωB/O=ωB/IAOBωO/I=ωB/IAOBω0 (9)

where AOB is the rotation matrix from the local orbital frame to the body reference frame. The changes in the reference frame presented are directly related to the description of the reference frames in Section 2.2.1. The choice of the inertial reference frame to use has been meticulously made to facilitate the calculations in Equation (9).

3. Attitude Determination Methods

3.1. Tri-Axial Attitude Determination Method (TRIAD)

3.1.1. Formulation of the Method

The TRIAD algorithm aims to determine the attitude of the CubeSat. The output of the algorithm is the rotation matrix from the orbit reference frame (O) to the body reference frame (B). This matrix is also called the attitude matrix. The calculations are done instantaneously using two known vectors in both of the reference frames. The inputs required to compute the attitude matrix are the Sun LOS and the magnetic field in the two reference frames. In the body reference frame, the vectors are determined from the UVSQ-SAT measurements. In the orbit reference frame, the inputs are computed from the International Geomagnetic Reference Field [22] and orbital models at the satellite’s location and time. We note that in an eclipse, we use nadir vectors instead of Sun LOS vectors. The nadir vector is defined as N in the body frame and No in the local orbital frame. The method is described in sunlight in the Equations (10) and (11). For the eclipse periods, N and S would commute. Nevertheless, less accurate results are expected in an eclipse since it is more complicated to determine the nadir from the infrared sensors rather than the Sun LOS.

To compute the attitude from the TRIAD algorithm, we introduce a new reference frame based on the body and orbital reference frames. This new reference frame is called the TRIAD frame and was described in [23,24]. The TRIAD frame is meant to be an intermediary between the orbital and the body frame; therefore, it should be easily defined in each of those reference frames. This reference frame is based on the magnetic field and the Sun LOS vectors. Let us start by expressing the TRIAD frame in the body reference frame, which is described as t1b,t2b,t3b in Figure 7. Ideally, the most accurate vector should be used as the first axis. Usually, Sun sensors are more accurate than magnetometers. The Sun LOS is therefore chosen as the first direction. This axis is often called the anchor as it remains unchanged. Thus, the frame can be described in the body reference frame as (Equation (10))

t1b=SS,t2b=S×BS×B,t3b=t1b×t2b (10)

where S and B are the Sun LOS and magnetic field vector in the body frame retrieved from the instruments on-board the spacecraft, and the TRIAD’s basis can be expressed as t1o,t2o,t3o in the orbital frame, in Equation (11):

t1o=SoSo,t2o=So×BoSo×Bo,t3o=t1o×t2o (11)

where So and Bo are the Sun LOS and magnetic field vectors in the orbital frame computed from models. Therefore, it is rather simple to recover the transfer matrix from the orbital to body frame via the TRIAD frame. The rotation matrix can be written as in Equation (12):

RTRIAD,OB=[t1o,t2o,t3o][t1b,t2b,t3b]T (12)
Figure 7.

Figure 7

Reference frames for TRIAD method.

3.1.2. Optimized TRIAD

One of the limitations of the TRIAD method presented in Section 3.1.1 is the dependence on the choice of the first direction. This direction, called the anchor, remains untouched through the TRIAD process. However, in reality, neither of the two vectors used are perfectly aligned with the model. Therefore, in [25], the authors proposed to improve the method by taking the relative accuracy of the two measurements into account. The idea is to weight the two attitude matrices corresponding to the choice of using either of the two vectors as the first direction. This algorithm is called the optimized TRIAD algorithm. We define σS and σB as the standard deviations of the error of the LOS vector and the magnetic field vector, respectively. The attitude matrices AS and AB computed via the TRIAD method are for using the Sun LOS vector and magnetic field vector, respectively, as the first direction of the TRIAD frame. The weighting process is done as follows (Equation (13)).

A*=σS2σS2+σB2AS+σB2σS2+σB2AB (13)

In order to obtain an attitude matrix, the resulting matrix must be orthogonal; therefore, the final attitude matrix is obtained in Equation (14). According to [26], one orthogonalization cycle is needed as A* is close to being orthogonal.

A=12[A*+(A*1)T] (14)

Coarse Sun sensors are obviously not as accurate as Sun sensors. Therefore, it is quite legitimate to take the relative uncertainties of the two components into account via the presented method.

As for the simple TRIAD algorithm, no noise correction is applied. In case of large noise or, for example, high variability of the magnetic field, the computed attitude would not be accurate.

3.2. Multiplicative Extended Kalman Method

The MEKF method aims to improve the attitude determination accuracy by correcting instrument noise and calibrating the gyrometer in real-time. The Kalman filter was described by Swerling in 1958 or Kalman [27] and Kalman and Bucy [28]. The principle is based on a two-step method that aims to correct noises and instrument uncertainties. The state variables describe the system at each time. These variables provide information on the corrections to be made to the instruments as well as the orientation of the satellite. They are first estimated and then corrected based on the observation from the instruments. Although standard Kalman filters are truly efficient for linear systems, they cannot be accurate for non-linear systems. Therefore, in our case, we use an Extended Kalman Filter (EKF). This algorithm is a linearized Kalman filter at the point of reference using the Taylor series expansions principle.

3.2.1. Formulation

At each iteration, MEKF [29] uses the quaternion as the attitude representation and the state vector δϑ for the representation of the attitude errors. The true quaternion can then be defined as follows (Equation (15)):

qtrue=δq(δϑ)q^ (15)

where qtrue is the true quaternion that represents the real orientation of the object that is defined from a product. q^ is the estimate quaternion giving an estimate of the object orientation. δq(δϑ) is the error quaternion defined by δϑ, with the three components representing the attitude error. ⊗ is the quaternion product symbol first used in [30] and defined in [29] as follows (Equation (16)):

q¯q=q4q¯1:3+q¯4q1:3+q¯1:3×q1:3q¯4q4q¯1:3.q1:3 (16)

where x^ represents the estimate of the quantity x (for example, the state vector). x^+ represents the updated quantity of x^, before being updated. The local attitude error is the true linearized variable of interest to compute the attitude at each iteration. However, the gyrometer which is required to predict the motion of the satellite has several calibration parameters that need to be computed, such as the misalignments, scale factors, and time-dependent drift biases. Therefore, those quantities must be computed at each iteration. So, they must be considered as state variables.

3.2.2. Initialization

The state vector as mentioned previously is computed as (Equation (17))

x^0=δϑ^0Tβ^0Ts^0Tk^U0Tk^L0T (17)

where β^0 is the initial gyro drift biases. s^0 is the initial gyrometer scale factor. k^U0 and k^L0 are the initial misalignments. P0 is the initial covariance matrix defined from the predicted instrument uncertainties. δϑ^0=03 is the initial attitude error for q^0 (initial quaternion).

3.2.3. Gain

The Kalman gain is used to give different weights to the measurements and the current estimate of the state. This is the weight assigned to the prediction or the observation and is defined by Kk as (Equation (18))

Kk=PkHkT(x^k)[Hk(x^k)PkHkT(x^k)+Rk]1 (18)

where Hk(xk) is the observation model at time tk. Rk is the measurement-error covariance matrix at tk. Pk is the state error covariance at tk. Hk(xk) is the observation matrix and is defined by (Equation 19):

Hk(xk)=A(q^)Bo×|03×12A(q^)So×|03×12A(q^)No×|03×12 (19)

The operator × is such that (Equation (20))

x1:3×=0x3x2x30x1x2x10 (20)

where A(q) is the attitude matrix in Equation (21):

A(q)=q2((q42q1:32)I+2q1:3q1:3T2q4[q1:3×])) (21)

3.2.4. Update

This subsection aims to compute the post-update of the different variables at time tk. The covariance matrix P can then be post-updated in Equation (22):

Pk+=[IKkHk(x^k)]Pk (22)

At this phase, a reset is applied to the pre-estimate of the error angle in Equation (23):

δϑ^k=03 (23)

It is then possible to update the state vector in Equation (24):

x^k+=x^k+Kk[ykhk(x^k)] (24)

where x^k=[δϑ^kTβ^kTs^kTk^UkTk^LkT]. hk(x^k) is the estimated observation that is given in Equation (25). The measurements are given in Equation (26).

hk(x^k)=A(q^)BoA(q^)SoA(q^)Notk (25)
yk=BSNtk (26)

The quaternion’s update is performed through two steps that aim to compute the quaternion corresponding to the error estimate in Equation (27a) and to preserve the unit quaternion norm in Equation (27b).

q^*=q^k+12Ξ(q^k)δϑ^k+ (27a)
q^k+=q*q* (27b)

where δϑ^k+ corresponds to the first three components of the state vector x^k+ and the Ξ(q) matrix is defined in Equation (28):

Ξ(q)=q4I3+[q1:3×]q1:3T (28)

3.2.5. Propagation

The propagation part aims to propagate the expected values and covariance at time tk+1. First of all, we compute the estimate of the gyrometer components corrected based on the factors, drifts, and misalignments obtained from the previous step as (Equation (29))

ω^+(t)=[I3S^(t)][ω^(t)β^(t)] (29)

where S characterizes the gyrometer biases and misalignments and is defined as (Equation (30)):

S=s1kU1kU2kL1s2kU3kL2kL3s3 (30)

Based on the knowledge of the updated angular rate and quaternion at time tk, the quaternion’s estimate at time tk+1 is defined in Equation (31) as

q^k+1=Θ¯(ω^k+)q^k+ (31)

where Θ¯(ω^k+) is defined as (Equation (32))

Θ¯(ω^k+)=cos12ω^k+ΔtI3[Ψ^k+×]Ψ^k+Ψ^k+cos12ω^k+Δt (32)

where Δt is the duration between the two considered epochs. Ψ^k+ is computed in Equation (33) as

Ψ^k+=sin12ω^k+Δtω^k+ω^k+ (33)

The covariance matrix P estimate at tk+1 is such that (Equation (34))

Pk+1=ΦkPk+ΦkT+ΓkQkΓkT (34)

where Qk is defined as in Equations (35)–(37) at the initialization and during the iterations as

Q(t)=blockdiagonal([σv2I3σu2I3σs2I3σU2I3σL2I3]) (35)
Qk=ΔtGQGT (36)
G(t)=(I3S^)03×12012×3I12 (37)

where Φk is the state transition matrix that is computed as follows (Equations (38)–(40b)) for a simple first-order approximation:

Φk=I15+ΔtF(tk) (38)
F(t)=[ω^(t)×](I3S^)diag(ωβ^)U^L^012×3012×3012×3012×3012×3 (39)
U^=ω2β^2ω3β^3000ω3β^3000 (40a)
L^=000ω1β^1000ω1β^1ω2β^2 (40b)

These calculation steps are applied to the inputs for each time step. In the case where the uncertainties related to the dynamics model are not very important, the corrections related to the gyro will converge at least in the short term. Nevertheless, they could evolve with the aging of the instrument and the flight conditions; thus, real-time calibration is legitimate.

4. Results

Once the algorithm is implemented, it is possible to calculate the satellite attitude for each measurement acquisition. The objective of calculating this attitude is required to compute the incident flux for each face of the CubeSat, as presented in Section 1. This means that the measured fluxes are corrected from their angle to the observed source. Therefore, the flux corrections are directly related to the Sun LOS and nadir vectors in the spacecraft body frame.

This section presents the two unit vectors in the satellite’s body reference frame for both TRIAD and MEKF methods. The vectors are represented as a function of time according to each of their components in the satellite reference frame.

For example, if the X component of the Sun LOS is equal to 1, the satellite’s +X face is facing the Sun, the normal to the face coincides with the Sun LOS vector, and this would be the case for the −X face if the Sun LOS X component was −1. In the following studies, only data from the UVSQ-SAT satellite in orbit are used to test the TRIAD and MEKF methods.

4.1. Results with TRIAD Method

The TRIAD method (Section 3.1) provides the CubeSat attitude matrix. The Sun LOS in the body frame is computed from the model and the attitude matrix. The nadir direction in the body frame is obtained from the transformation of the nadir vector in the orbital frame (defined as the third axis of the reference frame basis). Those two vectors are represented in Figure 8.

Figure 8.

Figure 8

First lights of the Sun LOS (a) and nadir (b) components in the satellite body frame based on TRIAD method on 2 March 2021 (representative period in the case of measurements at 30 s intervals almost continuously, with eclipse phase in gray).

4.2. Results with MEKF Method

The second method, described in Section 3.2, should correct the signals from noise and gyrometer biases. The Sun LOS and nadir directions are computed in the body reference frame from the attitude matrix. Their components in this frame are shown in Figure 9.

Figure 9.

Figure 9

First lights of the Sun LOS (a) and nadir (b) components in the satellite body frame based on MEKF on 2 March 2021 (representative period in the case of measurements at 30 s intervals almost continuously with eclipse phase in gray).

4.3. Discussion and Perspectives

The TRIAD and MEKF methods were applied to in-orbit data. The objective is to compare the two methods. To visualize the improvement expected from the MEKF method, it can be wise to superpose the results from the different methods in Figure 10. Three indicators to compare the methods are described in this part. The first indicator is based on the variations of the attitude itself while the second one is derived from the measurements of a sensor that was not used as an input by the two methods. The last indicator is the uncertainty of each method. The satellite attitude computed with the Kalman filter is continuous, which corresponds to a realistic case in orbit. Discontinuities mostly come from noise in the measurement process. It is therefore relevant to quantify the fast changes in attitude. This can be done studying the gradient of the Sun LOS or nadir components. Studying the standard deviation of the gradient is representative of the short variations that could be due to the attitude determination error. The average of the standard deviations of the Sun LOS gradients is equal to 5.17 × 103s1 for the TRIAD method compared to 4.1 × 103s1 for the MEKF method (UVSQ-SAT data on the 2 and 3 February 2021). Therefore, the MEKF method seems to represent the satellite attitude variations better based on the previous indicator as it reduces discontinuities thanks to its smoothing asset.

Figure 10.

Figure 10

First lights of the Sun LOS and nadir coordinates in the satellite body frame based on MEKF and TRIAD on 2 March 2021 (representative period in the case of measurements at 30 s intervals almost continuously with eclipse phase in gray).

A more accurate analysis can be established based on the measurements of a sensor not used in the attitude determination process. UV sensors (UVSs) with a narrow field of view (FOV) are used to compare the results based on the two methods. Those sensors are primarily sensitive to solar radiation. Therefore, the sensors should detect when the Sun appears in the FOV. It is therefore a great indicator to evaluate the precision and accuracy of both methods. This allows us to determine which method is the most adequate to find the orientation of the satellite (in the majority of cases). It is important to note that this study has limitations as it is realized only in the phases of sunlight and in some configurations. The reference cases are related to direct solar observations.

The accuracy and precision values are computed for each method. The accuracy value is defined in Equation (41a) as the proximity of a measured value to a real value. The value of precision in Equation (41b) refers to the proximity of two or more measurements to each other. This allows us to monitor the presence of a bias in the attitude determination.

Accuracy=TP+TNTP+FP+FN+TN (41a)
Precision=TPTP+FP (41b)

where TP, FN, FP, and TN are defined in Table 2.

Table 2.

Definition of the true positive, false negative, false positive, and true negative.

Definition Attitude Determination
Facing the Sun Not facing the Sun
UVS Facing the Sun True Positive (TP) False Negative (FN)
Not Facing the Sun False Positive (FP) True Negative (TN)

These values are calculated in the case of the TRIAD method in Figure 11 and then for MEKF in Figure 12.

Figure 11.

Figure 11

Precision (a) and accuracy (b) of the TRIAD method based on the UVS indicator.

Figure 12.

Figure 12

Precision (a) and accuracy (b) of the MEKF method based on the UVS indicator.

The indicators are plotted according to different FOV. Indeed, the FOV of the instrument can be different from the theoretical FOV due to uncertainties of measurements and misalignments. This is the reason why we choose to calculate the accuracy and precision for different values of angle threshold (theoretical FOV). When the angle between the normal to the sensor and the Sun LOS determined by each method is below a certain threshold (FOV), it is verified that the UVS sensor receives a signal corresponding to the incident solar flux. This is an indicator that the considered face is facing the Sun. Using large numbers of values corresponding to large numbers of different configurations helps us to quantify the ability of the methods to recover the Sun LOS in the body frame.

The methods can be compared by computing the difference between the indicators for MEKF and TRIAD. The results are presented in Figure 13. The MEKF method allows us to increase the precision by about 20% and the accuracy by a few percent.

Figure 13.

Figure 13

Difference between the precision (a) and accuracy (b) of the MEKF and the TRIAD methods based on the UVS indicator (positive means that MEKF has better performance compared to TRIAD).

The last indicator used to compare the methods is the absolute uncertainty of the two methods developed above. To do this, we choose to use the Monte Carlo method to perform the propagation of uncertainties. The uncertainties of the instruments are quantified from the specifications and empirically. They are represented as a Gaussian probability density function. We then seek to quantify the uncertainty propagated on the angle to the Sun and the angle to the nadir as the flux computation depends on those parameters. The uncertainty is estimated in two different cases. The plot at the top of Figure 14 shows the evolution of the uncertainty for TRIAD and MEKF methods in the case of the data received almost continuously over the whole selected period. The sampling rate is thus almost constant and regular. This represents the ideal case where all the data are retrieved, and the only limitation is the sampling rate. The plot at the bottom of Figure 14 represents the same evolution for a longer period equivalent to more than 22 orbits including phases with missing data. It is thus possible to obtain the restitution of attitude with a 3° uncertainty (at 1 σ) in sunlight for both methods. In eclipse, for long periods of time (including missing data), the uncertainty reaches 14° for TRIAD while it converges to about 10° for the MEKF method. In general, we see an improvement of about 4°. Eclipse phases appear in gray and sunlight in white. The determination of the uncertainty in time is pertinent as the attitude will be time-dependent for the MEKF method. This is apparent in Figure 14 as the uncertainty for the MEKF method converges with time. We also see that sunlight and eclipse phases have totally different results in terms of uncertainty as the data provided come from different instruments.

Figure 14.

Figure 14

Uncertainties estimated from the Monte Carlo method for TRIAD and MEKF methods for continuous sampling on 2 March 2021 (top) and from 11–13 March 2021 (bottom) with eclipse phases in gray.

The accuracy of the MEKF method can be compared to validation with in-orbit data from [3]. It appears that the uncertainty is much lower for the Radio Aurora Explorer satellites with a 1 Hz sampling rate (below 1°). A 1 Hz sampling rate was not enough to capture the spacecraft motion, and a slowing down of the satellite rotation was therefore undertaken and allowed to improve the results. In our case, the sampling period of 30 s does not allow us to reach such accuracy. This is nevertheless important to note as feedback.

It is possible to estimate the uncertainties on the incident flux from the uncertainties on the angles to the source. Indeed, fluxes are corrected using the cosine of the angle for the Sun and the view factor in the case of terrestrial flux. Those uncertainties are based only on the attitude determination uncertainties. Therefore, for the solar flux, the uncertainty is estimated at 4% (1σ) for both methods. For the eclipse phase and terrestrial flux, the TRIAD method allows us to compute the flux with around 19% uncertainty, although MEKF allows for around 13% accuracy (1σ). The MEKF method brings improvements. but it also presents limitations. The algorithm loads the data on-ground from in-orbit data to compute the CubeSat attitude. However, the method relies on the need to predict the state vector at the next iteration from the previous measurements.

Therefore, it is important that those two steps are not too far in time given the chosen sampling rate. Rarely, but not impossibly, the inputs data can be missing due to a single-event upset (SEU) or missing values in the communication process. An example of this appears in Figure 15.

Figure 15.

Figure 15

Nadir Z component in the satellite frame based on the TRIAD and MEKF methods—missing values are delimited with hatches for a 10 min duration on 3 February 2021.

After the missing values, the first estimations of the nadir component from the MEKF method seem to be very different from the TRIAD estimations. Data gaps cause the poor prediction of the next iteration. This issue can be solved by implementing the algorithm on-board the satellite to avoid missing values due to communication issues. To do so, the computations should be executed on the on-board computer. Computational resources can be limited in-orbit. Therefore, an optimized algorithm was developed to reduce the required computations and is described in [15].

This section has presented the results of the methods. The advantages and limitations can be summarized as follows. The use of infrared sensors instead of photodiodes in an eclipse allows us to greatly reduce the measurement uncertainty. This is still recent and rarely developed in the literature (Table 1, such as in [12] or [19]), but its use could be validated in orbit. Moreover, the use of the Kalman filter allowed us to increase the accuracy of the attitude restitution and is relatively computationally efficient compared to the Unscented Kalman Filter presented in [19]. However, certain limitations are present due to difficulties of a making predictions due to a lack of data.

5. Conclusions

UVSQ-SAT CubeSat aims to validate innovative technologies in-orbit for a future constellation to study the Earth’s energy imbalance. UVSQ-SAT has been in orbit since 24 January 2021. To improve the UVSQ-SAT’s reflected solar radiation and outgoing longwave radiation measurements at the top of the atmosphere, the UVSQ-SAT’s attitude must be accurately known. Two different methods were implemented to determine the UVSQ-SAT CubeSat’s attitude, and they are based on real data from space observations.

The first method developed is based on the TRIAD algorithm. The accuracy of the UVSQ-SAT attitude knowledge obtained with the TRIAD method is close to ±3° (at one σ) in sunlight. During eclipse periods, the accuracy of the UVSQ-SAT attitude knowledge is ±14° (at one σ). In this observation phase, accurate knowledge of the CubeSat attitude is more difficult to obtain. This mode of operation with other sensors (Earth radiative sensors instead of solar visible photodiodes) brings limits. Moreover, the TRIAD method does not correct all measurement noises.

The MEKF method allows us to estimate and correct instrument noise. It performs the real-time calibration of the UVSQ-SAT gyrometer. The MEKF method computes the UVSQ-SAT attitude knowledge with an accuracy similar to TRIAD in sunlight, but with an accuracy of ±10° during eclipse periods (at one σ). There are limitations to the MEKF method, such as the lack of continuous data. This is a limiting factor since it leads to large divergence errors. The prediction becomes better when the time between two measurements is short. Then, the linearization becomes more realistic. Reducing the time-step could be beneficial for future CubeSats, and ground-based tests in near-space conditions would be recommended to optimize the various parameters.

The methods presented on this manuscript are based on direct measurements (TRIAD) or Kalman filters (MEKF). Another approach would be to use neural networks to determine the UVSQ-SAT satellite’s attitude as described in [31]. The neural network will be implemented and trained in-orbit in sunlight to improve the attitude determination accuracy during eclipse periods. The training will be based on the previously described methods, and the performance of the new method will be evaluated to assess the ability of the method to be implemented for the future satellites of the constellation.

Acknowledgments

The authors acknowledge support from the Centre National de la Recherche Scientifique (CNRS, France), the Centre National d’Études Spatiales (CNES, France), and Office National d’Études et de Recherches Aérospatiales (ONERA, France).

Author Contributions

Conceptualization, A.F., C.D., T.B., M.M.; methodology, A.F., C.D., T.B. and M.M.; software, A.F., C.D.; validation, C.D.; resources, M.M.; writing—original draft preparation, A.F., C.D., T.B., M.M.; writing—review and editing, A.F., C.D., M.M., A.M., A.S., P.K. and T.B.; visualization, A.F., C.D., M.M.; supervision, M.M.; project administration, M.M.; funding acquisition, M.M. All authors have read and agreed to the published version of the manuscript.

Funding

This research was mainly funded by Centre National de la Recherche Scientifique (CNRS, France), UVSQ (Université de Versailles Saint-Quentin-en-Yvelines, France), and Agence Nationale de La Recherche (ANR, France). This work was supported by the Programme National Soleil Terre (PNST) of CNRS/INSU (France) co-funded by CNES and Commissariat à l’énergie atomique (CEA, France).

Institutional Review Board Statement

Not applicable.

Informed Consent Statement

Not applicable.

Data Availability Statement

Not applicable.

Conflicts of Interest

The authors declare no conflict of interest.

Footnotes

Publisher’s Note: MDPI stays neutral with regard to jurisdictional claims in published maps and institutional affiliations.

References

  • 1.Meftah M., Damé L., Keckhut P., Bekki S., Sarkissian A., Hauchecorne A., Bertran E., Carta J.P., Rogers D., Abbaki S., et al. UVSQ-SAT, a pathfinder cubesat mission for observing essential climate variables. Remote Sens. 2020;12:92. doi: 10.3390/rs12010092. [DOI] [Google Scholar]
  • 2.Meftah M., Boutéraon T., Dufour C., Hauchecorne A., Keckhut P., Finance A., Bekki S., Abbaki S., Bertran E., Damé L., et al. The UVSQ-SAT/INSPIRESat-5 CubeSat Mission: First In-Orbit Measurements of the Earth’s Outgoing Radiation. Remote Sens. 2021;13:1449. doi: 10.3390/rs13081449. [DOI] [Google Scholar]
  • 3.Springmann J.C., Cutler J.W. On-orbit Calibration of Photodiodes for Attitude Determination. J. Guid. Control. Dyn. 2014;37:1808–1823. doi: 10.2514/1.G000175. [DOI] [Google Scholar]
  • 4.Psiaki M.L., Martel F., Pal P.K. Three-axis attitude determination via Kalman filtering of magnetometer data. J. Guid. Control. Dyn. 1990;13:506–514. doi: 10.2514/3.25364. [DOI] [Google Scholar]
  • 5.Hashmall J.A., Radomski M., Sedlak J. On-orbit calibration of satellite gyroscopes; Proceedings of the Astrodynamics Specialist Conference; Minneapolis, MN, USA. 13–16 August 2000; pp. 339–349. [DOI] [Google Scholar]
  • 6.Pittelkau M.E. Kalman Filtering for Spacecraft System Alignment Calibration. J. Guid. Control. Dyn. 2001;24:1187–1195. doi: 10.2514/2.4834. [DOI] [Google Scholar]
  • 7.Theil S., Appel P., Schleicher A. Low Cost, Good Accuracy—Attitude Determination Using Magnetometer and Simple Sun Sensor. 2003. [(accessed on 20 July 2021)]. Available online: https://digitalcommons.usu.edu/smallsat/2003/All2003/81/
  • 8.Bhanderi D., Bak T. Modeling Earth Albedo for Satellites in Earth Orbit; Proceedings of the AIAA Guidance, Navigation, and Control Conference and Exhibit; San Francisco, CA, USA. 15–18 August 2005; [DOI] [Google Scholar]
  • 9.Ma G.-F., Jiang X.-Y. Unscented Kalman Filter for Spacecraft Attitude Estimation and Calibration Using Magnetometer Measurements; Proceedings of the 2005 International Conference on Machine Learning and Cybernetics; Guangzhou, China. 18–21 August 2005; pp. 506–511. [DOI] [Google Scholar]
  • 10.Côté J., De Lafontaine J. AIAA Guidance, Navigation and Control Conference and Exhibit. AIAA; Reston, VA, USA: 2008. Magnetic-only orbit and attitude estimation using the Square-Root Unscented Kalman Filter: Application to the PROBA-2 spacecraft; pp. 1–24. [DOI] [Google Scholar]
  • 11.Filipski M.N., Varatharajoo R. Evaluation of a spacecraft attitude and rate estimation algorithm. Aircr. Eng. Aerosp. Technol. 2010;82:184–193. doi: 10.1108/00022661011075919. [DOI] [Google Scholar]
  • 12.Springmann J.C., Sloboda A.J., Klesh A.T., Bennett M.W., Cutler J.W. The attitude determination system of the RAX satellite. Acta Astronaut. 2012;75:120–135. doi: 10.1016/j.actaastro.2012.02.001. [DOI] [Google Scholar]
  • 13.Searcy J.D., Pernicka H.J. Magnetometer-Only Attitude Determination Using Novel Two-Step Kalman Filter Approach. J. Guid. Control. Dyn. 2012;35:1693–1701. doi: 10.2514/1.57344. [DOI] [Google Scholar]
  • 14.Zeng Z., Zhang S., Xing Y., Cao X. Robust Adaptive Filter for Small Satellite Attitude Estimation Based on Magnetometer and Gyro. Abstr. Appl. Anal. 2014;2014:159149. doi: 10.1155/2014/159149. [DOI] [Google Scholar]
  • 15.Pham M.D., Low K.S., Goh S.T., Chen S. Gain-scheduled extended Kalman filter for nanosatellite attitude determination system. IEEE Trans. Aerosp. Electron. Syst. 2015;51:1017–1028. doi: 10.1109/TAES.2014.130204. [DOI] [Google Scholar]
  • 16.Kiani M., Pourtakdoust S.H., Sheikhy A.A. Consistent calibration of magnetometers for nonlinear attitude determination. Meas. J. Int. Meas. Confed. 2015;73:180–190. doi: 10.1016/j.measurement.2015.05.005. [DOI] [Google Scholar]
  • 17.Koizumi S., Kikuya Y., Sasaki K., Masuda Y., Iwasaki Y., Watanabe K. AIAA/USU Conference on Small Satellites. AIAA; Reston, VA, USA: 2018. Development of Attitude Sensor using Deep Learning; pp. 1–8. [Google Scholar]
  • 18.Labibian A., Pourtakdoust S.H., Alikhani A., Fourati H. Development of a radiation based heat model for satellite attitude determination. Aerosp. Sci. Technol. 2018;82–83:479–486. doi: 10.1016/j.ast.2018.09.031. [DOI] [Google Scholar]
  • 19.Baroni L. Attitude determination by unscented Kalman filter and solar panels as sun sensor. Eur. Phys. J. Spec. Top. 2020;229:1501–1506. doi: 10.1140/epjst/e2020-900158-2. [DOI] [Google Scholar]
  • 20.Kapás K., Bozóki T., Dálya G., Takátsy J., Mészáros L., Pál A. Attitude Determination for Nano-Satellites—I. Spherical Projections for Large Field of View Infrasensors. Exp. Astron. 2021;51:1–13. doi: 10.1007/s10686-021-09730-y. [DOI] [Google Scholar]
  • 21.Mimasu Y., Narumi T., Van der Ha J. Attitude Determination by Magnetometer and Gyros During Eclipse. AIAA; Reston, VA, USA: 2008. [DOI] [Google Scholar]
  • 22.Alken P., Thébault E., Beggan C.D., Amit H., Aubert J., Baerenzung J., Bondar T.N., Brown W.J., Califf S., Chambodut A., et al. International Geomagnetic Reference Field: The thirteenth generation. Earth Planets Space. 2021;73:49. doi: 10.1186/s40623-020-01288-x. [DOI] [Google Scholar]
  • 23.Black H.D. A passive system for determining the attitude of a satellite. AIAA J. 1964;2:1350–1351. doi: 10.2514/3.2555. [DOI] [Google Scholar]
  • 24.Markley F.L., Mortari D. How to estimate attitude from vector observations. Adv. Astronaut. Sci. 2000;103:1979–1996. [Google Scholar]
  • 25.Bar-Itzhack I.Y., Harman R.R. Optimized TRIAD Algorithm for Attitude Determination. J. Guid. Control. Dyn. 1997;20:208–211. doi: 10.2514/2.4025. [DOI] [Google Scholar]
  • 26.Bar-itzhack I.Y., Meyer J. On the Convergence of Iterative Orthogonalization Processes. IEEE Trans. Aerosp. Electron. Syst. 1976;AES-12:146–151. doi: 10.1109/TAES.1976.308289. [DOI] [Google Scholar]
  • 27.Kalman R.E. A New Approach to Linear Filtering and Prediction Problems. Trans. ASME-Basic Eng. 1960;82:35–45. doi: 10.1115/1.3662552. [DOI] [Google Scholar]
  • 28.Kalman R.E., Bucy R.S. New Results in Linear Filtering and Prediction Theory. J. Basic Eng. 1961;83:95–108. doi: 10.1115/1.3658902. [DOI] [Google Scholar]
  • 29.Markley F.L., Crassidis J.L. Fundamentals of Spacecraft Attitude Determination and Control. Springer; New York, NY, USA: 2014. Static Attitude Determination Methods; pp. 183–233. [DOI] [Google Scholar]
  • 30.Lefferts E.J., Markley F.L., Shuster M.D. Kalman Filtering for Spacecraft Attitude Estimation. J. Guid. Control. Dyn. 1982;5:417–429. doi: 10.2514/3.56190. [DOI] [Google Scholar]
  • 31.Finance A., Meftah M., Dufour C., Boutéraon T., Bekki S., Hauchecorne A., Keckhut P., Sarkissian A., Damé L., Mangin A. A New Method Based on a Multilayer Perceptron Network to Determine In-Orbit Satellite Attitude for Spacecrafts without active ADCS like UVSQ-SAT. Remote Sens. 2021;13:1185. doi: 10.3390/rs13061185. [DOI] [Google Scholar]

Associated Data

This section collects any data citations, data availability statements, or supplementary materials included in this article.

Data Availability Statement

Not applicable.


Articles from Sensors (Basel, Switzerland) are provided here courtesy of Multidisciplinary Digital Publishing Institute (MDPI)

RESOURCES