mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-05 07:28:29 -04:00
AP_MotorsHeli: Create Servo Test functionality
This commit is contained in:
parent
eeb544d098
commit
bb7f8c1999
@ -148,6 +148,14 @@ const AP_Param::GroupInfo AP_MotorsHeli::var_info[] = {
|
|||||||
// @User: Advanced
|
// @User: Advanced
|
||||||
AP_GROUPINFO("CYC_MAX", 16, AP_MotorsHeli, _cyclic_max, AP_MOTORS_HELI_SWASH_CYCLIC_MAX),
|
AP_GROUPINFO("CYC_MAX", 16, AP_MotorsHeli, _cyclic_max, AP_MOTORS_HELI_SWASH_CYCLIC_MAX),
|
||||||
|
|
||||||
|
// @Param: SV_TEST
|
||||||
|
// @DisplayName: Boot-up Servo Test Cycles
|
||||||
|
// @Description: Number of cycles to run servo test on boot-up
|
||||||
|
// @Range: 0 10
|
||||||
|
// @Increment: 1
|
||||||
|
// @User: Standard
|
||||||
|
AP_GROUPINFO("SV_TEST", 17, AP_MotorsHeli, _servo_test, 0),
|
||||||
|
|
||||||
AP_GROUPEND
|
AP_GROUPEND
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -161,6 +169,9 @@ void AP_MotorsHeli::Init()
|
|||||||
// set update rate
|
// set update rate
|
||||||
set_update_rate(_speed_hz);
|
set_update_rate(_speed_hz);
|
||||||
|
|
||||||
|
// load boot-up servo test cycles into counter to be consumed
|
||||||
|
_servo_test_cycle_counter = _servo_test;
|
||||||
|
|
||||||
// ensure inputs are not passed through to servos on start-up
|
// ensure inputs are not passed through to servos on start-up
|
||||||
_servo_mode = SERVO_CONTROL_MODE_AUTOMATED;
|
_servo_mode = SERVO_CONTROL_MODE_AUTOMATED;
|
||||||
|
|
||||||
@ -247,6 +258,10 @@ void AP_MotorsHeli::output_armed_zero_throttle()
|
|||||||
// output_disarmed - sends commands to the motors
|
// output_disarmed - sends commands to the motors
|
||||||
void AP_MotorsHeli::output_disarmed()
|
void AP_MotorsHeli::output_disarmed()
|
||||||
{
|
{
|
||||||
|
if (_servo_test_cycle_counter > 0){
|
||||||
|
// perform boot-up servo test cycle if enabled
|
||||||
|
servo_test();
|
||||||
|
} else {
|
||||||
// manual override (i.e. when setting up swash)
|
// manual override (i.e. when setting up swash)
|
||||||
switch (_servo_mode) {
|
switch (_servo_mode) {
|
||||||
case SERVO_CONTROL_MODE_MANUAL_PASSTHROUGH:
|
case SERVO_CONTROL_MODE_MANUAL_PASSTHROUGH:
|
||||||
@ -285,6 +300,7 @@ void AP_MotorsHeli::output_disarmed()
|
|||||||
// no manual override
|
// no manual override
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// ensure swash servo endpoints haven't been moved
|
// ensure swash servo endpoints haven't been moved
|
||||||
init_outputs();
|
init_outputs();
|
||||||
|
@ -223,6 +223,7 @@ protected:
|
|||||||
AP_Int16 _rsc_idle_output; // Rotor control output while at idle
|
AP_Int16 _rsc_idle_output; // Rotor control output while at idle
|
||||||
AP_Int16 _rsc_power_low; // throttle value sent to throttle servo at zero collective pitch
|
AP_Int16 _rsc_power_low; // throttle value sent to throttle servo at zero collective pitch
|
||||||
AP_Int16 _rsc_power_high; // throttle value sent to throttle servo at maximum collective pitch
|
AP_Int16 _rsc_power_high; // throttle value sent to throttle servo at maximum collective pitch
|
||||||
|
AP_Int8 _servo_test; // sets number of cycles to test servo movement on bootup
|
||||||
|
|
||||||
// internal variables
|
// internal variables
|
||||||
float _rollFactor[AP_MOTORS_HELI_NUM_SWASHPLATE_SERVOS];
|
float _rollFactor[AP_MOTORS_HELI_NUM_SWASHPLATE_SERVOS];
|
||||||
@ -240,6 +241,7 @@ protected:
|
|||||||
int16_t _throttle_radio_passthrough = 0; // throttle control PWM direct from radio, used for manual control
|
int16_t _throttle_radio_passthrough = 0; // throttle control PWM direct from radio, used for manual control
|
||||||
int16_t _yaw_radio_passthrough = 0; // yaw control PWM direct from radio, used for manual control
|
int16_t _yaw_radio_passthrough = 0; // yaw control PWM direct from radio, used for manual control
|
||||||
int16_t _collective_range = 0; // maximum absolute collective pitch range (500 - 1000)
|
int16_t _collective_range = 0; // maximum absolute collective pitch range (500 - 1000)
|
||||||
|
uint8_t _servo_test_cycle_counter = 0; // number of test cycles left to run after bootup
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // AP_MOTORSHELI
|
#endif // AP_MOTORSHELI
|
||||||
|
@ -522,6 +522,10 @@ void AP_MotorsHeli_Single::servo_test()
|
|||||||
roll_test = 0.0f;
|
roll_test = 0.0f;
|
||||||
pitch_test = 0.0f;
|
pitch_test = 0.0f;
|
||||||
yaw_test = 0.0f;
|
yaw_test = 0.0f;
|
||||||
|
// decrement servo test cycle counter at the end of the cycle
|
||||||
|
if (_servo_test_cycle_counter > 0){
|
||||||
|
_servo_test_cycle_counter--;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// over-ride servo commands to move servos through defined ranges
|
// over-ride servo commands to move servos through defined ranges
|
||||||
|
Loading…
Reference in New Issue
Block a user