mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-18 06:38:29 -04:00
AP_Motors: add scripting dynamic mixer, allowing varable geometry vehicles
This commit is contained in:
parent
015b971ccb
commit
6848cbc241
@ -12,3 +12,4 @@
|
|||||||
#include "AP_MotorsTailsitter.h"
|
#include "AP_MotorsTailsitter.h"
|
||||||
#include "AP_Motors6DOF.h"
|
#include "AP_Motors6DOF.h"
|
||||||
#include "AP_MotorsMatrix_6DoF_Scripting.h"
|
#include "AP_MotorsMatrix_6DoF_Scripting.h"
|
||||||
|
#include "AP_MotorsMatrix_Scripting_Dynamic.h"
|
||||||
|
@ -30,7 +30,7 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
// init
|
// init
|
||||||
void init(motor_frame_class frame_class, motor_frame_type frame_type) override;
|
virtual void init(motor_frame_class frame_class, motor_frame_type frame_type) override;
|
||||||
|
|
||||||
#ifdef ENABLE_SCRIPTING
|
#ifdef ENABLE_SCRIPTING
|
||||||
// Init to be called from scripting
|
// Init to be called from scripting
|
||||||
@ -61,7 +61,7 @@ public:
|
|||||||
bool output_test_num(uint8_t motor, int16_t pwm);
|
bool output_test_num(uint8_t motor, int16_t pwm);
|
||||||
|
|
||||||
// output_to_motors - sends minimum values out to the motors
|
// output_to_motors - sends minimum values out to the motors
|
||||||
void output_to_motors() override;
|
virtual void output_to_motors() override;
|
||||||
|
|
||||||
// get_motor_mask - returns a bitmask of which outputs are being used for motors (1 means being used)
|
// get_motor_mask - returns a bitmask of which outputs are being used for motors (1 means being used)
|
||||||
// this can be used to ensure other pwm outputs (i.e. for servos) do not conflict
|
// this can be used to ensure other pwm outputs (i.e. for servos) do not conflict
|
||||||
|
128
libraries/AP_Motors/AP_MotorsMatrix_Scripting_Dynamic.cpp
Normal file
128
libraries/AP_Motors/AP_MotorsMatrix_Scripting_Dynamic.cpp
Normal file
@ -0,0 +1,128 @@
|
|||||||
|
/*
|
||||||
|
This program is free software: you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Public License as published by
|
||||||
|
the Free Software Foundation, either version 3 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License
|
||||||
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
#ifdef ENABLE_SCRIPTING
|
||||||
|
|
||||||
|
// This allows motor roll, pitch, yaw and throttle factors to be changed in flight, allowing vehicle geometry to be changed
|
||||||
|
|
||||||
|
#include "AP_MotorsMatrix_Scripting_Dynamic.h"
|
||||||
|
#include <GCS_MAVLink/GCS.h>
|
||||||
|
#include <AP_HAL/AP_HAL.h>
|
||||||
|
|
||||||
|
extern const AP_HAL::HAL& hal;
|
||||||
|
|
||||||
|
#define debug_print 0
|
||||||
|
|
||||||
|
// add a motor and give its testing order
|
||||||
|
bool AP_MotorsMatrix_Scripting_Dynamic::add_motor(uint8_t motor_num, uint8_t testing_order)
|
||||||
|
{
|
||||||
|
if (initialised_ok()) {
|
||||||
|
// no adding motors after init
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (motor_num < AP_MOTORS_MAX_NUM_MOTORS) {
|
||||||
|
_test_order[motor_num] = testing_order;
|
||||||
|
motor_enabled[motor_num] = true;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
void AP_MotorsMatrix_Scripting_Dynamic::load_factors(const factor_table &new_table)
|
||||||
|
{
|
||||||
|
WITH_SEMAPHORE(_sem);
|
||||||
|
had_table = true;
|
||||||
|
|
||||||
|
memcpy(_roll_factor,new_table.roll,sizeof(_roll_factor));
|
||||||
|
memcpy(_pitch_factor,new_table.pitch,sizeof(_pitch_factor));
|
||||||
|
memcpy(_yaw_factor,new_table.yaw,sizeof(_yaw_factor));
|
||||||
|
memcpy(_throttle_factor,new_table.throttle,sizeof(_throttle_factor));
|
||||||
|
|
||||||
|
#if debug_print
|
||||||
|
hal.console->printf("Got new factors:\n");
|
||||||
|
for (uint8_t i = 0; i < AP_MOTORS_MAX_NUM_MOTORS; i++) {
|
||||||
|
if (motor_enabled[i]) {
|
||||||
|
hal.console->printf("%i - Roll: %0.2f, Pitch %0.2f, Yaw: %0.2f, throttle %0.2f\n",i,_roll_factor[i],_pitch_factor[i],_yaw_factor[i],_throttle_factor[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
bool AP_MotorsMatrix_Scripting_Dynamic::init(uint8_t expected_num_motors)
|
||||||
|
{
|
||||||
|
WITH_SEMAPHORE(_sem);
|
||||||
|
|
||||||
|
// Check factors have been set
|
||||||
|
if (!had_table) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Make sure the correct number of motors have been added
|
||||||
|
uint8_t num_motors = 0;
|
||||||
|
for (uint8_t i = 0; i < AP_MOTORS_MAX_NUM_MOTORS; i++) {
|
||||||
|
if (motor_enabled[i]) {
|
||||||
|
num_motors++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
set_initialised_ok(expected_num_motors == num_motors);
|
||||||
|
|
||||||
|
if (!initialised_ok()) {
|
||||||
|
_mav_type = MAV_TYPE_GENERIC;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
switch (num_motors) {
|
||||||
|
case 3:
|
||||||
|
_mav_type = MAV_TYPE_TRICOPTER;
|
||||||
|
break;
|
||||||
|
case 4:
|
||||||
|
_mav_type = MAV_TYPE_QUADROTOR;
|
||||||
|
break;
|
||||||
|
case 6:
|
||||||
|
_mav_type = MAV_TYPE_HEXAROTOR;
|
||||||
|
break;
|
||||||
|
case 8:
|
||||||
|
_mav_type = MAV_TYPE_OCTOROTOR;
|
||||||
|
break;
|
||||||
|
case 10:
|
||||||
|
_mav_type = MAV_TYPE_DECAROTOR;
|
||||||
|
break;
|
||||||
|
case 12:
|
||||||
|
_mav_type = MAV_TYPE_DODECAROTOR;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
_mav_type = MAV_TYPE_GENERIC;
|
||||||
|
}
|
||||||
|
|
||||||
|
set_update_rate(_speed_hz);
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
// output - sends commands to the motors,
|
||||||
|
// Need to take the semaphore to enasure the motor factors are not changed during the mixer calculation
|
||||||
|
void AP_MotorsMatrix_Scripting_Dynamic::output_to_motors()
|
||||||
|
{
|
||||||
|
WITH_SEMAPHORE(_sem);
|
||||||
|
|
||||||
|
// call the base class ouput function
|
||||||
|
AP_MotorsMatrix::output_to_motors();
|
||||||
|
}
|
||||||
|
|
||||||
|
// singleton instance
|
||||||
|
AP_MotorsMatrix_Scripting_Dynamic *AP_MotorsMatrix_Scripting_Dynamic::_singleton;
|
||||||
|
|
||||||
|
#endif // ENABLE_SCRIPTING
|
65
libraries/AP_Motors/AP_MotorsMatrix_Scripting_Dynamic.h
Normal file
65
libraries/AP_Motors/AP_MotorsMatrix_Scripting_Dynamic.h
Normal file
@ -0,0 +1,65 @@
|
|||||||
|
#pragma once
|
||||||
|
#ifdef ENABLE_SCRIPTING
|
||||||
|
|
||||||
|
#include "AP_MotorsMatrix.h"
|
||||||
|
|
||||||
|
class AP_MotorsMatrix_Scripting_Dynamic : public AP_MotorsMatrix {
|
||||||
|
public:
|
||||||
|
|
||||||
|
// Constructor
|
||||||
|
AP_MotorsMatrix_Scripting_Dynamic(uint16_t loop_rate, uint16_t speed_hz = AP_MOTORS_SPEED_DEFAULT) :
|
||||||
|
AP_MotorsMatrix(loop_rate, speed_hz)
|
||||||
|
{
|
||||||
|
if (_singleton != nullptr) {
|
||||||
|
AP_HAL::panic("AP_MotorsMatrix_Scripting_Dynamic must be singleton");
|
||||||
|
}
|
||||||
|
_singleton = this;
|
||||||
|
};
|
||||||
|
|
||||||
|
// get singleton instance
|
||||||
|
static AP_MotorsMatrix_Scripting_Dynamic *get_singleton() {
|
||||||
|
return _singleton;
|
||||||
|
}
|
||||||
|
|
||||||
|
struct factor_table {
|
||||||
|
float roll[AP_MOTORS_MAX_NUM_MOTORS];
|
||||||
|
float pitch[AP_MOTORS_MAX_NUM_MOTORS];
|
||||||
|
float yaw[AP_MOTORS_MAX_NUM_MOTORS];
|
||||||
|
float throttle[AP_MOTORS_MAX_NUM_MOTORS];
|
||||||
|
};
|
||||||
|
|
||||||
|
// base class method must not be used
|
||||||
|
void init(motor_frame_class frame_class, motor_frame_type frame_type) override {};
|
||||||
|
|
||||||
|
// Init to be called from scripting
|
||||||
|
bool init(uint8_t expected_num_motors) override;
|
||||||
|
|
||||||
|
// add a motor and give its testing order
|
||||||
|
bool add_motor(uint8_t motor_num, uint8_t testing_order);
|
||||||
|
|
||||||
|
// add a interpolation point table
|
||||||
|
void load_factors(const factor_table &table);
|
||||||
|
|
||||||
|
// output - sends commands to the motors
|
||||||
|
void output_to_motors() override;
|
||||||
|
|
||||||
|
const char* get_frame_string() const override { return "Dynamic Matrix"; }
|
||||||
|
|
||||||
|
protected:
|
||||||
|
|
||||||
|
// Do not apply thrust compensation, this is used by Quadplane tiltrotors
|
||||||
|
// assume the compensation is done in the mixer and should not be done by quadplane
|
||||||
|
void thrust_compensation(void) override {};
|
||||||
|
|
||||||
|
private:
|
||||||
|
|
||||||
|
// True when received a factors table, will only init having received a table
|
||||||
|
bool had_table;
|
||||||
|
|
||||||
|
// For loading of new factors, cannot load while in use
|
||||||
|
HAL_Semaphore _sem;
|
||||||
|
|
||||||
|
static AP_MotorsMatrix_Scripting_Dynamic *_singleton;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // ENABLE_SCRIPTING
|
@ -47,6 +47,7 @@ public:
|
|||||||
MOTOR_FRAME_DECA = 14,
|
MOTOR_FRAME_DECA = 14,
|
||||||
MOTOR_FRAME_SCRIPTING_MATRIX = 15,
|
MOTOR_FRAME_SCRIPTING_MATRIX = 15,
|
||||||
MOTOR_FRAME_6DOF_SCRIPTING = 16,
|
MOTOR_FRAME_6DOF_SCRIPTING = 16,
|
||||||
|
MOTOR_FRAME_DYNAMIC_SCRIPTING_MATRIX = 17,
|
||||||
};
|
};
|
||||||
|
|
||||||
// return string corresponding to frame_class
|
// return string corresponding to frame_class
|
||||||
|
Loading…
Reference in New Issue
Block a user