mirror of
https://github.com/iNavFlight/inav.git
synced 2025-07-23 16:25:26 +03:00
Use TURN_ASSIST for navigation
This commit is contained in:
parent
b7516be4a5
commit
27a907eab5
5 changed files with 25 additions and 20 deletions
|
@ -699,7 +699,7 @@ void pidController(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef USE_FLM_TURN_ASSIST
|
#ifdef USE_FLM_TURN_ASSIST
|
||||||
if (FLIGHT_MODE(TURN_ASSISTANT)) {
|
if (FLIGHT_MODE(TURN_ASSISTANT) || naivationRequiresTurnAssistance()) {
|
||||||
pidTurnAssistant(pidState);
|
pidTurnAssistant(pidState);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -2420,13 +2420,33 @@ bool naivationRequiresAngleMode(void)
|
||||||
return (currentState & NAV_REQUIRE_ANGLE) || ((currentState & NAV_REQUIRE_ANGLE_FW) && STATE(FIXED_WING));
|
return (currentState & NAV_REQUIRE_ANGLE) || ((currentState & NAV_REQUIRE_ANGLE_FW) && STATE(FIXED_WING));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*-----------------------------------------------------------
|
||||||
|
* An indicator that TURN ASSISTANCE is required for navigation
|
||||||
|
*-----------------------------------------------------------*/
|
||||||
|
bool naivationRequiresTurnAssistance(void)
|
||||||
|
{
|
||||||
|
const navigationFSMStateFlags_t currentState = navGetStateFlags(posControl.navState);
|
||||||
|
if (STATE(FIXED_WING)) {
|
||||||
|
// For airplanes turn assistant is always required when controlling position
|
||||||
|
return (currentState & NAV_CTL_POS);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* An indicator that NAV is in charge of heading control (a signal to disable other heading controllers)
|
* An indicator that NAV is in charge of heading control (a signal to disable other heading controllers)
|
||||||
*/
|
*/
|
||||||
int8_t naivationGetHeadingControlState(void)
|
int8_t naivationGetHeadingControlState(void)
|
||||||
{
|
{
|
||||||
// No explicit MAG_HOLD mode for airplanes
|
// For airplanes report as manual heading control
|
||||||
if ((navGetStateFlags(posControl.navState) & NAV_REQUIRE_MAGHOLD) && !STATE(FIXED_WING)) {
|
if (STATE(FIXED_WING)) {
|
||||||
|
return NAV_HEADING_CONTROL_MANUAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
// For multirotors it depends on navigation system mode
|
||||||
|
if (navGetStateFlags(posControl.navState) & NAV_REQUIRE_MAGHOLD) {
|
||||||
if (posControl.flags.isAdjustingHeading) {
|
if (posControl.flags.isAdjustingHeading) {
|
||||||
return NAV_HEADING_CONTROL_MANUAL;
|
return NAV_HEADING_CONTROL_MANUAL;
|
||||||
}
|
}
|
||||||
|
|
|
@ -258,6 +258,7 @@ void applyWaypointNavigationAndAltitudeHold(void);
|
||||||
/* Functions to signal navigation requirements to main loop */
|
/* Functions to signal navigation requirements to main loop */
|
||||||
bool naivationRequiresAngleMode(void);
|
bool naivationRequiresAngleMode(void);
|
||||||
bool navigationRequiresThrottleTiltCompensation(void);
|
bool navigationRequiresThrottleTiltCompensation(void);
|
||||||
|
bool naivationRequiresTurnAssistance(void);
|
||||||
int8_t naivationGetHeadingControlState(void);
|
int8_t naivationGetHeadingControlState(void);
|
||||||
bool naivationBlockArming(void);
|
bool naivationBlockArming(void);
|
||||||
bool navigationPositionEstimateIsHealthy(void);
|
bool navigationPositionEstimateIsHealthy(void);
|
||||||
|
|
|
@ -297,13 +297,6 @@ static void updatePositionHeadingController_FW(timeUs_t currentTimeUs, timeDelta
|
||||||
|
|
||||||
// Convert rollAdjustment to decidegrees (rcAdjustment holds decidegrees)
|
// Convert rollAdjustment to decidegrees (rcAdjustment holds decidegrees)
|
||||||
posControl.rcAdjustment[ROLL] = CENTIDEGREES_TO_DECIDEGREES(rollAdjustment);
|
posControl.rcAdjustment[ROLL] = CENTIDEGREES_TO_DECIDEGREES(rollAdjustment);
|
||||||
|
|
||||||
// Update magHold heading lock in case pilot is using MAG mode (prevent MAGHOLD to fight navigation)
|
|
||||||
posControl.desiredState.yaw = wrap_36000(posControl.actualState.yaw + headingError);
|
|
||||||
updateHeadingHoldTarget(CENTIDEGREES_TO_DEGREES(posControl.desiredState.yaw));
|
|
||||||
|
|
||||||
// Add pitch compensation
|
|
||||||
//posControl.rcAdjustment[PITCH] = -CENTIDEGREES_TO_DECIDEGREES(ABS(rollAdjustment)) * 0.50f;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void applyFixedWingPositionController(timeUs_t currentTimeUs)
|
void applyFixedWingPositionController(timeUs_t currentTimeUs)
|
||||||
|
@ -440,15 +433,6 @@ void applyFixedWingPitchRollThrottleController(navigationFSMStateFlags_t navStat
|
||||||
if (isRollAdjustmentValid && (navStateFlags & NAV_CTL_POS)) {
|
if (isRollAdjustmentValid && (navStateFlags & NAV_CTL_POS)) {
|
||||||
rollCorrection = constrain(rollCorrection, -DEGREES_TO_DECIDEGREES(navConfig()->fw.max_bank_angle), DEGREES_TO_DECIDEGREES(navConfig()->fw.max_bank_angle));
|
rollCorrection = constrain(rollCorrection, -DEGREES_TO_DECIDEGREES(navConfig()->fw.max_bank_angle), DEGREES_TO_DECIDEGREES(navConfig()->fw.max_bank_angle));
|
||||||
rcCommand[ROLL] = pidAngleToRcCommand(rollCorrection, pidProfile()->max_angle_inclination[FD_ROLL]);
|
rcCommand[ROLL] = pidAngleToRcCommand(rollCorrection, pidProfile()->max_angle_inclination[FD_ROLL]);
|
||||||
|
|
||||||
// Calculate coordinated turn rate based on velocity and banking angle
|
|
||||||
if (posControl.actualState.velXY >= 300.0f) {
|
|
||||||
float targetYawRateDPS = RADIANS_TO_DEGREES(tan_approx(DECIDEGREES_TO_RADIANS(-rollCorrection)) * GRAVITY_CMSS / posControl.actualState.velXY);
|
|
||||||
rcCommand[YAW] = pidRateToRcCommand(targetYawRateDPS, currentControlRateProfile->rates[FD_YAW]);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
rcCommand[YAW] = 0;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((navStateFlags & NAV_CTL_ALT) || (navStateFlags & NAV_CTL_POS)) {
|
if ((navStateFlags & NAV_CTL_ALT) || (navStateFlags & NAV_CTL_POS)) {
|
||||||
|
|
|
@ -36,9 +36,9 @@
|
||||||
#define GPS
|
#define GPS
|
||||||
#define GPS_PROTO_UBLOX
|
#define GPS_PROTO_UBLOX
|
||||||
#define NAV
|
#define NAV
|
||||||
|
#define USE_FLM_TURN_ASSIST // This is mandatory for fixed-wing navigation
|
||||||
#define TELEMETRY
|
#define TELEMETRY
|
||||||
#define TELEMETRY_LTM
|
#define TELEMETRY_LTM
|
||||||
#define USE_FLM_TURN_ASSIST
|
|
||||||
#define TELEMETRY_FRSKY
|
#define TELEMETRY_FRSKY
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue