Ardupilot2/libraries/AP_Scripting/applets/x-quad-cg-allocation.md
George Zogopoulos 61c910b08b AP_Scripting: Added script for Quad-X CoM compensation
The script uses the scripting matrix to produce non-equal
front and back thrust, compensating for the lever arm between the center
of thrust and the center of mass.
2024-07-03 18:44:36 +10:00

2.5 KiB

Multicopter CoM compensation

This script allows for adjusting the control allocation matrix.

When the Center of Mass (CoM) of an airframe does not coincide with the center of its thrusters, then there is a lever arm between the thrust vector and the CoM. This often is the case in VTOL fixed-wing aircraft (quadplanes) where typically the CoM is more forward than the center of thrust. As a result, the thrust produces a pitch-down moment. This produces a disturbance in the pitch control and requires significant wind-up in the pitch integrator.

To compensate for this issue, this script employs the scriptable control allocation matrix to request asymmeterical front and back thrust.

WARNING: This script is applicable only to X-type quadrotors and quadplanes. Do not use in any other frame configuration!

Parameters

The script adds 1 parameter to control its behaviour.

CGA_RATIO

This is the desired ratio between the front and back thrust. To have the front motors produce more lift that the rear, increase higher than 1.

Reasonable extreme values are 2 (front works twice as hard as the rear) and 0.5 (the inverse case). Given an out-of-bounds parameter value, the script will revert to the default 1.0.

Operation

How To Use

First of all, place this script in the "scripts" directory.

To tune CGA_RATIO on the fly:

  1. Set FRAME_CLASS or Q_FRAME_CLASS (for quadplanes) to 17 to enable the dynamic scriptable mixer.
  2. Enable Lua scripting via the SCR_ENABLE parameter.
  3. Reboot.
  4. Fly the vehicle.
  5. Adjust the value of the CGA_RATIO parameter. A good indicator of a good tune is to monitor the telemetry value PID_TUNE[2].I (pitch rate controller integrator) until it reaches zero during a stable hover.

Once you are happy with the tuning, you can fall back to the static motor matrix, which consumes no resources from the scripting engine:

  1. Set FRAME_CLASS or Q_FRAME_CLASS (for quadplanes) to 15 to enable the static scriptable mixer.
  2. Ensure Lua scripting is enabled via the SCR_ENABLE parameter.
  3. Reboot.

The aircraft is ready to fly. Keep in mind that any further changes to CGA_RATIO will now require a reboot.

How It Works

  1. The dynamic control allocation matrix is able to change the coefficients that convert the throttle command to individual PWM commands for every motor. These coefficients have a default value of 1.
  2. The parameter CGA_RATIO is used to alter these coefficients, so that the front and back thrust commands are not equal.