Skip to content

Configuration/Tuning (Ackermann Rover)

This topic provides a step-by-step guide for setting up your Ackermann rover.

Successive steps enable drive modes with more autopilot support and features.

WARNING

Each step is dependent on the previous steps having been completed. Modes will only work properly if the preceding modes have been configured.

Basic Setup

To configure the Ackermann rover frame and outputs:

  1. Enable Rover support by flashing the PX4 rover build onto your flight controller. Note that this is a special build that contains rover-specific modules.

  2. In the Airframe configuration select the Generic Rover Ackermann:

    QGC screenshot showing selection of the airframe 'Generic ackermann rover'

    Select the Apply and Restart button.

    INFO

    If this airframe is not displayed and you have checked that you are using rover firmware (not the default), you can alternatively enable this frame by setting the SYS_AUTOSTART parameter to 51000.

:::

  1. Open the Actuators Configuration & Testing to map the steering and throttle functions to flight controller outputs.

手动模式

WARNING

For this mode to work properly the Basic Setup must've already been completed!

The basic setup already covers the minimum setup required to use the rover in Manual mode.

This mode is also affected by (optional) acceleration/deceleration limits. As configuration of these limits becomes mandatory for subsequent modes, we do this setup here.

Navigate to Parameters in QGroundControl and set the following parameters:

  1. RA_WHEEL_BASE [m]: Measure the distance from the back to the front wheels.

  2. RA_MAX_STR_ANG [deg]: Measure the maximum steering angle.

    Geometric parameters

  3. RO_MAX_THR_SPEED [m/s]: Drive the rover at full throttle and set this parameter to the observed value of the ground speed.

    INFO

    This parameter is also used for the feed-forward term of the speed control. It will be further tuned in the configuration of Position mode.

:::

  1. (Optional) RO_ACCEL_LIM [m/s^2]: Maximum acceleration you want to allow for your rover.

    TIP

    Your rover has a maximum possible acceleration which is determined by the maximum torque the motor can supply. This may or may not be appropriate for your vehicle and use case.

    One approach to determine an appropriate value is:

    1. From a standstill, give the rover full throttle until it reaches the maximum speed.
    2. Disarm the rover and plot the measured_speed_body_x from RoverVelocityStatus.
    3. Divide the maximum speed by the time it took to reach it and set this as the value for RO_ACCEL_LIM.

    Some RC rovers have enough torque to lift up if the maximum acceleration is not limited. If that is the case:

    1. Set RO_ACCEL_LIM to a low value, give the rover full throttle from a standstill and observe its behaviour.
    2. Increase RO_ACCEL_LIM until the rover starts to lift up during the acceleration.
    3. Set RO_ACCEL_LIM to the highest value that does not cause the rover to lift up.

:::

  1. (Optional) RO_DECEL_LIM [m/s^2]: Maximum deceleration you want to allow for your rover.

    TIP

    The same considerations as in the configuration of RO_ACCEL_LIM apply.

:::

INFO

This parameter is also used for the calculation of the speed setpoint during Auto modes.

  1. (Optional) RA_STR_RATE_LIM [deg/s]: Maximum steering rate you want to allow for your rover.

    TIP

    This value depends on your rover and use case. For bigger rovers there might be a mechanical limit that is easy to identify by steering the rover at a standstill and increasing RA_STR_RATE_LIM until you observe the steering rate to no longer be limited by the parameter. For smaller rovers you might observe the steering to be too aggressive. Set RA_STR_RATE_LIM to a low value and steer the rover at a standstill. Increase the parameter until you reach the maximum steering rate you are comfortable with.

:::

WARNING

A low maximum steering rate makes the rover worse at tracking steering setpoints, which can lead to a poor performance in the subsequent modes.

Acro Mode

WARNING

For this mode to work properly Manual mode must've already been configured!

To set up Acro mode configure the following parameters in QGroundControl:

  1. RO_YAW_RATE_LIM: Maximum yaw rate you want to allow for your rover.

    TIP

    Limiting the yaw rate is necessary if the rover is prone rolling over, loosing traction at high speeds or if passenger comfort is important. Small rovers especially can be prone to rolling over when steering aggressively at high speeds.

    If this is the case:

    1. In Acro mode, set RO_YAW_RATE_LIM to a small value and drive the rover at full throttle and with the right stick all the way to the left or right.
    2. Increase RO_YAW_RATE_LIM until the wheels of the rover start to lift up.
    3. Set RO_YAW_RATE_LIM to the highest value that does not cause the rover to lift up.

    If you see no need to limit the yaw rate, set this parameter to the maximum yaw rate the rover can achieve:

    1. In Manual mode drive the rover at full throttle and with the maximum steering angle.
    2. Plot the measured_yaw_rate from RoverRateStatus and enter the highest observed value for RO_YAW_RATE_LIM.

