1. Introduction
Mission operations often require the capability to orient the spacecraft in a specific direction. To perform these maneuvers, an adequately accurate knowledge of the spacecraft orientation in space, namely its attitude, is required, and this is the goal of attitude determination. The results from this process are input to attitude control, which produces, through the actuators, an adequate control torque driving the spacecraft to the desired attitude.
The problem of attitude determination has been extensively studied since the outset of space exploration, and consists of the determination of the rotation matrix 
, which transforms any vector 
, whose coordinates are expressed in a reference frame 
 rotating rigidly with the spacecraft, to the corresponding vector 
, expressed in a reference coordinate system 
 [
1]. Typically, the problem is solved using the Tri-axial Attitude Determination (TRIAD) algorithm which requires the knowledge of at least two couples of vectors in both 
 and 
 [
2]. Similar methods, representing solutions to Wahba’s problem [
3], have been widely applied and include the q-method by Davenport [
1,
4], Schuster’s QUaternion ESTimator (QUEST) algorithm [
5,
6] and the optimized TRIAD by Bar-Itzhack and Harman [
7]. Other approaches produce attitude determination by direct quaternion estimation [
8,
9], and can be significantly faster than the other algorithms outlined but can show singularities, which occur when the attitude rotation axis lays on the plane of the unit vectors on which the estimation is based, as detail by Markley [
10].
The above-mentioned algorithms require two vector measurements in two-body frames 
 and 
. In fact, the measurements in 
 can be replaced by predictions of the vector behavior in time and space; for instance, the International Geomagnetic Reference Field (IGRF) model can be used to estimate the values of the Geomagnetic field vector at any orbital coordinates of the spacecraft [
11]. These models can be rather complex and accurate, and their selection is a crucial part of the design process. A similar approach is not effective for vectors in 
 because their prediction requires knowledge of the spacecraft attitude, which is instead the unknown of the attitude determination problem. As a result, on-board sensors must be used for vector measurements in 
, and their characteristics strongly determine the accuracy of the attitude determination algorithm. The use of star trackers can produce attitude determination with accuracy less than 0.01°. Nevertheless, these components are relatively expensive, power and memory consuming if compared to MEMS (Micro-Electro-Mechanical Systems) sensors, such as magnetometers, gyroscopes, and sun sensors, which, therefore, represent an attracting alternative for low-cost missions. MEMS gyroscopes are accurate angular rate sensors; nevertheless, because of technological limitations, they usually have structure defects which produce high drift and require compensation, thus opening to alternative methods of angular rate determination [
12].
Gyroless attitude determination methods are of interest as backup solutions for small satellite missions that do not require high pointing accuracy for basic operations [
13]. Such a solution can be effective when the above-mentioned measurement drift increases above a threshold level, in case of failure of the sensor and in the presence of an error in the algorithm which produces the interpretation of the signal. Several methods have been proposed based on the use of a three-axis magnetometer together either with other low-cost sensors or solar panels [
14,
15,
16,
17] or on their own.
Magnetometer-only attitude determination is a challenging task, mainly because the measurements from a three-axis magnetometer can provide information on only two axes of the spacecraft attitude. To resolve all three axes, either some constraints on the attitude motion or a filtering process is required. A first solution was proposed by Natanson et al. [
18], whose DADMOD algorithm provided good results in the post-processing. A further implementation of the algorithm using DADMOD to initialize a Real-Time Sequential Filter (RTSF) extended it to real-time applications [
19,
20], with an accuracy of 2° on attitude and 0.01°/s on angular rates. 
The most popular methods for three-axis magnetometer-only attitude determination are based on the Extended Kalman Filter (EKF) and can reach an accuracy below 5° on attitude and 0.01°/s on the angular rates [
21,
22,
23]. Other solutions include the Unscented Kalman Filter (UKF) algorithm by Ma and Jiang [
24], or the two-step EKF algorithm proposed by Searcy and Pernicka [
25], which achieves accuracies of less than 1°, but is effective only if the angular rates along at least one axis exceeds 0.1°/s. 
Despite their rather high accuracy, the mentioned algorithms either require sophisticate models for vector estimation, are effective only under some specific attitude control, or include complex vector and matrix operations. The latter can be rather complex to be implemented as the Field Programmable Gate Array (FPGA) core of an On-Board Computer (OBC). The use of FPGA-based OBC in small satellites, especially CubeSats, has grown in the last years. This trend is motivated by FPGA hardware and software flexibility, which allows on-ground and in-orbit risk-free reconfiguration, and by their capability to perform processes in parallel.
In this work, we propose a simple attitude determination strategy suitable to be implemented on an FPGA-based OBC. The solution does not require any Kalman Filter and is based only on the measurements of a three-axis magnetometer and the Geomagnetic field data stored on the OBC memory. Angular rates are determined independently from attitude, based on a method proposed previously by the same authors [
26]. The Attitude matrix is then estimated by developing a form of the unsymmetrical TRIAD. All the complex matrix operations are arranged in the form of a Faddeev algorithm [
27], which can be implemented on FPGA using one single compact systolic array architecture [
28]. The use of the same architecture for all the complex matrix operations leads to an increase in the system and algorithm efficiency. The performance and robustness of the attitude determination strategy are verified by means of numerical analyses in MATLAB Simulink, showing an accuracy of 0.2°/s for angular rates and below 10° for the attitude. The results show how process delay, characterizing the algorithm, can be minimal when implemented on real hardware, as verified by Hardware-in-the-Loop (HiL) simulation.
The manuscript is organized as follows. In 
Section 2, the dynamical framework and the models used for the analysis are introduced. The design and implementation of the attitude determination algorithm is provided in 
Section 3, and its performance and robustness are verified by numerical analyses in 
Section 4. The analyses are performed simulating the detumbling and pointing of the satellite after deployment, assuming unknown initial conditions randomly selected. In 
Section 5 the algorithm is implemented on the FPGA core of a CubeSat OBC, and tested by HiL simulation as a preliminary verification of its suitability for implementation for real missions.
  2. Dynamical Framework 
