Mixer update: dynamic idle and throttle logging improvements
commit8050ecd1e77a755660db821a69f5351a4d172b70
authorctzsnooze <chris.thompson@sydney.edu.au>
Sun, 8 Nov 2020 22:07:38 +0000 (9 09:07 +1100)
committerctzsnooze <chris.thompson@sydney.edu.au>
Sun, 8 Nov 2020 22:09:17 +0000 (9 09:09 +1100)
tree97ce6c10d16181bb7adb78c392651ee170308c5d
parent8ee317f815312ab8eee0df46009a85a19929326d
Mixer update: dynamic idle and throttle logging improvements

- all CLI parameters related to dynamic idle alone re-named with the `dyn_idle_` prefix
- when linear throttle scaling is active, the user's set idle value is now correct whether dynamic idle is on or off. Previously, the idle value fell when dynamic idle was activated at the same time as linear throttle scaling.
- enabling dynamic idle no longer causes a deadband at full throttle
- the setpoint throttle value sent to Blackbox does not include the dynamic idle offset
- the throttle value sent to the antigravity and dynamic lowpass code includes throttle scaling, but no other modifiers, to avoid false elevation of the apparent throttle position from dynamic idle and unnecessary transient changes in their filter cutoffs
- Dynamic Idle now uses a modified PI controller during active rpm control phase
- the D factor provides early detection of rapid falls in rpm, e.g. in hard chops. It is filtered heavily. Inadequate `dyn_idle_d_gain` may lead to a transient drop in rpm immediately after cutting throttle. Default is 50.
- the P factor provides fast control over rpm during the active control phase. Too much `dyn_idle_p_gain` may cause oscillation in that phase. Note enough and a slow drop in rpm will be inadequately corrected. Default is 50. Needs to be higher with heavier larger props.
- An integral element does most of the work.  It prevents enduring offsets from the set rpm. The I gain is high when increasing responding to low rpm, and slow to release.  The slow release makes a huge difference and avoids I oscillation. Not enough `dyn_idle_i_gain` and there may be wobble in rpm during the control phase, or the idle value may rise too slowly; too much may cause wobble. Default is 50. Needs to be higher with heavier larger props.
- The DYN_IDLE debug shows idle P, I and D in debugs 0, 1 and 2. minRps stays in debug 3.
- Interactions between throttle and thrust linear, dynamic idle, throttle scaling and throttle boost have been checked and work as they should.
12 files changed:
src/main/blackbox/blackbox.c
src/main/cli/settings.c
src/main/config/config.c
src/main/drivers/motor.c
src/main/flight/mixer.c
src/main/flight/mixer_init.c
src/main/flight/mixer_init.h
src/main/flight/pid.c
src/main/flight/pid.h
src/main/flight/pid_init.c
src/main/flight/rpm_filter.c
src/main/msp/msp.c