:::

  1. RO_YAW_RATE_P [-]: Proportional gain of the closed loop yaw rate controller. The closed loop acceleration control will compare the yaw rate setpoint with the measured yaw rate and adapt the motor commands based on the error between them. The proportional gain is multiplied with this error and that value is added to the motor command. This compensates for disturbances such as uneven ground and external forces.

    TIP

    To tune this parameter:

    1. Put the rover in Acro mode and hold the throttle stick and the right stick at a few different levels for a couple of seconds each.
    2. Disarm the rover and from the flight log plot the adjusted_yaw_rate_setpoint from RoverRateStatus and the measured_yaw_rate from RoverRateStatus over each other.
    3. Increase RO_YAW_RATE_P if the measured value does not track the setpoint fast enough or decrease it if the measurement overshoots the setpoint by too much.
    4. Repeat until you are satisfied with the behaviour.

:::

  1. RO_YAW_RATE_I [-]: Integral gain of the closed loop yaw rate controller. The integral gain accumulates the error between the desired and actual yaw rate scaled by the integral gain over time and that value is added to the motor command.

    TIP

    An integrator might not be necessary at this stage, but it will become important for subsequent modes.

:::

The rover is now ready to drive in Acro mode.

Stabilized Mode

WARNING

For this mode to work properly Acro mode must've already been configured!

For Stabilized mode the controller utilizes a closed loop yaw controller, which creates a yaw rate setpoint to control the yaw when it is active:

Cascaded PID for yaw control

Unlike the closed loop yaw rate, this controller has no feed-forward term. Therefore you only need to tune the closed loop gains:

  1. RO_YAW_P [-]: Proportional gain for the closed loop yaw controller.

    TIP

    In stabilized mode the closed loop yaw control is only active when driving a straight line (no yaw rate input). To tune it start with a value of 1 for RO_YAW_P. Put the rover into stabilized mode and move the left stick of your controller up to drive forwards. Disarm the rover and from the flight log plot the measured_yaw and the adjusted_yaw_setpoint from the RoverAttitudeStatus message over each other. Increase/Decrease the parameter until you are satisfied with the setpoint tracking.

:::

INFO

For the closed loop yaw control an integrator gain is useful because this setpoint is often constant for a while and an integrator eliminates steady state errors that can cause the rover to never reach the setpoint. Since the yaw and yaw rate controllers are cascaded, there only needs to be one integrator which is in the yaw rate controller. If you observe a steady state error in the yaw setpoint increase the RO_YAW_RATE_I parameter.

The rover is now ready to drive in Stabilized mode.

Position Mode

WARNING

For this mode to work properly Stabilized mode must already be configured!

Position mode is the most advanced manual mode, utilizing closed loop yaw rate and speed control and leveraging position estimates.

To configure set the following parameters:

  1. RO_SPEED_LIM [m/s]: This is the maximum speed you want to allow for your rover. This will define the stick-to-speed mapping for position mode and set an upper limit for the speed setpoint for all auto modes.

  2. RO_MAX_THR_SPEED [m/s]: This parameter is used to calculate the feed-forward term of the closed loop speed control which linearly maps desired speeds to normalized motor commands. As mentioned in the Manual mode configuration , a good starting point is the observed ground speed when the rover drives at maximum throttle in Manual mode.

    TIP

    To further tune this parameter:

    1. Set RO_SPEED_P and RO_SPEED_I to zero. This way the speed is only controlled by the feed-forward term, which makes it easier to tune.
    2. Put the rover in Position mode and then move the left stick of your controller up and/or down and hold it at a few different levels for a couple of seconds each.
    3. Disarm the rover and from the flight log plot the adjusted_speed_body_x_setpoint and the measured_speed_body_x from the RoverVelocityStatus message over each other.
    4. If the actual speed of the rover is higher than the speed setpoint, increase RO_MAX_THR_SPEED. If it is the other way around decrease the parameter and repeat until you are satisfied with the setpoint tracking.

:::

INFO

If your rover oscillates when driving a straight line in Position mode, set this parameter to the observed ground speed at maximum throttle in Manual mode and complete steps 5-7 first before continuing the tuning of the closed loop speed control (Steps 2-4).

  1. RO_SPEED_P [-]: Proportional gain of the closed loop speed controller.

    TIP

    This parameter can be tuned the same way as RO_MAX_THR_SPEED. If you tuned RO_MAX_THR_SPEED well, you might only need a very small value.

:::

  1. RO_SPEED_I [-]: Integral gain for the closed loop speed controller.

    TIP

    For the closed loop speed control an integrator gain is useful because this setpoint is often constant for a while and an integrator eliminates steady state errors that can cause the rover to never reach the setpoint.

