mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-18 06:38:29 -04:00
AC_AttitudeControl: Tradheli- fix inverted mode collective handling
This commit is contained in:
parent
52bffc4b4d
commit
d103eebf91
@ -539,12 +539,27 @@ void AC_AttitudeControl_Heli::set_throttle_out(float throttle_in, bool apply_ang
|
|||||||
_throttle_in = throttle_in;
|
_throttle_in = throttle_in;
|
||||||
update_althold_lean_angle_max(throttle_in);
|
update_althold_lean_angle_max(throttle_in);
|
||||||
|
|
||||||
if (_inverted_flight) {
|
if (_transition_count > 0) {
|
||||||
throttle_in = 1.0 - throttle_in;
|
_transition_count -= 1;
|
||||||
|
} else {
|
||||||
|
_transition_count = 0;
|
||||||
|
}
|
||||||
|
float throttle_out = 0.0f;
|
||||||
|
if (_transition_count > 0) {
|
||||||
|
if ((_ahrs.roll_sensor >= -3000 && _ahrs.roll_sensor <= 3000) || _ahrs.roll_sensor >= 15000 || _ahrs.roll_sensor <= -15000) {
|
||||||
|
throttle_out = (throttle_in - ((AP_MotorsHeli&)_motors).get_coll_mid()) / cosf(radians(_ahrs.roll_sensor * 0.01f)) + ((AP_MotorsHeli&)_motors).get_coll_mid();
|
||||||
|
} else if ((_ahrs.roll_sensor > 3000 && _ahrs.roll_sensor < 15000) || (_ahrs.roll_sensor > -15000 && _ahrs.roll_sensor < -3000)) {
|
||||||
|
float scale_factor = cosf(radians(_ahrs.roll_sensor * 0.01f)) / cosf(radians(30.0f));
|
||||||
|
throttle_out = scale_factor * (throttle_in - ((AP_MotorsHeli&)_motors).get_coll_mid())/ cosf(radians(30.0f)) + ((AP_MotorsHeli&)_motors).get_coll_mid();
|
||||||
|
}
|
||||||
|
} else if (_inverted_flight) {
|
||||||
|
throttle_out = 1.0f - throttle_in;
|
||||||
|
} else {
|
||||||
|
throttle_out = throttle_in;
|
||||||
}
|
}
|
||||||
|
|
||||||
_motors.set_throttle_filter_cutoff(filter_cutoff);
|
_motors.set_throttle_filter_cutoff(filter_cutoff);
|
||||||
_motors.set_throttle(throttle_in);
|
_motors.set_throttle(throttle_out);
|
||||||
// Clear angle_boost for logging purposes
|
// Clear angle_boost for logging purposes
|
||||||
_angle_boost = 0.0f;
|
_angle_boost = 0.0f;
|
||||||
}
|
}
|
||||||
@ -574,4 +589,13 @@ void AC_AttitudeControl_Heli::set_notch_sample_rate(float sample_rate)
|
|||||||
_pid_rate_pitch.set_notch_sample_rate(sample_rate);
|
_pid_rate_pitch.set_notch_sample_rate(sample_rate);
|
||||||
_pid_rate_yaw.set_notch_sample_rate(sample_rate);
|
_pid_rate_yaw.set_notch_sample_rate(sample_rate);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// enable/disable inverted flight
|
||||||
|
void AC_AttitudeControl_Heli::set_inverted_flight(bool inverted)
|
||||||
|
{
|
||||||
|
if (_inverted_flight != inverted) {
|
||||||
|
_transition_count = AC_ATTITUDE_HELI_INVERTED_TRANSITION_TIME * AP::scheduler().get_filtered_loop_rate_hz();
|
||||||
|
}
|
||||||
|
_inverted_flight = inverted;
|
||||||
|
}
|
||||||
|
@ -28,6 +28,7 @@
|
|||||||
#define AC_ATTITUDE_HELI_RATE_Y_FF_FILTER 20.0f
|
#define AC_ATTITUDE_HELI_RATE_Y_FF_FILTER 20.0f
|
||||||
#define AC_ATTITUDE_HELI_HOVER_ROLL_TRIM_DEFAULT 300
|
#define AC_ATTITUDE_HELI_HOVER_ROLL_TRIM_DEFAULT 300
|
||||||
#define AC_ATTITUDE_HELI_ACRO_OVERSHOOT_ANGLE_RAD ToRad(30.0f)
|
#define AC_ATTITUDE_HELI_ACRO_OVERSHOOT_ANGLE_RAD ToRad(30.0f)
|
||||||
|
#define AC_ATTITUDE_HELI_INVERTED_TRANSITION_TIME 3.0f
|
||||||
|
|
||||||
class AC_AttitudeControl_Heli : public AC_AttitudeControl {
|
class AC_AttitudeControl_Heli : public AC_AttitudeControl {
|
||||||
public:
|
public:
|
||||||
@ -82,9 +83,7 @@ public:
|
|||||||
void input_euler_angle_roll_pitch_yaw(float euler_roll_angle_cd, float euler_pitch_angle_cd, float euler_yaw_angle_cd, bool slew_yaw) override;
|
void input_euler_angle_roll_pitch_yaw(float euler_roll_angle_cd, float euler_pitch_angle_cd, float euler_yaw_angle_cd, bool slew_yaw) override;
|
||||||
|
|
||||||
// enable/disable inverted flight
|
// enable/disable inverted flight
|
||||||
void set_inverted_flight(bool inverted) override {
|
void set_inverted_flight(bool inverted) override;
|
||||||
_inverted_flight = inverted;
|
|
||||||
}
|
|
||||||
|
|
||||||
// set the PID notch sample rates
|
// set the PID notch sample rates
|
||||||
void set_notch_sample_rate(float sample_rate) override;
|
void set_notch_sample_rate(float sample_rate) override;
|
||||||
@ -103,6 +102,7 @@ private:
|
|||||||
|
|
||||||
// true in inverted flight mode
|
// true in inverted flight mode
|
||||||
bool _inverted_flight;
|
bool _inverted_flight;
|
||||||
|
uint16_t _transition_count;
|
||||||
|
|
||||||
// Integrate vehicle rate into _att_error_rot_vec_rad
|
// Integrate vehicle rate into _att_error_rot_vec_rad
|
||||||
void integrate_bf_rate_error_to_angle_errors();
|
void integrate_bf_rate_error_to_angle_errors();
|
||||||
|
Loading…
Reference in New Issue
Block a user