mirror of
https://github.com/iNavFlight/inav.git
synced 2025-07-20 23:05:17 +03:00
Update navigation_fixedwing.c
Add fixed wing Emergency Landing vertical descent rate control if altitude sensors working
This commit is contained in:
parent
b55bc46f12
commit
35cf5e89a3
1 changed files with 16 additions and 6 deletions
|
@ -243,18 +243,18 @@ static int8_t loiterDirection(void) {
|
||||||
|
|
||||||
if (pidProfile()->loiter_direction == NAV_LOITER_YAW) {
|
if (pidProfile()->loiter_direction == NAV_LOITER_YAW) {
|
||||||
|
|
||||||
if (rcCommand[YAW] < -250) {
|
if (rcCommand[YAW] < -250) {
|
||||||
loiterDirYaw = 1; //RIGHT //yaw is contrariwise
|
loiterDirYaw = 1; //RIGHT //yaw is contrariwise
|
||||||
}
|
}
|
||||||
|
|
||||||
if (rcCommand[YAW] > 250) {
|
if (rcCommand[YAW] > 250) {
|
||||||
loiterDirYaw = -1; //LEFT //see annexCode in fc_core.c
|
loiterDirYaw = -1; //LEFT //see annexCode in fc_core.c
|
||||||
}
|
}
|
||||||
|
|
||||||
dir = loiterDirYaw;
|
dir = loiterDirYaw;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (IS_RC_MODE_ACTIVE(BOXLOITERDIRCHN)) {
|
if (IS_RC_MODE_ACTIVE(BOXLOITERDIRCHN)) {
|
||||||
dir *= -1;
|
dir *= -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -612,13 +612,23 @@ bool isFixedWingLandingDetected(void)
|
||||||
/*-----------------------------------------------------------
|
/*-----------------------------------------------------------
|
||||||
* FixedWing emergency landing
|
* FixedWing emergency landing
|
||||||
*-----------------------------------------------------------*/
|
*-----------------------------------------------------------*/
|
||||||
void applyFixedWingEmergencyLandingController(void)
|
void applyFixedWingEmergencyLandingController(timeUs_t currentTimeUs)
|
||||||
{
|
{
|
||||||
// FIXME: Use altitude controller if available (similar to MC code)
|
|
||||||
rcCommand[ROLL] = pidAngleToRcCommand(failsafeConfig()->failsafe_fw_roll_angle, pidProfile()->max_angle_inclination[FD_ROLL]);
|
rcCommand[ROLL] = pidAngleToRcCommand(failsafeConfig()->failsafe_fw_roll_angle, pidProfile()->max_angle_inclination[FD_ROLL]);
|
||||||
rcCommand[PITCH] = pidAngleToRcCommand(failsafeConfig()->failsafe_fw_pitch_angle, pidProfile()->max_angle_inclination[FD_PITCH]);
|
|
||||||
rcCommand[YAW] = -pidRateToRcCommand(failsafeConfig()->failsafe_fw_yaw_rate, currentControlRateProfile->stabilized.rates[FD_YAW]);
|
rcCommand[YAW] = -pidRateToRcCommand(failsafeConfig()->failsafe_fw_yaw_rate, currentControlRateProfile->stabilized.rates[FD_YAW]);
|
||||||
rcCommand[THROTTLE] = currentBatteryProfile->failsafe_throttle;
|
rcCommand[THROTTLE] = currentBatteryProfile->failsafe_throttle;
|
||||||
|
|
||||||
|
if (posControl.flags.estAltStatus >= EST_USABLE) {
|
||||||
|
updateClimbRateToAltitudeController(-1.0f * navConfig()->general.emerg_descent_rate, ROC_TO_ALT_NORMAL);
|
||||||
|
applyFixedWingAltitudeAndThrottleController(currentTimeUs);
|
||||||
|
|
||||||
|
if (isPitchAdjustmentValid) {
|
||||||
|
int16_t pitchCorrection = constrain(posControl.rcAdjustment[PITCH], -DEGREES_TO_DECIDEGREES(navConfig()->fw.max_dive_angle), DEGREES_TO_DECIDEGREES(navConfig()->fw.max_climb_angle));
|
||||||
|
rcCommand[PITCH] = -pidAngleToRcCommand(pitchCorrection, pidProfile()->max_angle_inclination[FD_PITCH]);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
rcCommand[PITCH] = pidAngleToRcCommand(failsafeConfig()->failsafe_fw_pitch_angle, pidProfile()->max_angle_inclination[FD_PITCH]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*-----------------------------------------------------------
|
/*-----------------------------------------------------------
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue