diff --git a/docs/wiki/guides/current/Position-Hold-v4-6.md b/docs/wiki/guides/current/Position-Hold-v4-6.md index 99bb360db6..a7982daa3a 100644 --- a/docs/wiki/guides/current/Position-Hold-v4-6.md +++ b/docs/wiki/guides/current/Position-Hold-v4-6.md @@ -1,17 +1,19 @@ # Position Hold 4.6 -Betaflight 4.6 introduces Altitude Hold and Position Hold +Betaflight 4.6 introduces Altitude Hold and Position Hold. When used together, these features allow the pilot to hit a switch and the aircraft will hover at a fixed location and constant altitude, in Angle Mode. The sticks can then be used to ajust altitude and location. A GPS is essential, and a Magnetometer is strongly recommended. ## Quick-Start - Include `ALTITUDE_HOLD` and `POSITION_HOLD` in your firmware build. -- Ensure your GPS is working properly -- Ideally, include a Magnetometer and verify that it is working properly -- Set the hover throttle value accurately -- Enable both Altitude Hold and Position Hold on the same Mode switch -- Hover the quad and test carefully; the aircraft will be in Angle mode and stick responses will be different from usual. +- Ensure your GPS is working properly. +- Ideally, include a Magnetometer and verify that it is working properly. +- Set the hover throttle value accurately. +- Enable both Altitude Hold and Position Hold on the same Mode switch. +- Check that the aircraft hovers without drift in Angle Mode (ie, that the accelerometer is calibrated correctly. Field adjustments to Acc Cal can be made using the sticks. +- Hover the quad and test carefully +- Note that the aircraft will be in Angle mode - stick responses will be very different from usual. ## Altitude Hold @@ -23,26 +25,24 @@ The accuracy of the altitude hold depends on a number of factors - the accuracy If used 'alone' - i.e. without Position Hold, the aircraft's altitude should be stable, but there will be NO position stability; roll, pitch and yaw controls will work as they 'normally' do, and the craft will always be in Angle mode. -Reliable altitude hold requires a good altitude source. A GPS alone is sufficient, but needs lot of satellites, and some of them must be low to the horizon. Sometimes enabling a Barometer will improve altitude estimation. The accuracy and stability of the Altitude estimate can be checked in the Congfigurator Sensors tab. The default PIDs are intended for GPS only configurations, and may be a bit aggressive if a fast Barometer is added. +Reliable altitude hold requires a good altitude source. A GPS alone is sufficient, but needs lot of satellites, and some of them must be low to the horizon. Sometimes enabling a Barometer will improve altitude estimation, particularly while hovering, but it may also cause altitude errors in gusty or windy conditions, when close to ground, if temperature changes, and when the speed of the aircraft changes. The accuracy and stability of the Altitude estimate can be checked in the Congfigurator Sensors tab. The default PIDs are intended for GPS only configurations, and may be a bit aggressive if a fast Barometer is added. The pilot must configure a mode switch to enable Altitude Hold in Configurator's Modes tab. When active, if the throttle is kept within a deadband around the normal hover throttle stick position, the aircraft should maintain constant altitude. -If the pilot wants to adjust the altitude to a higher value, they should bring the throttle above the deadband zone, and vice versa. The aircraft responds by climbing at a velocity that is proportional to stick position. At full throttle, the aircraft will climb at a steady rate of only 5m/s. If throttle is below the deadband, the aircraft will descend at a steady rate. +To adjust the altitude to a higher value, the pilot should raise throttle above the deadband zone; the aircraft should climb at a velocity proportional to stick position. At full throttle, the aircraft will climb at the `alt_hold_adjust_rate` of 5m/s by default. If throttle is below the deadband, the aircraft will descend at a steady rate. However, if throttle is put all the way down, to zero, the aircraft will hover, and neither ascend nor descend. Putting throttle hard to zero is a kind of 'short-cut' to a 'fixed altitude hover'. -When Altitude Hold is initiated, it first sets throttle to the CLI `hover_throttle` value, and a PID controller then adjusts the throttle, either side of the hover value, to maintain altitude. - -If the `hover_throttle` value is too low, the quad will immediately drop every time Altitude Hold starts, and if it is too high, the quad will immediately climb at the start. The response at the start should be used to fine-tune the correct value. When set correctly, there will be no sudden altitude change at the start. At the field, the hover throttle value can be adjusted via the GPS Rescue OSD sub-menu. +When Altitude Hold is initiated, throttle is initially set to the CLI `hover_throttle` value. A PID controller then adjusts the throttle, either side of the hover value, to maintain altitude. If the `hover_throttle` value is too low, the quad will immediately drop every time Altitude Hold starts, and if it is too high, the quad will immediately climb at the start. The response at the start should be used to fine-tune the correct value. When set correctly, there will be no sudden altitude change at the start. At the field, the hover throttle value can be adjusted via the GPS Rescue OSD sub-menu. To keep the aircraft at constant height, throttle must be set either to: - a position within the deadband zone either side of the hover throttle value, or - zero (throttle all the way down) -If Altitude Hold is enabled as an emergency response to a rapid drop, or if the quad is climbing really fast, there will likely be overshoot. The code cannot stop the quad instantly, but it should get to the initiation point within a few seconds. It's wise to check behaviour in situations like these, before relying on it. +If Altitude Hold is enabled as an emergency response to a rapid drop, or if the quad is climbing really fast, there will be overshoot, and often a bounce-back. The code cannot stop the quad instantly, but it should return to the initiation point within a few seconds. It's wise to check behaviour in situations like these, before relying on it. -Altitude Hold can be enabled while inverted, the quad just flips over and should stay at that height. +Altitude Hold can be enabled while inverted, the quad just flips over, and should stay at that height. While in Altitude Hold mode, the aircraft will enter Angle Mode. If Position Hold is not simultaneously enabled, Roll, Pitch and Yaw work normally - only the altitude is controlled. @@ -58,23 +58,29 @@ Position Hold should be enabled at the same time as Altitude Hold, by configurin When enabled together, both the altitude, and the position of the quad, should be held constant. The aircraft will enter Angle Mode, and should quickly stop, then hover at the location it stops at. -Typically the aircraft should hover within 1-2m of the target location, depending mostly on the consistency of the GPS signal, how windy it is, and how the PIDs are optimised. More aggressive PIDs will hold position better, but will result in lots of rapid small responses. Less aggressive PIDs will be smoother, but slower in response. +After stopping, the aircraft should stay within 1-2m of the target location, depending on the accuracy of the GPS signal, how windy it is, and how the PIDs are optimised. More aggressive PIDs will hold position better, but will result in lots of rapid small responses. Less aggressive PIDs will be smoother, but slower in response. Position Hold requires a good GPS signal, and works best when an accurately calibrated and fully working Magnetometer is enabled. -With a Magnetometer, accurate Position Hold is available immediately after takeoff. In contrast, when there is no Magnetometer, Position Hold **will not work** until the aircraft has been flown in a straight line, pitched forward, at a decent speed, for at least several seconds. The warning message `POSHOLD FAIL` will appear in the OSD in this case. +With a Magnetometer, accurate Position Hold is available immediately after takeoff. + +In contrast, when there is no Magnetometer, Position Hold **will not work** until the aircraft has been flown in a straight line, pitched forward, at a decent speed, for at least several seconds. The warning message `POSHOLD FAIL` will appear in the OSD in this case. :::caution -If the Magnetometer returns false heading information, or if the GPS heading has become messed up, enabling Position Hold may cause the aircraft to tilt a lot, and fly away at speed! +If the Magnetometer returns false heading information, or if the GPS heading has become messed up, enabling Position Hold may cause the aircraft to tilt a lot, circle around, or even fly away at speed! ::: :::note For information on setting up a Magnetometer, see the [Betaflght.com wiki](https://betaflight.com/docs/wiki/guides/current/magnetometer). ::: -While in Position Hold, the target position can be adjusted using Roll and Pitch inputs that exceed `pos_hold_deadband`. The quad can then be moved around, and even flown, using the sticks, a bit like normal Angle Mode, especially if the deadband is set to a low value. However it will always stop quite hard when the sticks are re-centered. The deadband can be adjusted in the CLI with the `pos_hold_deadband` value, in percent stick distance out from centre, to suite your requirements. If `pos_hold_deadband` is set to zero, pitch and roll inputs will be completely ignored; the quad's location will be locked until the switch is reverted. +While in Position Hold, the target position can be adjusted using Roll and Pitch inputs that exceed `pos_hold_deadband`. The quad can then be moved around, and even flown, using the sticks, a bit like normal Angle Mode, especially if the deadband is set to a low value. The deadband can be adjusted in the CLI with the `pos_hold_deadband` value, in percent stick distance out from centre, to suite your requirements. If `pos_hold_deadband` is set to zero, pitch and roll inputs will be completely ignored; the quad's location will be locked until the switch is reverted. + +Stick responsiveness will be significantly less than in normal angle mode. The maximum angle that the pilot can command is half the `autopilot_max_angle` value, which itself defaults to 50 degrees. + +The aircraft will stop quite hard when the sticks are re-centered, especially if it is moving at speed. For example, if the quad is moving at 10-15m/s forwards, the aircraft may apply the maximum default 50 degrees of pitch back to arrest forward speed. To get a smoother stop from speed, slow the aircraft down using the sticks before recentering them. -If the quad is carrying speed when Position Hold is initiated by returning sticks quickly to centre, there will be a strong pitch or roll response to stop the aircraft's movement as quickly as possible. To get a smoother stop from speed, slow the aircraft down using the sticks before recentering them. +The `autopilot_max_angle` value may be increased to 70 degrees if more aggressive flight behaviours are needed. If both Position Hold and Altitude Hold are working, and failsafe is set to `landing mode`, the quad will enter a controlled descent phase at the current position, without drifting or falling. This is much nicer than the old method. GPS Rescue mode is still preferred over `landing mode`, for failsafe, and will take precedence over Position Hold. @@ -82,17 +88,21 @@ If both Position Hold and Altitude Hold are working, and failsafe is set to `lan - `pos_hold_without_mag = true` : permits Position Hold without a Magnetometer - `pos_hold_deadband` : the deadband around center stick position, default is 5%. If set to zero, sticks will be ignored. Smaller deadbands are nicer for adjusting position or flying around. -- `autopilot_position_P` : the P value for position hold. THere are also values for pid D, I and A values, where A is 'Acceleration'. Defaults are all 30. When too high, the quad will oscillate. When too low, control is loose. Take care when adjusting these, adjust them one at a time to learn what they do. +- `autopilot_max_angle` : the maximum angle that the autopilot code can apply to the aircraft during a hard stop. Default is 50 degrees, max is 70. The maximum angle the pilot can command is half this value. +- `autopilot_position_P` : the P value for position hold. There are also values for pid D, I and A values, where A is 'Acceleration'. Defaults are all 30. When too high, the quad will oscillate. When too low, control is loose. Take care when adjusting these, adjust them one at a time to learn what they do. - `autopilot_position_cutoff` : a smoothing filter applied to the PID D and A values. Default is 80, or 0.8Hz. There is still some jittering around like this. 50 is a lot smoother, but leads to vagueness in position control. 200 is very jittery. You choose. - `gyro_filter_debug_axis` : selects whether Pitch or Roll distances and PIDs are logged to the `autopilot_position` debug. ### Pre-flight checks -- If using a Magnetometer, validate the heading carefully with Configurator's home screen. It doesn't have to be perfect, but must show heading correctly, within an error of about 20 degrees, at pitch angles +/- 60 degrees. Check vs a mobile phone that it reads close to zero when the aircraft points North, near 90 when East, 180 when South, etc. -- Hover in Angle mode and confirm that the Acc is calibrated and the hover is stable. Sticks can be used to fine-tune a dead flat hover. -- First test Altitude Hold alone, and check that there is no immediate drop, or climb in height, the moment you engage Altitude Hold. Adjust `hover_throttle` until altitude doesn't abruptly change when Altitude Hold is engaged. Check that you can adjust altitude while in Altitude Hold using throttle, up or down. -- Make sure you have lots of GPS sats, arm, go to Angle mode, hover a couple of meters in the air, LOS and engage both Altitude Hold and Position Hold at the same time. Be ready to undo the Position Hold switch or disarm immediately. The aircraft should just stay where it is. Expect that it may drift around a bit, and go up and down a bit, within about a 1m radius. -- If it immediately flys off at a bad angle, or circles around vaguely, then the heading information from either Mag or GPS is bad. +- If using a Magnetometer, validate the heading carefully with Configurator's home screen. Check by comparing the heading value against the compass on a mobile phone. The Mag should reads close to zero when the aircraft points North, near 90 when East, 180 when South, etc.It doesn't have to be perfect, but should have an error of less than 20 degrees. Check it remains accurate at pitch angles +/- 60 degrees. +- Hover in Angle mode and confirm that the Acc is calibrated and the hover is stable. Sticks can be used to fine-tune to a perfect hover. +- Test Altitude Hold first, alone, and check that there is no immediate drop, or climb in height, the moment you engage Altitude Hold. Adjust `hover_throttle` until altitude doesn't abruptly change when Altitude Hold is engaged. Practice adjusting altitude up or down using throttle. +- Then enable Position Hold on the same Mode switch. Make sure you have lots of GPS sats. +- If the aircraft does not have a Mag, it must be flown straight ahead, at some decent speed, with zero roll or yaw input, for at least 50-100m, sometimes more, until the home arrow points straight up when you are flying directly towards home. This 'calibrates' the heading of the craft to the GPS heading information. Unless this is done, Position Hold will not be available, and will not work. +- If the aircraft has a Mag, there is no need to worry about flying forward; Position Hold can be used from the moment you take off. +- When you're ready to test Position Hold, hover a couple of meters in the air, LOS and engage both Altitude Hold and Position Hold at the same time. Be ready to undo the Position Hold switch or disarm immediately. The aircraft should just stay where it is. It may drift around within about a 1m radius. +- If it immediately flys off at a bad angle, or circles around vaguely, then the heading information from either Mag or GPS is bad. If you have no Mag, try flying straight again for 50-100m at a decent speed, with no roll or yaw input. - If it shakes a lot or oscillates, the PIDs are too high. - Confirm that you can adjust the position using the Roll and Pitch sticks. Do this cautiously and gently. It will not feel 'normal'. When you want to slow down, do so 'gently', or manually wash the speed off by reversing your pitch input before entering the sticks. Otherwise, sudden stops at high speed will cause abrupt pitch changes, because the quad will try to stop as quickly as possible. - Get a good feel for the 'control' over position hold with LOS flying before using it FPV. @@ -102,14 +112,14 @@ If both Position Hold and Altitude Hold are working, and failsafe is set to `lan - The aircraft cannot be armed in Position Hold or Altitude Hold. - Position Hold will not work: - if there is no GPS 3D fix. - - when a Mag is required, but the Mag is 'not healthy', ie broken, or has never been calibrated. - - a Mag is not required, but the GPS has not yet provided a workable heading because the aircraft has not been flown cleanly pitched forward for long enough, or not fast enough -- A `POS HOLD FAIL` message will appear in the OSD if Position Hold is attempted but any of the above checks fail. + - if there is no Mag, and the GPS has not yet provided a workable heading because the aircraft has not been flown cleanly pitched forward for long enough, or not fast enough + - when there is a Mag, and it is needed because the GPS Heading is not available as a fallback (see above), or the Mag is 'not healthy', ie broken, or has never been calibrated. +- A `POS HOLD FAIL` message will appear in the OSD if Position Hold is attempted and any of the above checks fail. - By default, Mag is required. The pilot can permit Pos Hold without Mag only with `set pos_hold_without_mag = true` -- If `pos_hold_without_mag` is set to true, and there is no Mag, Position Hold will not be available immediately after takeoff, and will not be permitted until the GPS has provided a useful heading. The user must fly in a straight line with a solid pitch forward angle, and no yaw or roll, for several seconds at least, to orient the IMU to the GPS. Until that orientation takes place, Position Hold will not initiate, and show the failure warning, when the switch is set. +- If `pos_hold_without_mag` is set to true, and there is no Mag, Position Hold will not be available immediately after takeoff, and will not be permitted until the GPS has provided a useful heading. The user must fly in a straight line with a solid pitch forward angle, and no roll or yaw input, for several seconds at least, to orient the IMU to the GPS. Until that orientation takes place, Position Hold will not initiate, and will show the failure warning in the OSD. - If the craft is armed, and then Position Hold is enabled, the OSD flight mode will show `POSH`, the quad will start Angle Mode and wait for throttle to be raised. Once the throttle is raised, the aircraft should lift off, and once it is about 1m up in the air, Position Hold will engage. - There is a simple sanity check that will terminate Position Hold if it cannot stay within 10m of the start point. The distance is increased if the quad is moving fast when initiated. -- GPS Rescue will override Position Hold. +- GPS Rescue will override Position Hold and should work normally. :::caution If Position Hold is enabled quickly after power up, when the GPS fix is poor, both altitude and position control can be erratic. A good GPS position fix, with stable altitude and position values, is essential for Position Hold. @@ -146,4 +156,4 @@ These pidSums are converted to a single vector pointing in the direction needed When the sticks are outside deadband, control is passed to the normal Angle Mode controller, and the pilot flies completely in Angle Mode, which feels pretty good. The location, velocity and acceleration values are checked while you fly around. When the sticks return inside deadband, Position Hold is restored with a temporary target at that point, in a special 'stopping' phase, with greater D than normal. The PIDs then actively stop the movement. When the quad finally comes to a stop, we re-set the location at the stop point for that axis, and the quad stays there. -draft v1 +draft v1.1