mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-06 07:58:28 -04:00
Copter: add 6DoF support
This commit is contained in:
parent
f490c9d799
commit
d6fa4d97e3
@ -42,6 +42,7 @@
|
|||||||
#include <AP_AHRS/AP_AHRS.h>
|
#include <AP_AHRS/AP_AHRS.h>
|
||||||
#include <AP_Mission/AP_Mission.h> // Mission command library
|
#include <AP_Mission/AP_Mission.h> // Mission command library
|
||||||
#include <AC_AttitudeControl/AC_AttitudeControl_Multi.h> // Attitude control library
|
#include <AC_AttitudeControl/AC_AttitudeControl_Multi.h> // Attitude control library
|
||||||
|
#include <AC_AttitudeControl/AC_AttitudeControl_Multi_6DoF.h> // 6DoF Attitude control library
|
||||||
#include <AC_AttitudeControl/AC_AttitudeControl_Heli.h> // Attitude control library for traditional helicopter
|
#include <AC_AttitudeControl/AC_AttitudeControl_Heli.h> // Attitude control library for traditional helicopter
|
||||||
#include <AC_AttitudeControl/AC_PosControl.h> // Position control library
|
#include <AC_AttitudeControl/AC_PosControl.h> // Position control library
|
||||||
#include <AP_Motors/AP_Motors.h> // AP Motors library
|
#include <AP_Motors/AP_Motors.h> // AP Motors library
|
||||||
|
@ -864,7 +864,7 @@ const AP_Param::GroupInfo ParametersG2::var_info[] = {
|
|||||||
// @Param: FRAME_CLASS
|
// @Param: FRAME_CLASS
|
||||||
// @DisplayName: Frame Class
|
// @DisplayName: Frame Class
|
||||||
// @Description: Controls major frame class for multicopter component
|
// @Description: Controls major frame class for multicopter component
|
||||||
// @Values: 0:Undefined, 1:Quad, 2:Hexa, 3:Octa, 4:OctaQuad, 5:Y6, 6:Heli, 7:Tri, 8:SingleCopter, 9:CoaxCopter, 10:BiCopter, 11:Heli_Dual, 12:DodecaHexa, 13:HeliQuad, 14:Deca, 15:Scripting Matrix
|
// @Values: 0:Undefined, 1:Quad, 2:Hexa, 3:Octa, 4:OctaQuad, 5:Y6, 6:Heli, 7:Tri, 8:SingleCopter, 9:CoaxCopter, 10:BiCopter, 11:Heli_Dual, 12:DodecaHexa, 13:HeliQuad, 14:Deca, 15:Scripting Matrix, 16:6DoF Scripting
|
||||||
// @User: Standard
|
// @User: Standard
|
||||||
// @RebootRequired: True
|
// @RebootRequired: True
|
||||||
AP_GROUPINFO("FRAME_CLASS", 15, ParametersG2, frame_class, DEFAULT_FRAME_CLASS),
|
AP_GROUPINFO("FRAME_CLASS", 15, ParametersG2, frame_class, DEFAULT_FRAME_CLASS),
|
||||||
|
@ -484,6 +484,12 @@ void Copter::allocate_motors(void)
|
|||||||
motors = new AP_MotorsTailsitter(copter.scheduler.get_loop_rate_hz());
|
motors = new AP_MotorsTailsitter(copter.scheduler.get_loop_rate_hz());
|
||||||
motors_var_info = AP_MotorsTailsitter::var_info;
|
motors_var_info = AP_MotorsTailsitter::var_info;
|
||||||
break;
|
break;
|
||||||
|
case AP_Motors::MOTOR_FRAME_6DOF_SCRIPTING:
|
||||||
|
#ifdef ENABLE_SCRIPTING
|
||||||
|
motors = new AP_MotorsMatrix_6DoF_Scripting(copter.scheduler.get_loop_rate_hz());
|
||||||
|
motors_var_info = AP_MotorsMatrix_6DoF_Scripting::var_info;
|
||||||
|
#endif // ENABLE_SCRIPTING
|
||||||
|
break;
|
||||||
#else // FRAME_CONFIG == HELI_FRAME
|
#else // FRAME_CONFIG == HELI_FRAME
|
||||||
case AP_Motors::MOTOR_FRAME_HELI_DUAL:
|
case AP_Motors::MOTOR_FRAME_HELI_DUAL:
|
||||||
motors = new AP_MotorsHeli_Dual(copter.scheduler.get_loop_rate_hz());
|
motors = new AP_MotorsHeli_Dual(copter.scheduler.get_loop_rate_hz());
|
||||||
@ -518,8 +524,15 @@ void Copter::allocate_motors(void)
|
|||||||
const struct AP_Param::GroupInfo *ac_var_info;
|
const struct AP_Param::GroupInfo *ac_var_info;
|
||||||
|
|
||||||
#if FRAME_CONFIG != HELI_FRAME
|
#if FRAME_CONFIG != HELI_FRAME
|
||||||
attitude_control = new AC_AttitudeControl_Multi(*ahrs_view, aparm, *motors, scheduler.get_loop_period_s());
|
if ((AP_Motors::motor_frame_class)g2.frame_class.get() == AP_Motors::MOTOR_FRAME_6DOF_SCRIPTING) {
|
||||||
ac_var_info = AC_AttitudeControl_Multi::var_info;
|
#ifdef ENABLE_SCRIPTING
|
||||||
|
attitude_control = new AC_AttitudeControl_Multi_6DoF(*ahrs_view, aparm, *motors, scheduler.get_loop_period_s());
|
||||||
|
ac_var_info = AC_AttitudeControl_Multi_6DoF::var_info;
|
||||||
|
#endif // ENABLE_SCRIPTING
|
||||||
|
} else {
|
||||||
|
attitude_control = new AC_AttitudeControl_Multi(*ahrs_view, aparm, *motors, scheduler.get_loop_period_s());
|
||||||
|
ac_var_info = AC_AttitudeControl_Multi::var_info;
|
||||||
|
}
|
||||||
#else
|
#else
|
||||||
attitude_control = new AC_AttitudeControl_Heli(*ahrs_view, aparm, *motors, scheduler.get_loop_period_s());
|
attitude_control = new AC_AttitudeControl_Heli(*ahrs_view, aparm, *motors, scheduler.get_loop_period_s());
|
||||||
ac_var_info = AC_AttitudeControl_Heli::var_info;
|
ac_var_info = AC_AttitudeControl_Heli::var_info;
|
||||||
|
Loading…
Reference in New Issue
Block a user