#ifndef MISSION_CONTROLLER_CONTROLLERDEFINITIONS_ACSCTRLDEFINITIONS_H_ #define MISSION_CONTROLLER_CONTROLLERDEFINITIONS_ACSCTRLDEFINITIONS_H_ #include #include #include #include namespace acsctrl { static const uint8_t INTERFACE_ID = CLASS_ID::ACS_CTRL; //! [EXPORT] : [COMMENT] File deletion failed and at least one file is still existent. static constexpr ReturnValue_t FILE_DELETION_FAILED = MAKE_RETURN_CODE(0xA0); //! [EXPORT] : [COMMENT] Writing the TLE to the file has failed. static constexpr ReturnValue_t WRITE_FILE_FAILED = MAKE_RETURN_CODE(0xA1); //! [EXPORT] : [COMMENT] Reading the TLE to the file has failed. static constexpr ReturnValue_t READ_FILE_FAILED = MAKE_RETURN_CODE(0xA2); //! [EXPORT] : [COMMENT] A single RW has failed. static constexpr ReturnValue_t SINGLE_RW_UNAVAILABLE = MAKE_RETURN_CODE(0xA3); //! [EXPORT] : [COMMENT] Multiple RWs have failed. static constexpr ReturnValue_t MULTIPLE_RW_UNAVAILABLE = MAKE_RETURN_CODE(0xA4); struct RwAvail { bool rw1avail = false; bool rw2avail = false; bool rw3avail = false; bool rw4avail = false; }; enum SetIds : uint32_t { MGM_SENSOR_DATA, MGM_PROCESSED_DATA, SUS_SENSOR_DATA, SUS_PROCESSED_DATA, GYR_SENSOR_DATA, GYR_PROCESSED_DATA, GPS_PROCESSED_DATA, MEKF_DATA, CTRL_VAL_DATA, ACTUATOR_CMD_DATA, FUSED_ROTATION_RATE_DATA, FUSED_ROTATION_RATE_SOURCES_DATA, TLE_SET, }; enum PoolIds : lp_id_t { // MGM Raw MGM_0_LIS3_UT, MGM_1_RM3100_UT, MGM_2_LIS3_UT, MGM_3_RM3100_UT, MGM_IMTQ_CAL_NT, MGM_IMTQ_CAL_ACT_STATUS, // MGM Processed MGM_0_VEC, MGM_1_VEC, MGM_2_VEC, MGM_3_VEC, MGM_4_VEC, MGM_VEC_TOT, MGM_VEC_TOT_DERIVATIVE, MAG_IGRF_MODEL, // SUS Raw SUS_0_N_LOC_XFYFZM_PT_XF, SUS_6_R_LOC_XFYBZM_PT_XF, SUS_1_N_LOC_XBYFZM_PT_XB, SUS_7_R_LOC_XBYBZM_PT_XB, SUS_2_N_LOC_XFYBZB_PT_YB, SUS_8_R_LOC_XBYBZB_PT_YB, SUS_3_N_LOC_XFYBZF_PT_YF, SUS_9_R_LOC_XBYBZB_PT_YF, SUS_4_N_LOC_XMYFZF_PT_ZF, SUS_10_N_LOC_XMYBZF_PT_ZF, SUS_5_N_LOC_XFYMZB_PT_ZB, SUS_11_R_LOC_XBYMZB_PT_ZB, // SUS Processed SUS_0_VEC, SUS_1_VEC, SUS_2_VEC, SUS_3_VEC, SUS_4_VEC, SUS_5_VEC, SUS_6_VEC, SUS_7_VEC, SUS_8_VEC, SUS_9_VEC, SUS_10_VEC, SUS_11_VEC, SUS_VEC_TOT, SUS_VEC_TOT_DERIVATIVE, SUN_IJK_MODEL, // GYR Raw GYR_0_ADIS, GYR_1_L3, GYR_2_ADIS, GYR_3_L3, // GYR Processed GYR_0_VEC, GYR_1_VEC, GYR_2_VEC, GYR_3_VEC, GYR_VEC_TOT, // GPS Processed SOURCE, GC_LATITUDE, GD_LONGITUDE, ALTITUDE, GPS_POSITION, GPS_VELOCITY, // MEKF SAT_ROT_RATE_MEKF, QUAT_MEKF, MEKF_STATUS, QUAT_QUEST, // Ctrl Values SAFE_STRAT, TGT_QUAT, ERROR_QUAT, ERROR_ANG, TGT_ROT_RATE, // Actuator Cmd RW_TARGET_TORQUE, RW_TARGET_SPEED, MTQ_TARGET_DIPOLE, // Fused Rotation Rate ROT_RATE_TOTAL_SUSMGM, ROT_RATE_TOTAL_SOURCE, ROT_RATE_SOURCE, // Fused Rotation Rate Sources ROT_RATE_ORTHOGONAL_SUSMGM, ROT_RATE_PARALLEL_SUSMGM, ROT_RATE_TOTAL_SUSMGM, ROT_RATE_TOTAL_QUEST, ROT_RATE_TOTAL_STR, }; static constexpr uint8_t MGM_SET_RAW_ENTRIES = 6; static constexpr uint8_t MGM_SET_PROCESSED_ENTRIES = 8; static constexpr uint8_t SUS_SET_RAW_ENTRIES = 12; static constexpr uint8_t SUS_SET_PROCESSED_ENTRIES = 15; static constexpr uint8_t GYR_SET_RAW_ENTRIES = 4; static constexpr uint8_t GYR_SET_PROCESSED_ENTRIES = 5; static constexpr uint8_t GPS_SET_PROCESSED_ENTRIES = 6; static constexpr uint8_t ATTITUDE_ESTIMATION_SET_ENTRIES = 4; static constexpr uint8_t CTRL_VAL_SET_ENTRIES = 5; static constexpr uint8_t ACT_CMD_SET_ENTRIES = 3; static constexpr uint8_t FUSED_ROT_RATE_SET_ENTRIES = 3; static constexpr uint8_t FUSED_ROT_RATE_SOURCES_SET_ENTRIES = 5; /** * @brief Raw MGM sensor data. Includes the IMTQ sensor data and actuator status. */ class MgmDataRaw : public StaticLocalDataSet { public: MgmDataRaw(HasLocalDataPoolIF* hkOwner) : StaticLocalDataSet(hkOwner, MGM_SENSOR_DATA) {} // The ACS board measurement are in floating point uT lp_vec_t mgm0Lis3 = lp_vec_t(sid.objectId, MGM_0_LIS3_UT, this); lp_vec_t mgm1Rm3100 = lp_vec_t(sid.objectId, MGM_1_RM3100_UT, this); lp_vec_t mgm2Lis3 = lp_vec_t(sid.objectId, MGM_2_LIS3_UT, this); lp_vec_t mgm3Rm3100 = lp_vec_t(sid.objectId, MGM_3_RM3100_UT, this); // The IMTQ measurements are in integer nT lp_vec_t imtqRaw = lp_vec_t(sid.objectId, MGM_IMTQ_CAL_NT, this); lp_var_t actuationCalStatus = lp_var_t(sid.objectId, MGM_IMTQ_CAL_ACT_STATUS, this); private: }; class MgmDataProcessed : public StaticLocalDataSet { public: MgmDataProcessed(HasLocalDataPoolIF* hkOwner) : StaticLocalDataSet(hkOwner, MGM_PROCESSED_DATA) {} lp_vec_t mgm0vec = lp_vec_t(sid.objectId, MGM_0_VEC, this); lp_vec_t mgm1vec = lp_vec_t(sid.objectId, MGM_1_VEC, this); lp_vec_t mgm2vec = lp_vec_t(sid.objectId, MGM_2_VEC, this); lp_vec_t mgm3vec = lp_vec_t(sid.objectId, MGM_3_VEC, this); lp_vec_t mgm4vec = lp_vec_t(sid.objectId, MGM_4_VEC, this); lp_vec_t mgmVecTot = lp_vec_t(sid.objectId, MGM_VEC_TOT, this); lp_vec_t mgmVecTotDerivative = lp_vec_t(sid.objectId, MGM_VEC_TOT_DERIVATIVE, this); lp_vec_t magIgrfModel = lp_vec_t(sid.objectId, MAG_IGRF_MODEL, this); private: }; class SusDataRaw : public StaticLocalDataSet { public: SusDataRaw(HasLocalDataPoolIF* hkOwner) : StaticLocalDataSet(hkOwner, SUS_SENSOR_DATA) {} lp_vec_t sus0 = lp_vec_t(sid.objectId, SUS_0_N_LOC_XFYFZM_PT_XF, this); lp_vec_t sus1 = lp_vec_t(sid.objectId, SUS_1_N_LOC_XBYFZM_PT_XB, this); lp_vec_t sus2 = lp_vec_t(sid.objectId, SUS_2_N_LOC_XFYBZB_PT_YB, this); lp_vec_t sus3 = lp_vec_t(sid.objectId, SUS_3_N_LOC_XFYBZF_PT_YF, this); lp_vec_t sus4 = lp_vec_t(sid.objectId, SUS_4_N_LOC_XMYFZF_PT_ZF, this); lp_vec_t sus5 = lp_vec_t(sid.objectId, SUS_5_N_LOC_XFYMZB_PT_ZB, this); lp_vec_t sus6 = lp_vec_t(sid.objectId, SUS_6_R_LOC_XFYBZM_PT_XF, this); lp_vec_t sus7 = lp_vec_t(sid.objectId, SUS_7_R_LOC_XBYBZM_PT_XB, this); lp_vec_t sus8 = lp_vec_t(sid.objectId, SUS_8_R_LOC_XBYBZB_PT_YB, this); lp_vec_t sus9 = lp_vec_t(sid.objectId, SUS_9_R_LOC_XBYBZB_PT_YF, this); lp_vec_t sus10 = lp_vec_t(sid.objectId, SUS_10_N_LOC_XMYBZF_PT_ZF, this); lp_vec_t sus11 = lp_vec_t(sid.objectId, SUS_11_R_LOC_XBYMZB_PT_ZB, this); private: }; class SusDataProcessed : public StaticLocalDataSet { public: SusDataProcessed(HasLocalDataPoolIF* hkOwner) : StaticLocalDataSet(hkOwner, SUS_PROCESSED_DATA) {} lp_vec_t sus0vec = lp_vec_t(sid.objectId, SUS_0_VEC, this); lp_vec_t sus1vec = lp_vec_t(sid.objectId, SUS_1_VEC, this); lp_vec_t sus2vec = lp_vec_t(sid.objectId, SUS_2_VEC, this); lp_vec_t sus3vec = lp_vec_t(sid.objectId, SUS_3_VEC, this); lp_vec_t sus4vec = lp_vec_t(sid.objectId, SUS_4_VEC, this); lp_vec_t sus5vec = lp_vec_t(sid.objectId, SUS_5_VEC, this); lp_vec_t sus6vec = lp_vec_t(sid.objectId, SUS_6_VEC, this); lp_vec_t sus7vec = lp_vec_t(sid.objectId, SUS_7_VEC, this); lp_vec_t sus8vec = lp_vec_t(sid.objectId, SUS_8_VEC, this); lp_vec_t sus9vec = lp_vec_t(sid.objectId, SUS_9_VEC, this); lp_vec_t sus10vec = lp_vec_t(sid.objectId, SUS_10_VEC, this); lp_vec_t sus11vec = lp_vec_t(sid.objectId, SUS_11_VEC, this); lp_vec_t susVecTot = lp_vec_t(sid.objectId, SUS_VEC_TOT, this); lp_vec_t susVecTotDerivative = lp_vec_t(sid.objectId, SUS_VEC_TOT_DERIVATIVE, this); lp_vec_t sunIjkModel = lp_vec_t(sid.objectId, SUN_IJK_MODEL, this); private: }; class GyrDataRaw : public StaticLocalDataSet { public: GyrDataRaw(HasLocalDataPoolIF* hkOwner) : StaticLocalDataSet(hkOwner, GYR_SENSOR_DATA) {} lp_vec_t gyr0Adis = lp_vec_t(sid.objectId, GYR_0_ADIS, this); lp_vec_t gyr1L3 = lp_vec_t(sid.objectId, GYR_1_L3, this); lp_vec_t gyr2Adis = lp_vec_t(sid.objectId, GYR_2_ADIS, this); lp_vec_t gyr3L3 = lp_vec_t(sid.objectId, GYR_3_L3, this); private: }; class GyrDataProcessed : public StaticLocalDataSet { public: GyrDataProcessed(HasLocalDataPoolIF* hkOwner) : StaticLocalDataSet(hkOwner, GYR_PROCESSED_DATA) {} lp_vec_t gyr0vec = lp_vec_t(sid.objectId, GYR_0_VEC, this); lp_vec_t gyr1vec = lp_vec_t(sid.objectId, GYR_1_VEC, this); lp_vec_t gyr2vec = lp_vec_t(sid.objectId, GYR_2_VEC, this); lp_vec_t gyr3vec = lp_vec_t(sid.objectId, GYR_3_VEC, this); lp_vec_t gyrVecTot = lp_vec_t(sid.objectId, GYR_VEC_TOT, this); private: }; class GpsDataProcessed : public StaticLocalDataSet { public: GpsDataProcessed(HasLocalDataPoolIF* hkOwner) : StaticLocalDataSet(hkOwner, GPS_PROCESSED_DATA) {} lp_var_t gcLatitude = lp_var_t(sid.objectId, GC_LATITUDE, this); lp_var_t gdLongitude = lp_var_t(sid.objectId, GD_LONGITUDE, this); lp_var_t altitude = lp_var_t(sid.objectId, ALTITUDE, this); lp_vec_t gpsPosition = lp_vec_t(sid.objectId, GPS_POSITION, this); lp_vec_t gpsVelocity = lp_vec_t(sid.objectId, GPS_VELOCITY, this); lp_var_t source = lp_var_t(sid.objectId, SOURCE, this); private: }; class AttitudeEstimationData : public StaticLocalDataSet { public: AttitudeEstimationData(HasLocalDataPoolIF* hkOwner) : StaticLocalDataSet(hkOwner, MEKF_DATA) {} lp_vec_t quatMekf = lp_vec_t(sid.objectId, QUAT_MEKF, this); lp_vec_t satRotRateMekf = lp_vec_t(sid.objectId, SAT_ROT_RATE_MEKF, this); lp_var_t mekfStatus = lp_var_t(sid.objectId, MEKF_STATUS, this); lp_vec_t quatQuest = lp_vec_t(sid.objectId, QUAT_MEKF, this); private: }; class CtrlValData : public StaticLocalDataSet { public: CtrlValData(HasLocalDataPoolIF* hkOwner) : StaticLocalDataSet(hkOwner, CTRL_VAL_DATA) {} lp_var_t safeStrat = lp_var_t(sid.objectId, SAFE_STRAT, this); lp_vec_t tgtQuat = lp_vec_t(sid.objectId, TGT_QUAT, this); lp_vec_t errQuat = lp_vec_t(sid.objectId, ERROR_QUAT, this); lp_var_t errAng = lp_var_t(sid.objectId, ERROR_ANG, this); lp_vec_t tgtRotRate = lp_vec_t(sid.objectId, TGT_ROT_RATE, this); private: }; class ActuatorCmdData : public StaticLocalDataSet { public: ActuatorCmdData(HasLocalDataPoolIF* hkOwner) : StaticLocalDataSet(hkOwner, ACTUATOR_CMD_DATA) {} lp_vec_t rwTargetTorque = lp_vec_t(sid.objectId, RW_TARGET_TORQUE, this); lp_vec_t rwTargetSpeed = lp_vec_t(sid.objectId, RW_TARGET_SPEED, this); lp_vec_t mtqTargetDipole = lp_vec_t(sid.objectId, MTQ_TARGET_DIPOLE, this); private: }; class FusedRotRateData : public StaticLocalDataSet { public: FusedRotRateData(HasLocalDataPoolIF* hkOwner) : StaticLocalDataSet(hkOwner, FUSED_ROTATION_RATE_DATA) {} lp_vec_t rotRateTotalSusMgm = lp_vec_t(sid.objectId, ROT_RATE_TOTAL_SUSMGM, this); lp_vec_t rotRateTotalSource = lp_vec_t(sid.objectId, ROT_RATE_TOTAL_SOURCE, this); lp_var_t rotRateSource = lp_var_t(sid.objectId, ROT_RATE_SOURCE, this); private: }; class FusedRotRateSourcesData : public StaticLocalDataSet { public: FusedRotRateSourcesData(HasLocalDataPoolIF* hkOwner) : StaticLocalDataSet(hkOwner, FUSED_ROTATION_RATE_SOURCES_DATA) {} lp_vec_t rotRateOrthogonalSusMgm = lp_vec_t(sid.objectId, ROT_RATE_ORTHOGONAL_SUSMGM, this); lp_vec_t rotRateParallelSusMgm = lp_vec_t(sid.objectId, ROT_RATE_PARALLEL_SUSMGM, this); lp_vec_t rotRateTotalSusMgm = lp_vec_t(sid.objectId, ROT_RATE_TOTAL_SUSMGM, this); lp_vec_t rotRateTotalQuest = lp_vec_t(sid.objectId, ROT_RATE_TOTAL_QUEST, this); lp_vec_t rotRateTotalStr = lp_vec_t(sid.objectId, ROT_RATE_TOTAL_STR, this); private: }; } // namespace acsctrl #endif /* MISSION_CONTROLLER_CONTROLLERDEFINITIONS_ACSCTRLDEFINITIONS_H_ */