The attitude determination strategy presented in this work is targeted to spacecraft orbiting in circular Low Earth Orbits (LEO) and does not require any a-priori knowledge of the Right Ascension of the Ascending Node (RAAN) , orbit phase angle , attitude and angular rates.
The satellite is modeled as a rigid body, and its attitude is described using Euler angles 
 and angular rates 
, representing the angular velocity components of the reference frame 
, attached to the satellite, with respect to the inertial reference frame 
, here selected as the Geo-Centric Inertial (GCI) frame. Assuming 
 to be coincident with the principal axes of inertia of the satellite, then attitude dynamics can be expressed by the following set of equations [
1]
      
      where 
 and 
 are, respectively, the moment of inertia and the external torque in the 
i-th direction of 
. It can be noticed that the third equation in system (1) shows a singularity for 
 and this can be avoided using quaternions instead of Euler angles to represent the attitude [
1]. The attitude dynamics using the quaternion representation can be expressed by the following system:
For the case examined here, the control torque is produced by three magnetorquers each one orthogonal to an axis of 
. Indicating with 
 the magnetic dipole moment produced by the three magnetorquers, the control torque is given by:
      where 
 is the Geomagnetic field vector in 
. 
Considering the worst-case scenario of a spacecraft deployed with unknown attitude and angular rates, equipped with only a three-axis magnetometer as an attitude sensor, then the only control actions that can be performed are stabilization and pointing with respect to the Geomagnetic field. A case of interest is that in which the satellite is stabilized to pure-spin around the 
i-th axis, with a desired angular rate 
 and, contemporarily, the 
i-th axis is redirected towards the Geomagnetic field vector. A suitable control law, leading to the mentioned result for 
, is given by the following equations:
      where the 
hat “ 
” indicates the direction of the vector 
, , 
kp is the gain for the pointing control, and 
ki are the gains for the stabilization law. It can be noticed that Equation (4a) is similar to the nadir-pointing control in [
29], in which the nadir direction in Equation (4c) is replaced by 
 and the damping term, originally given by the B-dot, has been changed to Equation (4b). Equation (4b) corresponds to a rearrangement of the Y-Thompson spin, where the spin axis is 
 instead of 
 [
30]. In this arrangement, a magnetic torque along 
 produces damping, which is inversely proportional to the angular displacement between 
 and the magnetic field vector, in virtue of 
. Differently, the magnetic torques along 
 and 
 decrease as 
 reaches the desired value 
 allowing non-zero spin stabilization. It is worth noting that, once solved the attitude determination problem, the same control law Equations (4a)–(4c) can be used to point towards the desired direction 
