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.
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:
- Set
FRAME_CLASS
orQ_FRAME_CLASS
(for quadplanes) to 17 to enable the dynamic scriptable mixer. - Enable Lua scripting via the
SCR_ENABLE
parameter. - Reboot.
- Fly the vehicle.
- Adjust the value of the
CGA_RATIO
parameter. A good indicator of a good tune is to monitor the telemetry valuePID_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:
- Set
FRAME_CLASS
orQ_FRAME_CLASS
(for quadplanes) to 15 to enable the static scriptable mixer. - Ensure Lua scripting is enabled via the
SCR_ENABLE
parameter. - 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
- 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.
- The parameter
CGA_RATIO
is used to alter these coefficients, so that the front and back thrust commands are not equal.