:::

  1. PP_LOOKAHD_GAIN: When driving in a straight line (right stick centered) position mode leverages the same path following algorithm used in auto modes called pure pursuit to achieve the best possible straight line driving behaviour (Illustration of control architecture). This parameter determines how aggressive the controller will steer towards the path.

    TIP

    Decreasing the parameter makes it more aggressive but can lead to oscillations.

    To tune this:

    1. Start with a value of 1 for PP_LOOKAHD_GAIN
    2. Put the rover in Position mode and while driving a straight line at approximately half the maximum speed observe its behaviour.
    3. If the rover does not drive in a straight line, reduce the value of the parameter, if it oscillates around the path increase the value.
    4. Repeat until you are satisfied with the behaviour.

:::

  1. PP_LOOKAHD_MIN: Minimum threshold for the lookahead distance used by the pure pursuit algorithm.

    TIP

    Put the rover in Position mode and drive at very low speeds, if the rover starts to oscillate even though the tuning of PP_LOOKAHD_GAIN was good for medium speeds, then increase the value of PP_LOOKAHD_MIN.

:::

  1. PP_LOOKAHD_MAX: Maximum threshold for the lookahead distance used by pure pursuit.

    TIP

    Put the rover in Position mode and drive at very high speeds, if the rover does not drive in a straight line even though the tuning of PP_LOOKAHD_GAIN was good for medium speeds, then decrease the value of PP_LOOKAHD_MAX.

:::

The rover is now ready to drive in Position mode.

Auto Modes

WARNING

For auto modes to work properly Manual Mode, Acro modeand Position mode must already be configured!

In auto modes the autopilot takes over navigation tasks using the following control architecture:

Pure Pursuit Controller

The required parameter configuration is discussed in the following sections.

Speed

  1. RO_DECEL_LIM [m/s^2] and RO_JERK_LIM [m/s^3] are used to calculate a speed trajectory such that the rover reaches the next waypoint with the correct cornering speed.

    TIP

    Plan a mission for the rover to drive a square and observe how it slows down when approaching a waypoint:

    • If the rover decelerates too quickly decrease the RO_DECEL_LIM parameter, if it starts slowing down too early increase the parameter.
    • If you observe a jerking motion as the rover slows down, decrease the RO_JERK_LIM parameter otherwise increase it as much as possible as it can interfere with the tuning of RO_DECEL_LIM.

    These two parameters have to be tuned as a pair, repeat until you are satisfied with the behaviour.

:::

  1. Plot the adjusted_speed_body_x_setpoint and measured_speed_body_x from the RoverVelocityStatus message over each other. If the tracking of these setpoints is not satisfactory adjust the values for RO_SPEED_P and RO_SPEED_I.

Corner Cutting

The module employs a special cornering logic causing the rover to "cut corners" to achieve a smooth trajectory. This is done by scaling the acceptance radius based on the corner the rover has to drive (for geometric explanation see Cornering logic).

Cornering Logic

The degree to which corner cutting is allowed can be tuned, or disabled, with the following parameters:

INFO

The corner cutting effect is a tradeoff between how close you get to the waypoint and the smoothness of the trajectory.

  1. NAV_ACC_RAD [m]: Default acceptance radius This is also used as a lower bound for the acceptance radius scaling.

  2. RA_ACC_RAD_MAX [m]: The maximum the acceptance radius can be scaled to. Set equal to NAV_ACC_RAD to disable the corner cutting effect.

  3. RA_ACC_RAD_GAIN [-]: This tuning parameter is a multiplicand on the calculated ideal acceptance radius to account for dynamic effects.

    TIP

    Initially set this parameter to 1. If you observe the rover overshooting the corner, increase this parameter until you are satisfied with the behaviour. Note that the scaling of the acceptance radius is limited by RA_ACC_RAD_MAX.

:::

Path Following

The pure pursuit algorithm is used to calculate a yaw rate setpoint for the vehicle that is then close loop controlled. The close loop yaw rate was tuned in the configuration of the Acro mode, and the pure pursuit was tuned when setting up the Position mode. During any auto navigation task observe the behaviour of the rover.

If you are unsatisfied with the path following, there are 2 steps to take:

  1. Plot the adjusted_yaw_rate_setpoint and the measured_yaw_rate from the RoverRateStatus over each other. If the tracking of these setpoints is not satisfactory adjust the values for RO_YAW_RATE_P and RO_YAW_RATE_I.
  2. Plot the adjusted_yaw_setpoint and the measured_yaw from the RoverAttitudeStatus over each other. If the tracking of these setpoints is not satisfactory adjust the value for RO_YAW_P and potentially further tune RO_YAW_RATE_I.
  3. Steps 1 and 2 ensures accurate setpoint tracking, if the path following is still unsatisfactory you need to further tune the pure pursuit parameters.