, by simply replacing 
 with 
 in Equation (4c). The selection of the control gain represents a rather complex issue for both the control laws Equations (4b) and (4c). In fact, even though higher gains correspond to higher torques, these are typically limited by the threshold value of the magnetic dipole moments, which can be generated by the attitude control system. Some criteria for an optimal selection of these gains, in the presence of different constraints, have been developed [
31,
32,
33].
In 
Section 4 and 
Section 5, numerical and HiL simulations are performed to verify the performance and robustness of the attitude determination algorithm. 
  3. Attitude Determination Algorithm 
The design and implementation of the proposed magnetometer-only attitude determination algorithm are hereafter discussed. The spacecraft attitude and angular rates are determined in two different steps, thus limiting the size of the vectors and matrixes computed through the process to 3 × 1 and 3 × 3. All those vector and matrix operations that can be rearranged into the following form, a matrix equation of size 3:
      can be implemented on FPGA by means of the Faddeev algorithm [
34], using a single systolic array architecture. It means that the FPGA area dedicated to the systolic array can be used to calculate the results for any vector or matrix operation expressed in the form of Equation (5), taking advantage of parallel computing and reducing the usage on FPGA, thus increasing the efficiency of the algorithm [
35,
36,
37]. This concept is now applied to implement the attitude determination algorithm.
The three-axis magnetometer operates at a fixed sampling frequency 
, producing the measurement 
. The time derivatives of 
 can be approximated as 
 and, as proved in a previous work by the authors [
26], the angular rates can be estimated by processing with a second-order low-pass filter the results from the following equation:
It is worth highlighting that Equation (6) requires three consecutive samplings 
; therefore, it produces an estimation of the angular rates with a delay equal to three times the sampling time 
. The effect of this delay will be examined in 
Section 4 and 
Section 5. 
Equation (6) can be rearranged in a form suitable for systolic array implementation, which consists of the determination of the values of matrixes 
, 
, 
 and 
. A solution is given by the following set:
      where 
 and 
 indicate the 3 × 3 identities and the 3 × 3 zero matrixes. If the mass distribution of the spacecraft is not spherical, such as in CubeSats, Equation (6) is affected by an error, that resembles a high-frequency noise [
26], associated with the nonlinear terms 
. This can be removed using a second-order Butterworth low-pass filter [
35,
36], characterized by the following transfer function:
      where 
 is the filter gain and 
 is the cut-off frequency.
The estimated values of the angular rates and a model of the Geomagnetic field are now used to implement the unsymmetrical TRIAD and estimate the attitude matrix 
. As discussed in 
Section 1, the TRIAD requires knowledge of at least two vectors in 
 and the corresponding values in 
. Each vector 
 can be converted to the corresponding 
 by applying the transformation 
, where the expression for the rotation matrix 
 is given below:
According to Equation (9),  depends on the Euler angles and; therefore, it changes in time with the attitude of the spacecraft. The value of  is here estimated based on the values of  which are provided at fixed sampling rates. The value of the attitude matrix is estimated corresponding to each sample k and indicated as . The matrix is assumed constant in the interval between two consecutive samplings. 
Based on these considerations, the Geomagnetic field vector and its derivative in the two reference frames can be related by the following equations:
If the inclination of the orbital plane 
 and the altitude 
 of the spacecraft are known, the IGRF model can be used to calculate the Geomagnetic field data to be stored on the OBC [
11]. These data are selected and arranged into tables whose first entry is the true anomaly (ϑ) of the satellite (i.e., 
). When the satellite passes over the ground station, the value of ϑ at the passage is sent to the satellite and stored by the FPGA, which then propagates it in time. The value of ϑ triggers the reading of the table, producing the vector 
. The derivative in time of 
 can then be computed as 
.
Equation (6) could be used to solve the determination problem; nevertheless, a more accurate expression was developed based on the following result in [
26]: 
The vector product 
 in Equation (10b) can be rearranged as follows:
      where α is the angle between the vectors and 
 is the direction orthogonal to the plane, which they define. Noting that 
 is the projection of 
 orthogonal to 
, then 
 and considering Equation (11) it follows that:
Using the triple vector product properties 
, then Equation (10b) can be written as:
For the sake of clearness, the following compact notation is introduced: 
Based on Equation (14) the attitude matrix at time 
 can be estimated as follows:
