2022-08-12 12:29:28 +02:00
|
|
|
#ifndef MISSION_CONTROLLER_ACSCONTROLLER_H_
|
|
|
|
#define MISSION_CONTROLLER_ACSCONTROLLER_H_
|
|
|
|
|
2022-08-15 10:50:19 +02:00
|
|
|
#include <commonObjects.h>
|
2022-08-12 12:29:28 +02:00
|
|
|
#include <fsfw/controller/ExtendedControllerBase.h>
|
2022-09-30 11:06:17 +02:00
|
|
|
#include <fsfw/globalfunctions/math/VectorOperations.h>
|
2022-08-15 17:25:16 +02:00
|
|
|
|
2022-09-30 11:06:17 +02:00
|
|
|
#include "acs/ActuatorCmd.h"
|
2022-10-12 10:28:44 +02:00
|
|
|
#include "acs/Guidance.h"
|
2022-09-30 11:06:17 +02:00
|
|
|
#include "acs/Navigation.h"
|
|
|
|
#include "acs/SensorProcessing.h"
|
|
|
|
#include "acs/control/Detumble.h"
|
2022-10-12 10:28:44 +02:00
|
|
|
#include "acs/control/PtgCtrl.h"
|
2022-08-15 17:25:16 +02:00
|
|
|
#include "controllerdefinitions/AcsCtrlDefinitions.h"
|
2022-08-15 10:50:19 +02:00
|
|
|
#include "fsfw_hal/devicehandlers/MgmLIS3MDLHandler.h"
|
|
|
|
#include "fsfw_hal/devicehandlers/MgmRM3100Handler.h"
|
|
|
|
#include "mission/devices/devicedefinitions/IMTQHandlerDefinitions.h"
|
2022-08-17 09:27:19 +02:00
|
|
|
#include "mission/devices/devicedefinitions/SusDefinitions.h"
|
2022-08-12 12:29:28 +02:00
|
|
|
|
2022-08-15 09:58:18 +02:00
|
|
|
class AcsController : public ExtendedControllerBase {
|
|
|
|
public:
|
2022-08-15 10:50:19 +02:00
|
|
|
static constexpr dur_millis_t INIT_DELAY = 500;
|
|
|
|
|
2022-08-15 09:58:18 +02:00
|
|
|
AcsController(object_id_t objectId);
|
2022-08-12 12:29:28 +02:00
|
|
|
|
2022-09-30 11:06:17 +02:00
|
|
|
static const Submode_t SUBMODE_SAFE = 2;
|
|
|
|
static const Submode_t SUBMODE_DETUMBLE = 3;
|
|
|
|
static const Submode_t SUBMODE_PTG_GS = 4;
|
|
|
|
static const Submode_t SUBMODE_PTG_NADIR = 5;
|
|
|
|
|
|
|
|
protected:
|
2022-10-04 13:45:13 +02:00
|
|
|
|
|
|
|
void performSafe();
|
2022-09-30 11:06:17 +02:00
|
|
|
void performDetumble();
|
2022-10-04 13:45:13 +02:00
|
|
|
void performPointingCtrl();
|
2022-09-30 11:06:17 +02:00
|
|
|
|
2022-08-15 09:58:18 +02:00
|
|
|
private:
|
2022-10-06 15:37:41 +02:00
|
|
|
AcsParameters acsParameters;
|
2022-09-30 11:06:17 +02:00
|
|
|
SensorProcessing sensorProcessing;
|
|
|
|
Navigation navigation;
|
|
|
|
ActuatorCmd actuatorCmd;
|
2022-10-12 10:28:44 +02:00
|
|
|
Guidance guidance;
|
2022-09-30 11:06:17 +02:00
|
|
|
|
|
|
|
Detumble detumble;
|
2022-10-12 10:28:44 +02:00
|
|
|
PtgCtrl ptgCtrl;
|
|
|
|
|
2022-10-06 15:37:41 +02:00
|
|
|
uint8_t detumbleCounter;
|
2022-09-30 11:06:17 +02:00
|
|
|
|
2022-08-15 10:50:19 +02:00
|
|
|
enum class InternalState { STARTUP, INITIAL_DELAY, READY };
|
|
|
|
|
|
|
|
InternalState internalState = InternalState::STARTUP;
|
|
|
|
|
2022-08-12 12:29:28 +02:00
|
|
|
ReturnValue_t handleCommandMessage(CommandMessage* message) override;
|
|
|
|
void performControlOperation() override;
|
|
|
|
|
|
|
|
ReturnValue_t initializeLocalDataPool(localpool::DataPool& localDataPoolMap,
|
2022-08-15 09:58:18 +02:00
|
|
|
LocalDataPoolManager& poolManager) override;
|
2022-08-12 12:29:28 +02:00
|
|
|
LocalPoolDataSetBase* getDataSetHandle(sid_t sid) override;
|
|
|
|
|
|
|
|
// Mode abstract functions
|
|
|
|
ReturnValue_t checkModeCommand(Mode_t mode, Submode_t submode,
|
2022-08-15 09:58:18 +02:00
|
|
|
uint32_t* msToReachTheMode) override;
|
2022-10-04 13:45:13 +02:00
|
|
|
void modeChanged(Mode_t mode, Submode_t submode);
|
|
|
|
void announceMode(bool recursive);
|
2022-08-12 12:29:28 +02:00
|
|
|
|
|
|
|
// MGMs
|
2022-09-15 17:46:41 +02:00
|
|
|
acsctrl::MgmDataRaw mgmData;
|
2022-08-15 10:50:19 +02:00
|
|
|
|
2022-08-15 17:25:16 +02:00
|
|
|
MGMLIS3MDL::MgmPrimaryDataset mgm0Lis3Set =
|
|
|
|
MGMLIS3MDL::MgmPrimaryDataset(objects::MGM_0_LIS3_HANDLER);
|
|
|
|
RM3100::Rm3100PrimaryDataset mgm1Rm3100Set =
|
|
|
|
RM3100::Rm3100PrimaryDataset(objects::MGM_1_RM3100_HANDLER);
|
|
|
|
MGMLIS3MDL::MgmPrimaryDataset mgm2Lis3Set =
|
|
|
|
MGMLIS3MDL::MgmPrimaryDataset(objects::MGM_2_LIS3_HANDLER);
|
|
|
|
RM3100::Rm3100PrimaryDataset mgm3Rm3100Set =
|
|
|
|
RM3100::Rm3100PrimaryDataset(objects::MGM_3_RM3100_HANDLER);
|
2022-08-18 17:27:39 +02:00
|
|
|
IMTQ::RawMtmMeasurementSet imtqMgmSet = IMTQ::RawMtmMeasurementSet(objects::IMTQ_HANDLER);
|
2022-08-15 10:50:19 +02:00
|
|
|
|
2022-08-15 11:19:08 +02:00
|
|
|
PoolEntry<float> mgm0PoolVec = PoolEntry<float>(3);
|
|
|
|
PoolEntry<float> mgm1PoolVec = PoolEntry<float>(3);
|
|
|
|
PoolEntry<float> mgm2PoolVec = PoolEntry<float>(3);
|
|
|
|
PoolEntry<float> mgm3PoolVec = PoolEntry<float>(3);
|
2022-08-18 18:18:44 +02:00
|
|
|
PoolEntry<float> imtqMgmPoolVec = PoolEntry<float>(3);
|
2022-08-15 11:19:08 +02:00
|
|
|
PoolEntry<uint8_t> imtqCalActStatus = PoolEntry<uint8_t>();
|
2022-08-15 11:57:57 +02:00
|
|
|
|
2022-08-15 10:50:19 +02:00
|
|
|
void copyMgmData();
|
2022-08-12 12:29:28 +02:00
|
|
|
|
2022-08-17 09:27:19 +02:00
|
|
|
// Sun Sensors
|
2022-09-28 15:27:51 +02:00
|
|
|
|
|
|
|
acsctrl::SusDataRaw susData;
|
|
|
|
|
2022-08-19 15:49:22 +02:00
|
|
|
std::array<SUS::SusDataset, 12> susSets{
|
|
|
|
SUS::SusDataset(objects::SUS_0_N_LOC_XFYFZM_PT_XF),
|
|
|
|
SUS::SusDataset(objects::SUS_1_N_LOC_XBYFZM_PT_XB),
|
|
|
|
SUS::SusDataset(objects::SUS_2_N_LOC_XFYBZB_PT_YB),
|
|
|
|
SUS::SusDataset(objects::SUS_3_N_LOC_XFYBZF_PT_YF),
|
|
|
|
SUS::SusDataset(objects::SUS_4_N_LOC_XMYFZF_PT_ZF),
|
|
|
|
SUS::SusDataset(objects::SUS_5_N_LOC_XFYMZB_PT_ZB),
|
|
|
|
SUS::SusDataset(objects::SUS_6_R_LOC_XFYBZM_PT_XF),
|
|
|
|
SUS::SusDataset(objects::SUS_7_R_LOC_XBYBZM_PT_XB),
|
|
|
|
SUS::SusDataset(objects::SUS_8_R_LOC_XBYBZB_PT_YB),
|
|
|
|
SUS::SusDataset(objects::SUS_9_R_LOC_XBYBZB_PT_YF),
|
|
|
|
SUS::SusDataset(objects::SUS_10_N_LOC_XMYBZF_PT_ZF),
|
|
|
|
SUS::SusDataset(objects::SUS_11_R_LOC_XBYMZB_PT_ZB),
|
2022-08-17 09:27:19 +02:00
|
|
|
};
|
|
|
|
|
2022-09-28 15:27:51 +02:00
|
|
|
PoolEntry<uint16_t> sus0PoolVec = PoolEntry<uint16_t>(6);
|
|
|
|
PoolEntry<uint16_t> sus1PoolVec = PoolEntry<uint16_t>(6);
|
|
|
|
PoolEntry<uint16_t> sus2PoolVec = PoolEntry<uint16_t>(6);
|
|
|
|
PoolEntry<uint16_t> sus3PoolVec = PoolEntry<uint16_t>(6);
|
|
|
|
PoolEntry<uint16_t> sus4PoolVec = PoolEntry<uint16_t>(6);
|
|
|
|
PoolEntry<uint16_t> sus5PoolVec = PoolEntry<uint16_t>(6);
|
|
|
|
PoolEntry<uint16_t> sus6PoolVec = PoolEntry<uint16_t>(6);
|
|
|
|
PoolEntry<uint16_t> sus7PoolVec = PoolEntry<uint16_t>(6);
|
|
|
|
PoolEntry<uint16_t> sus8PoolVec = PoolEntry<uint16_t>(6);
|
|
|
|
PoolEntry<uint16_t> sus9PoolVec = PoolEntry<uint16_t>(6);
|
|
|
|
PoolEntry<uint16_t> sus10PoolVec = PoolEntry<uint16_t>(6);
|
|
|
|
PoolEntry<uint16_t> sus11PoolVec = PoolEntry<uint16_t>(6);
|
|
|
|
|
|
|
|
void copySusData();
|
|
|
|
|
2022-08-15 10:50:19 +02:00
|
|
|
// Initial delay to make sure all pool variables have been initialized their owners
|
|
|
|
Countdown initialCountdown = Countdown(INIT_DELAY);
|
2022-08-12 12:29:28 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif /* MISSION_CONTROLLER_ACSCONTROLLER_H_ */
|