mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-03 06:28:27 -04:00
Plane: QuadPlane: log assistance bitmask in QTUN
This commit is contained in:
parent
3e2a3bfe43
commit
fbcf37f6ca
@ -389,7 +389,8 @@ const struct LogStructure Plane::log_structure[] = {
|
|||||||
// @Field: CRt: climb rate
|
// @Field: CRt: climb rate
|
||||||
// @Field: TMix: transition throttle mix value
|
// @Field: TMix: transition throttle mix value
|
||||||
// @Field: Trn: Transition state: 0-AirspeedWait,1-Timer,2-Done / TailSitter: 0-FW Wait,1-VTOL Wait,2-Done
|
// @Field: Trn: Transition state: 0-AirspeedWait,1-Timer,2-Done / TailSitter: 0-FW Wait,1-VTOL Wait,2-Done
|
||||||
// @Field: Ast: Q assist active
|
// @Field: Ast: bitmask of assistance flags
|
||||||
|
// @FieldBitmaskEnum: Ast: log_assistance_flags
|
||||||
#if HAL_QUADPLANE_ENABLED
|
#if HAL_QUADPLANE_ENABLED
|
||||||
{ LOG_QTUN_MSG, sizeof(QuadPlane::log_QControl_Tuning),
|
{ LOG_QTUN_MSG, sizeof(QuadPlane::log_QControl_Tuning),
|
||||||
"QTUN", "QffffffeccfBB", "TimeUS,ThI,ABst,ThO,ThH,DAlt,Alt,BAlt,DCRt,CRt,TMix,Trn,Ast", "s----mmmnn---", "F----00000---" , true },
|
"QTUN", "QffffffeccfBB", "TimeUS,ThI,ABst,ThO,ThH,DAlt,Alt,BAlt,DCRt,CRt,TMix,Trn,Ast", "s----mmmnn---", "F----00000---" , true },
|
||||||
|
@ -1454,6 +1454,8 @@ float QuadPlane::desired_auto_yaw_rate_cds(void) const
|
|||||||
// Assistance not needed, reset any state
|
// Assistance not needed, reset any state
|
||||||
void QuadPlane::VTOL_Assist::reset()
|
void QuadPlane::VTOL_Assist::reset()
|
||||||
{
|
{
|
||||||
|
force_assist = false;
|
||||||
|
speed_assist = false;
|
||||||
angle_error.reset();
|
angle_error.reset();
|
||||||
alt_error.reset();
|
alt_error.reset();
|
||||||
}
|
}
|
||||||
@ -1525,17 +1527,19 @@ bool QuadPlane::VTOL_Assist::should_assist(float aspeed, bool have_airspeed)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
const bool force_assist = state == STATE::FORCE_ENABLED;
|
force_assist = state == STATE::FORCE_ENABLED;
|
||||||
|
|
||||||
if (speed <= 0) {
|
if (speed <= 0) {
|
||||||
// disabled via speed threshold, still allow force enabled
|
// all checks disabled via speed threshold, still allow force enabled
|
||||||
reset();
|
speed_assist = false;
|
||||||
|
alt_error.reset();
|
||||||
|
angle_error.reset();
|
||||||
return force_assist;
|
return force_assist;
|
||||||
}
|
}
|
||||||
|
|
||||||
// assistance due to Q_ASSIST_SPEED
|
// assistance due to Q_ASSIST_SPEED
|
||||||
// if option bit is enabled only allow assist with real airspeed sensor
|
// if option bit is enabled only allow assist with real airspeed sensor
|
||||||
const bool speed_assist = (have_airspeed && aspeed < speed) &&
|
speed_assist = (have_airspeed && aspeed < speed) &&
|
||||||
(!quadplane.option_is_set(QuadPlane::OPTION::DISABLE_SYNTHETIC_AIRSPEED_ASSIST) || plane.ahrs.using_airspeed_sensor());
|
(!quadplane.option_is_set(QuadPlane::OPTION::DISABLE_SYNTHETIC_AIRSPEED_ASSIST) || plane.ahrs.using_airspeed_sensor());
|
||||||
|
|
||||||
const uint32_t now_ms = AP_HAL::millis();
|
const uint32_t now_ms = AP_HAL::millis();
|
||||||
@ -3745,6 +3749,32 @@ void QuadPlane::Log_Write_QControl_Tuning()
|
|||||||
target_climb_rate_cms = pos_control->get_vel_target_z_cms();
|
target_climb_rate_cms = pos_control->get_vel_target_z_cms();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Asemble assistance bitmask, defintion here is used to generate log documentation
|
||||||
|
enum class log_assistance_flags {
|
||||||
|
in_assisted_flight = 1U<<0, // true if VTOL assist is active
|
||||||
|
forced = 1U<<1, // true if assistance is forced
|
||||||
|
speed = 1U<<2, // true if assistance due to low airspeed
|
||||||
|
alt = 1U<<3, // true if assistance due to low altitude
|
||||||
|
angle = 1U<<4, // true if assistance due to attitude error
|
||||||
|
};
|
||||||
|
|
||||||
|
uint8_t assist_flags = 0;
|
||||||
|
if (assisted_flight) {
|
||||||
|
assist_flags |= (uint8_t)log_assistance_flags::in_assisted_flight;
|
||||||
|
}
|
||||||
|
if (assist.in_force_assist()) {
|
||||||
|
assist_flags |= (uint8_t)log_assistance_flags::forced;
|
||||||
|
}
|
||||||
|
if (assist.in_speed_assist()) {
|
||||||
|
assist_flags |= (uint8_t)log_assistance_flags::speed;
|
||||||
|
}
|
||||||
|
if (assist.in_alt_assist()) {
|
||||||
|
assist_flags |= (uint8_t)log_assistance_flags::alt;
|
||||||
|
}
|
||||||
|
if (assist.in_angle_assist()) {
|
||||||
|
assist_flags |= (uint8_t)log_assistance_flags::angle;
|
||||||
|
}
|
||||||
|
|
||||||
struct log_QControl_Tuning pkt = {
|
struct log_QControl_Tuning pkt = {
|
||||||
LOG_PACKET_HEADER_INIT(LOG_QTUN_MSG),
|
LOG_PACKET_HEADER_INIT(LOG_QTUN_MSG),
|
||||||
time_us : AP_HAL::micros64(),
|
time_us : AP_HAL::micros64(),
|
||||||
@ -3759,7 +3789,7 @@ void QuadPlane::Log_Write_QControl_Tuning()
|
|||||||
climb_rate : int16_t(inertial_nav.get_velocity_z_up_cms()),
|
climb_rate : int16_t(inertial_nav.get_velocity_z_up_cms()),
|
||||||
throttle_mix : attitude_control->get_throttle_mix(),
|
throttle_mix : attitude_control->get_throttle_mix(),
|
||||||
transition_state : transition->get_log_transition_state(),
|
transition_state : transition->get_log_transition_state(),
|
||||||
assist : assisted_flight,
|
assist : assist_flags,
|
||||||
};
|
};
|
||||||
plane.logger.WriteBlock(&pkt, sizeof(pkt));
|
plane.logger.WriteBlock(&pkt, sizeof(pkt));
|
||||||
|
|
||||||
|
@ -358,6 +358,12 @@ private:
|
|||||||
};
|
};
|
||||||
void set_state(STATE _state) { state = _state; }
|
void set_state(STATE _state) { state = _state; }
|
||||||
|
|
||||||
|
// Logging getters for assist types
|
||||||
|
bool in_force_assist() const { return force_assist; }
|
||||||
|
bool in_speed_assist() const { return speed_assist; }
|
||||||
|
bool in_alt_assist() const { return alt_error.is_active(); }
|
||||||
|
bool in_angle_assist() const { return angle_error.is_active(); }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
// Default to enabled
|
// Default to enabled
|
||||||
@ -382,6 +388,10 @@ private:
|
|||||||
Assist_Hysteresis angle_error;
|
Assist_Hysteresis angle_error;
|
||||||
Assist_Hysteresis alt_error;
|
Assist_Hysteresis alt_error;
|
||||||
|
|
||||||
|
// Force and speed assist have no hysteresis
|
||||||
|
bool force_assist;
|
||||||
|
bool speed_assist;
|
||||||
|
|
||||||
// Reference to access quadplane
|
// Reference to access quadplane
|
||||||
QuadPlane& quadplane;
|
QuadPlane& quadplane;
|
||||||
} assist {*this};
|
} assist {*this};
|
||||||
|
Loading…
Reference in New Issue
Block a user