Equation (15) is equivalent to the unsymmetrical form of the TRIAD algorithm [
10], in which the relative weight of the measurement 
 is higher than that of 
 in the estimation of 
. This form was preferred because the accuracy on 
, measured by on-board sensors, is reasonably higher than that of 
, estimated during the process. It can be noticed that the matrix 
 has a unit norm, and its transpose corresponds to the inverse. Therefore, Equation (15) can be set in the form Equation (6) of the Faddeev algorithm and solved through the systolic array architecture: 
  4. Performance and Robustness Analysis
A preliminary analysis of the attitude determination algorithm is performed by numerical simulation on two Test Cases (TC), TC1 and TC2, which differ by the angular rates at the deployment. The simulations are performed considering the properties of the 3U CubeSat Tigrisat, launched by the School of Aerospace Engineering in 2014, with volume 
 and the total mass 
. The dynamic attitude equations are integrated using Matlab Simulink 
ode8 fixed-step solver, considering a time step of 1 s and for a total time corresponding to three orbital periods. For each step of the integration, the Geomagnetic field vector 
 is calculated using the IGRF model and converted to 
 as 
 [
11].
The inertial properties of the satellite, the orbital elements and the filter and control parameters common to the two test cases are listed in 
Table 1, where the total time of the simulation corresponds to three orbital periods. The angular rates at the deployment for the two test cases are shown in 
Table 2. 
First, TC1 is examined. To investigate the accuracy of the attitude determination algorithm, the Mean Squared Error (MSE) between the actual 
 and the estimated 
 is calculated. The actual 
 is calculated based on the Euler angles calculated during the numerical integration by means of Equation (9). 
Figure 1 shows that the MSE assumes a final value of 1.172 × 10
−2 end enters the 
 error band (with respect to the final value) in 16680 s. The figure also reports the MSE calculated for 
 considering a delay of 5 (dashed line) and 6 (dotted line) seconds. These are calculated comparing, for each sample, the actual 
 with the same matrix at, respectively, the sample k-5 and k-6. The MSE for the 5 s and 6 s “delayed” 
 reaches the final value of, respectively, 1.065 × 10
−2 and 1.533 × 10
−2, 10% lower and 23% higher than the MSE for TC1. This result indicates that the process suffers a delay, which is in the range 5–6 s, thus five to six times higher than the simulation time step. Such a process delay arises because both the estimation processes require the same systolic array architecture, and the attitude matrix is calculated after the angular rates, which require three consecutive samples (
 s), and filtering to produce the result. The delay is considerably reduced when the algorithm is implemented on real hardware with higher operating and sampling frequency.
For the sake of clarity, the accuracy of the attitude determination is also evaluated by comparing the “actual” Euler angles, resulting from the ODE8 solver to the estimated ones, computed from 
. The difference between the estimated and the actual (from the integration) Euler angles is shown in 
Figure 2.
In particular, a highlight of 
Figure 2 from time 6000 s to the end of the simulation is reported in 
Figure 3, showing that the estimated 
 and 
 enter the 
 error band but the same is not verified for 
ψ. The Root Mean Square (RMS) values of the estimation errors for three different time windows are reported in 
Table 3.
Figure 4 and 
Figure 5 show the comparison and the estimation error between the actual angular rates and the estimated ones.
 It can be noticed that the angular rate 
 reaches the target value of 2.5°, while 
 and 
 approach zero. The angular rates enter the 
°/s error band in the times and with the RMS error indicated in 
Table 4.
Simulations results indicate that the control law Equations (4a)–(4c) is effective in producing the desired attitude, with the x-axis aligning to the Geomagnetic field vector, as shown in 
Figure 6.
The same analysis is repeated for the TC2, in which the satellite is supposed to be deployed at lower angular rates. The MSE between the actual 
 and the estimated 
 are plotted in 
Figure 7. In TC2, the MSE enters the ±10% error band with respect to the final value of 1.158 × 10
−2 in 12,111 s. The MSE for 5 s and 6 s delays are 1.071 × 10
−2 and 1.539 × 10
−2, respectively, the 8% lower and the 25% higher than the final MSE for TC2. Similar to TC1, this result indicates which the delay process is in the interval 5–6 s.
The estimation errors on the Euler angles show similar behavior in time, as reported in 
Figure 8, with 
 and 
 entering the ±10° error band in 4740 s and 5367 s, and 
 settling between 10° and 15°. The RMS values for TC2 are reported in 
