2022-09-20 13:46:42 +02:00
|
|
|
#ifndef SAFECTRL_H_
|
|
|
|
#define SAFECTRL_H_
|
|
|
|
|
2023-03-24 11:35:46 +01:00
|
|
|
#include <eive/resultClassIds.h>
|
2023-04-06 10:37:59 +02:00
|
|
|
#include <mission/acs/defs.h>
|
2023-03-24 11:35:46 +01:00
|
|
|
#include <mission/controller/acs/AcsParameters.h>
|
2022-09-20 13:46:42 +02:00
|
|
|
#include <stdio.h>
|
2022-10-20 11:07:45 +02:00
|
|
|
#include <string.h>
|
2022-09-20 13:46:42 +02:00
|
|
|
|
2022-10-20 11:07:45 +02:00
|
|
|
class SafeCtrl {
|
|
|
|
public:
|
|
|
|
SafeCtrl(AcsParameters *acsParameters_);
|
|
|
|
virtual ~SafeCtrl();
|
2022-09-20 13:46:42 +02:00
|
|
|
|
2023-11-02 16:59:09 +01:00
|
|
|
acs::ControlModeStrategy safeCtrlStrategy(const bool magFieldValid, const bool mekfValid,
|
2023-12-06 17:27:43 +01:00
|
|
|
const bool satRotRateValid, const bool sunDirValid,
|
|
|
|
const bool fusedRateTotalValid,
|
|
|
|
const uint8_t mekfEnabled, const uint8_t gyrEnabled,
|
|
|
|
const uint8_t dampingEnabled);
|
2022-09-20 13:46:42 +02:00
|
|
|
|
2023-03-24 14:51:33 +01:00
|
|
|
void safeMekf(const double *magFieldB, const double *satRotRateB, const double *sunDirModelI,
|
2023-04-14 11:37:23 +02:00
|
|
|
const double *quatBI, const double *sunDirRefB, double *magMomB,
|
|
|
|
double &errorAngle);
|
2023-03-24 14:51:33 +01:00
|
|
|
|
2023-07-19 13:24:37 +02:00
|
|
|
void safeGyr(const double *magFieldB, const double *satRotRateB, const double *sunDirB,
|
|
|
|
const double *sunDirRefB, double *magMomB, double &errorAngle);
|
2023-03-24 14:51:33 +01:00
|
|
|
|
2023-08-15 09:11:57 +02:00
|
|
|
void safeSusMgm(const double *magFieldB, const double *rotRateTotalB,
|
|
|
|
const double *rotRateParallelB, const double *rotRateOrthogonalB,
|
|
|
|
const double *sunDirB, const double *sunDirRefB, double *magMomB,
|
|
|
|
double &errorAngle);
|
2023-07-19 13:24:37 +02:00
|
|
|
|
|
|
|
void safeRateDampingGyr(const double *magFieldB, const double *satRotRateB,
|
|
|
|
const double *sunDirRefB, double *magMomB, double &errorAngle);
|
|
|
|
|
|
|
|
void safeRateDampingSusMgm(const double *magFieldB, const double *satRotRateB,
|
|
|
|
const double *sunDirRefB, double *magMomB, double &errorAngle);
|
2023-04-05 16:11:28 +02:00
|
|
|
|
|
|
|
void splitRotationalRate(const double *satRotRateB, const double *sunDirB);
|
|
|
|
|
2023-07-19 13:24:37 +02:00
|
|
|
void calculateRotationalRates(const double *magFieldB, const double *magRateB,
|
|
|
|
const double *sunDirB, const double *sunRateB,
|
|
|
|
double *fusedRotRate);
|
|
|
|
|
2023-07-21 14:24:52 +02:00
|
|
|
void calculateRotationalRateTorque(const double gainParallel, const double gainOrtho);
|
2023-04-05 16:11:28 +02:00
|
|
|
|
|
|
|
void calculateAngleErrorTorque(const double *sunDirB, const double *sunDirRefB,
|
2023-04-13 17:06:11 +02:00
|
|
|
const double gainAlign);
|
2023-04-05 16:11:28 +02:00
|
|
|
|
|
|
|
void calculateMagneticMoment(double *magMomB);
|
2022-09-20 13:46:42 +02:00
|
|
|
|
2022-10-20 11:07:45 +02:00
|
|
|
protected:
|
|
|
|
private:
|
2023-02-28 09:18:44 +01:00
|
|
|
AcsParameters *acsParameters;
|
2023-04-05 16:11:28 +02:00
|
|
|
double magFieldBT[3] = {0, 0, 0};
|
|
|
|
double satRotRateParallelB[3] = {0, 0, 0};
|
|
|
|
double satRotRateOrthogonalB[3] = {0, 0, 0};
|
|
|
|
double cmdParallel[3] = {0, 0, 0};
|
|
|
|
double cmdOrtho[3] = {0, 0, 0};
|
|
|
|
double cmdAlign[3] = {0, 0, 0};
|
|
|
|
double cmdTorque[3] = {0, 0, 0};
|
2022-09-20 13:46:42 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif /* ACS_CONTROL_SAFECTRL_H_ */
|