Pure Pursuit Guidance Logic

The desired yaw setpoints are generated using a pure pursuit algorithm.

The controller takes the intersection point between a circle around the vehicle and a line segment. In mission mode this line is usually constructed by connecting the previous and current waypoint.

Pure Pursuit Algorithm

The radius of the circle around the vehicle is used to tune the controller and is often referred to as look-ahead distance.

The look-ahead distance sets how aggressive the controller behaves and is defined as ld=vk. It depends on the velocity v of the rover and a tuning parameter k that can be set with the parameter PP_LOOKAHD_GAIN.

INFO

A lower value of PP_LOOKAHD_GAIN makes the controller more aggressive but can lead to oscillations!

The lookahead is constrained between PP_LOOKAHD_MAX and PP_LOOKAHD_MIN.

If the distance from the path to the rover is bigger than the lookahead distance, the rover will target the point on the path that is closest to the rover.

To summarize, the following parameters can be used to tune the controller:

参数描述Unit
PP_LOOKAHD_GAINMain tuning parameter-
PP_LOOKAHD_MAXMaximum value for the look ahead radiusm
PP_LOOKAHD_MINMinimum value for the look ahead radiusm

Mission Cornering Logic (Info only)

Corner Cutting Logic

To enable a smooth trajectory, the acceptance radius of waypoints is scaled based on the angle between a line segment from the current-to-previous and current-to-next waypoints. The ideal trajectory would be to arrive at the next line segment with the heading pointing towards the next waypoint. For this purpose the minimum turning circle of the rover is inscribed tangentially to both line segments.

Cornering Logic

The acceptance radius of the waypoint is set to the distance from the waypoint to the tangential points between the circle and the line segments:

rmin=Lsin(δmax)θ=12arccos(ab|a||b|)racc=rmintan(θ)
Symbol描述Unit
aVector from current to previous WPm
bVector from current to next WPm
rminMinimum turn radiusm
δmaxMaximum steer anglem
raccAcceptance radiusm

Cornering Speed

To smoothen the trajectory further and reduce the risk of the rover rolling over, the rover speed is regulated as follows:

  1. During cornering the rover drives at the following speed:

    vcor,max=ψ˙maxr

    with r: Turning radius for the upcoming corner and ψ˙max: Maximum yaw rate (RO_YAW_RATE_LIM).

  2. In between waypoints (straight line) the rover speed is regulated such that it will arrive at the acceptance radius of the waypoint with the desired cornering speed.

The rover is constrained between the maximum speed RO_SPEED_LIM and the speed where the maximum steering angle does not cause the rover to exceed the yaw rate limit:

vmin=wbψ˙maxtan(δmax)

with wb: Wheel base (RA_WHEEL_BASE), ψ˙max: Maximum yaw rate (RO_YAW_RATE_LIM) and δmax: Maximum steering angle (RA_MAX_STR_ANG).

Parameter Overview

List of all parameters of the ackermann rover module:

参数描述Unit
RA_WHEEL_BASEWheel basem
RA_MAX_STR_ANGMaximum steering angledeg
RO_MAX_THR_SPEEDSpeed the rover drives at maximum throttlem/s
RO_YAW_RATE_LIMMaximum allowed yaw ratem/s^2
RO_YAW_RATE_PProportional gain for yaw rate controller-
RO_YAW_RATE_IIntegral gain for yaw rate controller-
RO_YAW_PProportional gain for yaw controller-
RO_SPEED_LIMMaximum allowed speedm/s
RO_SPEED_PProportional gain for speed controller-
RO_SPEED_IIntegral gain for speed controller-
PP_LOOKAHD_GAINMain tuning parameter for pure pursuit-
PP_LOOKAHD_MAXMaximum value for the look ahead radius of the pure pursuit algorithmm
PP_LOOKAHD_MINMinimum value for the look ahead radius of the pure pursuit algorithmm
NAV_ACC_RADDefault acceptance radiusm
RA_STR_RATE_LIM(Optional) Maximum allowed steering ratedeg/s
RO_ACCEL_LIM(Optional) Maximum allowed accelerationm/s^2
RO_DECEL_LIM(Optional) Maximum allowed decelerationm/s^2
RO_JERK_LIM(Optional) Maximum allowed jerkm/s3
RA_ACC_RAD_MAX(Optional) Maximum radius the acceptance radius can be scaled tom
RA_ACC_RAD_GAIN(Optional) Tuning parameter for the acceptance radius scaling-

See Also