mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-25 10:08:28 -04:00
61c910b08b
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.
65 lines
2.5 KiB
Markdown
65 lines
2.5 KiB
Markdown
# 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. |