Table 5.
With respect to the angular rates, the target values are reached, and the error band of 
°/s is entered for all the axes in a time shorter than that for TC1. The results are shown in 
Figure 9 and in 
Table 6, including the RMS of angular rates estimation errors after settling time.
To evaluate the robustness of the algorithm, a total of 100 Test Cases (TC) is simulated, selecting random initial conditions for the orbital parameters, initial attitude, and initial angular rates. The values are selected within the following ranges:
There are different altitudes; therefore, the orbital period of the 100 TC will be different, therefore a unique total time for the simulation is selected, and it is set equal to 18,000 s, to be comparable with TC1 and TC2. To ensure that all the simulated TC converge within the mentioned time, the control gains were set to the following values 
kp = 400, 
k1 = 10, and 
k2 = 1. The filter parameters are the same for all the TC and equal to the values reported in 
Table 1.
The MSE was calculated on 
 for all the 100 TC, and it settles to a value ranging from 1.856 × 10
−2 to 2.505 × 10
−2, proving that the algorithm is robust with respect to the uncertain initial. For a clearer evaluation of the performance, the mean value for the RMS of the attitude estimation errors over the 100 TC was calculated and are reported in 
Table 7. The results in the table are in agreement with those evaluated for TC1 and TC2, with the accuracy of attitude determination exceeding the threshold level only for ψ. Angular rates determination is verified as well, registering that all the TC enter the ±0.2°/s error band within 14,902 s. The mean value for the RMS of the angular rates estimation errors was calculated and are reported in 
Table 8.
Numerical analyses here discussed represent only a preliminary result. The final validation of the algorithm is performed by HiL simulations, discussed in the following section.
  5. Implementation of FPGA and Hardware-in-the-Loop Simulations
Once validated, the global behavior of the algorithm was implemented on an Artix-7 xc7a50t FPGA, which is a core of the OBC currently under development for STECCO (Space Traveling Egg-Controlled Catadioptric Object), the first PocketQube of the School of Aerospace Engineering. The main blocks of the algorithm are shown in 
Figure 10.
The Geomagnetic field is simulated using Matlab Simulink and sent to the FPGA for processing them. The Geomagnetic field data were processed to include the quantization error characterizing the 12-bit MEMS three-axis magnetometer and random white noise, considering a standard deviation of 2 × 10
−7 T. The same systolic array architecture is used for both angular rates and attitude estimation, using Equations (7a)–(7d) and (16a)–(16d). The second-order Butterworth low-pass filter was implemented according to [
38,
39].
When implementing an algorithm on FPGA, its mathematical formulation is converted into several logical operations, which are stored into organized structures called Look Up Tables (LUT) and executed with desired time scheduling, under the control of Flip Flops (FF) [
40]. The number of operators that can be stored in the LUT, as well as the total number of LUT and FF, is limited. Therefore, minimizing their utilization is a crucial task, and for this aim, systolic array architecture was considered [
28]. It is worth highlighting that, as mentioned before, the use of the same architecture for both attitude matrix and angular rates estimation further increases the efficiency in terms of usage. Similar considerations apply for the total available memory (RAM) and the usage of the Digital Signal Processor, leading the logical process. 
The resource utilization for the algorithm implemented on the FGPA is reported in 
Table 9. One run of the algorithm requires 53 clock cycles, 40 of which are addressed to the systolic array architecture, which, therefore, represents the most computationally demanding section. 
The HiL simulations are performed based on the same data used for TC1, reported in 
Table 1 and 
Table 2. The high working frequency of the FPGA, equal to 50 MHz, allows reducing both the delay due to the filtering process, corresponding to a few clock cycles (2 × 10
−8 s) and that related to the sampling frequency of the magnetometer, which is here increased to 
, with benefit on the accuracy of the algorithm. In the selection of the sampling frequency, the Nyquist criterion must be considered to avoid aliasing and, therefore, loss of information. In particular, according to Fonod and Gill [
33], the sampling frequency can be related to the maximum angular rate expected for the satellite as 
, a condition which is verified for TC1 and 
. The MSE for TC1 at 100 Hz sampling frequency is represented in 
Figure 11, finally showing that the impact of process delay is a major cause of the error and that this delay can be reduced to negligible values in real hardware implementation.
It can be noticed that when the algorithm converges, the MSE settles in the range from 1.056 × 10
−2 to 1.1805 × 10
−2, a value included between the MSE calculated for 
 with 5 × 10
−2 s and 6 × 10
−2 s delay, respectively equal to 1.038 × 10
−2 and 1.2455 × 10
−2. The estimation errors on the Euler angles are shown in 
Figure 12.
The results obtained from the HiL simulations match those from numerical analysis in 
Section 4, with 
, 
 and 
 entering the ±10° error band in 13,431 s, 12,655 s, and 4775 s. The RMS values of the attitude estimation error are reported in 
Table 10. 
The time behavior of the estimation errors on the angular rates is reported in 
Figure 13, showing that 
 reaches the target value of 2.5°, while 
 and 
 approach zero. The settling times and the RMS values of the estimation of the angular rates after settling are reported in 
Table 11.
  6. Discussion
After having verified the performance of the algorithm, it is worth to compare it to other magnetometer-only solutions available in the literature [
19,
20,
21,
22,
23,
24,
25]. As mentioned in the introduction, these are typically based on the use of a Kalman filter (EKF or UKF) and can provide accuracy as good as 1° and 0.01°/s in the estimation of, respectively, the Euler angles and the angular rates. By comparison with the values reported in 
Table 10 and 
Table 11, it can be noticed that the accuracy of KF based algorithms is higher than that of the solution proposed. This result indicates that further investigation should be performed to improve the accuracy of the algorithm, but the output from HiL simulations is promising. 
Nevertheless, the attitude matrix and angular rate estimation algorithm discussed here is proposed to be a backup solution to be activated in case of failure of the primary attitude determination system. Therefore, also other features, besides accuracy, should be taken into account to evaluate its suitability. In particular, two aspects are worth to be examined, which are power and area usage. The former should be limited to be compliant with realistic power limitations occurring when a backup mode is required. The latter represents a constraint for the implementation on the FPGA, as discussed in 
Section 5, and should be minimized. Using systolic array architecture represents our attempt to reduce both power and area usage. This task was achieved by designing the attitude and angular rate estimation algorithm to be implemented in the Faddeev form. 
A detailed comparison in terms of power usage between the solution proposed and the KF based algorithms available in the literature would require the implementation of these onto microprocessors, which is beyond the scope of this work. Nevertheless, an estimation of power usage can be provided from the analysis by Mohd et al. [
41], evaluating N × N matrix multiplication performance on FPGA, using a systolic array, and on two microprocessors. A comparison between the power usage by the two devices in terms of the size N of the matrix is reported in 
Table 12, considering the lowest value between the two microprocessors.
It can be noticed that the estimated power usage from the algorithm proposed, implementing 3 × 3 matrix operations, is equal to 277 mW, a value compatible with those in 
Table 12. If referring to the methods [
20,
21,
22,
23,
24,
25], the matrix size ranges from 6 × 6 to 9 × 9; therefore, their power usage can be estimated to approximately 2.7 times higher. 
Recalling that the comparative analysis presented in this section represents only a preliminary result, it indicates that the attitude matrix and angular rate estimation strategy proposed can be a suitable option when the use of FPGA based OBC is preferred and lower accuracy can be accepted for the benefit of lower power usage.
  7. Conclusions
We proposed a magnetometer-only attitude determination strategy tailored for implementation on the FPGA core of an OBC, using systolic array architecture to enhance the efficiency of the algorithm. The determination algorithm is aimed to be a backup solution in case of failure of the primary determination system.
The algorithm provides results with accuracy of /s on the angular rates and of ° on the Euler angles. The numerical analyses and HiL simulations indicate that the algorithm suffers some processing delay, introduced by the filtering process, and by the sampling frequency of the magnetometer. This delay reduces as the operating frequency of the FPGA and, especially, the sampling frequency of the magnetometer increase. Simulations performed considering a MEMS three-axis magnetometer with sampling frequency as high as 100 Hz and an FPGA running at 50 MHz, indicate that the processing delay can be reduced to 50–60 milliseconds.
Despite being compatible with several small satellite missions and applications, the algorithm proposed is less accurate than other magnetometer-only methods available in the literature. Nevertheless, its lower power usage can represent an advantage for some critical scenarios. Furthermore, the low resources required and the use of systolic array architecture allows implementing the algorithm on the OBC at minimal area usage, resulting in a suitable and versatile solution for the use in small satellite missions.