mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-04 23:18:28 -04:00
AntennaTracker: adapted to new SRV_Channel API
This commit is contained in:
parent
93d6b012c2
commit
3f71fd98a0
@ -302,15 +302,11 @@ const AP_Param::Info Tracker::var_info[] = {
|
|||||||
// @Path: ../libraries/AP_Notify/AP_Notify.cpp
|
// @Path: ../libraries/AP_Notify/AP_Notify.cpp
|
||||||
GOBJECT(notify, "NTF_", AP_Notify),
|
GOBJECT(notify, "NTF_", AP_Notify),
|
||||||
|
|
||||||
// RC channel
|
|
||||||
//-----------
|
|
||||||
// @Group: RC1_
|
|
||||||
// @Path: ../libraries/RC_Channel/RC_Channel.cpp
|
// @Path: ../libraries/RC_Channel/RC_Channel.cpp
|
||||||
GOBJECT(channel_yaw, "RC1_", RC_Channel),
|
GOBJECT(rc_channels, "RC", RC_Channels),
|
||||||
|
|
||||||
// @Group: RC2_
|
// @Path: ../libraries/SRV_Channel/SRV_Channel.cpp
|
||||||
// @Path: ../libraries/RC_Channel/RC_Channel.cpp
|
GOBJECT(servo_channels, "SERVO", SRV_Channels),
|
||||||
GOBJECT(channel_pitch, "RC2_", RC_Channel),
|
|
||||||
|
|
||||||
// @Group: SERIAL
|
// @Group: SERIAL
|
||||||
// @Path: ../libraries/AP_SerialManager/AP_SerialManager.cpp
|
// @Path: ../libraries/AP_SerialManager/AP_SerialManager.cpp
|
||||||
|
@ -106,10 +106,12 @@ public:
|
|||||||
//
|
//
|
||||||
// 200 : Radio settings
|
// 200 : Radio settings
|
||||||
//
|
//
|
||||||
k_param_channel_yaw = 200,
|
k_param_channel_yaw_old = 200,
|
||||||
k_param_channel_pitch,
|
k_param_channel_pitch_old,
|
||||||
k_param_pidPitch2Srv,
|
k_param_pidPitch2Srv,
|
||||||
k_param_pidYaw2Srv,
|
k_param_pidYaw2Srv,
|
||||||
|
k_param_rc_channels,
|
||||||
|
k_param_servo_channels,
|
||||||
|
|
||||||
//
|
//
|
||||||
// 220: Waypoint data
|
// 220: Waypoint data
|
||||||
|
@ -128,8 +128,8 @@ private:
|
|||||||
/**
|
/**
|
||||||
antenna control channels
|
antenna control channels
|
||||||
*/
|
*/
|
||||||
RC_Channel channel_yaw{CH_YAW};
|
RC_Channels rc_channels;
|
||||||
RC_Channel channel_pitch{CH_PITCH};
|
SRV_Channels servo_channels;
|
||||||
|
|
||||||
LowPassFilterFloat yaw_servo_out_filt;
|
LowPassFilterFloat yaw_servo_out_filt;
|
||||||
LowPassFilterFloat pitch_servo_out_filt;
|
LowPassFilterFloat pitch_servo_out_filt;
|
||||||
|
@ -11,10 +11,12 @@
|
|||||||
void Tracker::update_manual(void)
|
void Tracker::update_manual(void)
|
||||||
{
|
{
|
||||||
// copy yaw and pitch input to output
|
// copy yaw and pitch input to output
|
||||||
channel_yaw.set_radio_out(constrain_int16(channel_yaw.get_radio_in(), channel_yaw.get_radio_min(), channel_yaw.get_radio_max()));
|
SRV_Channels::set_output_pwm(SRV_Channel::k_steering, RC_Channels::rc_channel(CH_YAW)->get_radio_in());
|
||||||
channel_pitch.set_radio_out(constrain_int16(channel_pitch.get_radio_in(), channel_pitch.get_radio_min(), channel_pitch.get_radio_max()));
|
SRV_Channels::constrain_pwm(SRV_Channel::k_steering);
|
||||||
|
|
||||||
// send output to servos
|
SRV_Channels::set_output_pwm(SRV_Channel::k_elevator, RC_Channels::rc_channel(CH_PITCH)->get_radio_in());
|
||||||
channel_yaw.output();
|
SRV_Channels::constrain_pwm(SRV_Channel::k_elevator);
|
||||||
channel_pitch.output();
|
|
||||||
|
SRV_Channels::calc_pwm();
|
||||||
|
SRV_Channels::output_ch_all();
|
||||||
}
|
}
|
||||||
|
@ -25,16 +25,19 @@ bool Tracker::servo_test_set_servo(uint8_t servo_num, uint16_t pwm)
|
|||||||
|
|
||||||
// set yaw servo pwm and send output to servo
|
// set yaw servo pwm and send output to servo
|
||||||
if (servo_num == CH_YAW) {
|
if (servo_num == CH_YAW) {
|
||||||
channel_yaw.set_radio_out(constrain_int16(pwm, channel_yaw.get_radio_min(), channel_yaw.get_radio_max()));
|
SRV_Channels::set_output_pwm(SRV_Channel::k_steering, pwm);
|
||||||
channel_yaw.output();
|
SRV_Channels::constrain_pwm(SRV_Channel::k_steering);
|
||||||
}
|
}
|
||||||
|
|
||||||
// set pitch servo pwm and send output to servo
|
// set pitch servo pwm and send output to servo
|
||||||
if (servo_num == CH_PITCH) {
|
if (servo_num == CH_PITCH) {
|
||||||
channel_pitch.set_radio_out(constrain_int16(pwm, channel_pitch.get_radio_min(), channel_pitch.get_radio_max()));
|
SRV_Channels::set_output_pwm(SRV_Channel::k_elevator, pwm);
|
||||||
channel_pitch.output();
|
SRV_Channels::constrain_pwm(SRV_Channel::k_elevator);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SRV_Channels::calc_pwm();
|
||||||
|
SRV_Channels::output_ch_all();
|
||||||
|
|
||||||
// return success
|
// return success
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -5,7 +5,6 @@
|
|||||||
void Tracker::read_radio()
|
void Tracker::read_radio()
|
||||||
{
|
{
|
||||||
if (hal.rcin->new_input()) {
|
if (hal.rcin->new_input()) {
|
||||||
channel_yaw.set_pwm(hal.rcin->read(CH_YAW));
|
RC_Channels::set_pwm_all();
|
||||||
channel_pitch.set_pwm(hal.rcin->read(CH_PITCH));
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -7,17 +7,18 @@
|
|||||||
// init_servos - initialises the servos
|
// init_servos - initialises the servos
|
||||||
void Tracker::init_servos()
|
void Tracker::init_servos()
|
||||||
{
|
{
|
||||||
// setup antenna control PWM channels
|
SRV_Channels::set_default_function(CH_YAW, SRV_Channel::k_steering);
|
||||||
channel_yaw.set_angle(g.yaw_range * 100/2); // yaw range is +/- (YAW_RANGE parameter/2) converted to centi-degrees
|
SRV_Channels::set_default_function(CH_PITCH, SRV_Channel::k_elevator);
|
||||||
channel_pitch.set_angle((-g.pitch_min+g.pitch_max) * 100/2); // pitch range is +/- (PITCH_MIN/MAX parameters/2) converted to centi-degrees
|
|
||||||
|
|
||||||
// move servos to mid position
|
// yaw range is +/- (YAW_RANGE parameter/2) converted to centi-degrees
|
||||||
channel_yaw.output_trim();
|
SRV_Channels::set_angle(SRV_Channel::k_steering, g.yaw_range * 100/2);
|
||||||
channel_pitch.output_trim();
|
|
||||||
|
|
||||||
// initialise output to servos
|
// pitch range is +/- (PITCH_MIN/MAX parameters/2) converted to centi-degrees
|
||||||
channel_yaw.calc_pwm();
|
SRV_Channels::set_angle(SRV_Channel::k_elevator, (-g.pitch_min+g.pitch_max) * 100/2);
|
||||||
channel_pitch.calc_pwm();
|
|
||||||
|
SRV_Channels::output_trim_all();
|
||||||
|
SRV_Channels::calc_pwm();
|
||||||
|
SRV_Channels::output_ch_all();
|
||||||
|
|
||||||
yaw_servo_out_filt.set_cutoff_frequency(SERVO_OUT_FILT_HZ);
|
yaw_servo_out_filt.set_cutoff_frequency(SERVO_OUT_FILT_HZ);
|
||||||
pitch_servo_out_filt.set_cutoff_frequency(SERVO_OUT_FILT_HZ);
|
pitch_servo_out_filt.set_cutoff_frequency(SERVO_OUT_FILT_HZ);
|
||||||
@ -45,8 +46,8 @@ void Tracker::update_pitch_servo(float pitch)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// convert servo_out to radio_out and send to servo
|
// convert servo_out to radio_out and send to servo
|
||||||
channel_pitch.calc_pwm();
|
SRV_Channels::calc_pwm();
|
||||||
channel_pitch.output();
|
SRV_Channels::output_ch_all();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -76,7 +77,7 @@ void Tracker::update_pitch_position_servo()
|
|||||||
|
|
||||||
// calculate new servo position
|
// calculate new servo position
|
||||||
g.pidPitch2Srv.set_input_filter_all(nav_status.angle_error_pitch);
|
g.pidPitch2Srv.set_input_filter_all(nav_status.angle_error_pitch);
|
||||||
int32_t new_servo_out = channel_pitch.get_servo_out() + g.pidPitch2Srv.get_pid();
|
int32_t new_servo_out = SRV_Channels::get_output_scaled(SRV_Channel::k_elevator) + g.pidPitch2Srv.get_pid();
|
||||||
|
|
||||||
// position limit pitch servo
|
// position limit pitch servo
|
||||||
if (new_servo_out <= pitch_min_cd) {
|
if (new_servo_out <= pitch_min_cd) {
|
||||||
@ -88,7 +89,7 @@ void Tracker::update_pitch_position_servo()
|
|||||||
g.pidPitch2Srv.reset_I();
|
g.pidPitch2Srv.reset_I();
|
||||||
}
|
}
|
||||||
// rate limit pitch servo
|
// rate limit pitch servo
|
||||||
channel_pitch.set_servo_out(new_servo_out);
|
SRV_Channels::set_output_scaled(SRV_Channel::k_elevator, new_servo_out);
|
||||||
|
|
||||||
if (pitch_servo_out_filt_init) {
|
if (pitch_servo_out_filt_init) {
|
||||||
pitch_servo_out_filt.apply(new_servo_out, G_Dt);
|
pitch_servo_out_filt.apply(new_servo_out, G_Dt);
|
||||||
@ -110,15 +111,15 @@ void Tracker::update_pitch_onoff_servo(float pitch)
|
|||||||
|
|
||||||
float acceptable_error = g.onoff_pitch_rate * g.onoff_pitch_mintime;
|
float acceptable_error = g.onoff_pitch_rate * g.onoff_pitch_mintime;
|
||||||
if (fabsf(nav_status.angle_error_pitch) < acceptable_error) {
|
if (fabsf(nav_status.angle_error_pitch) < acceptable_error) {
|
||||||
channel_pitch.set_servo_out(0);
|
SRV_Channels::set_output_scaled(SRV_Channel::k_elevator, 0);
|
||||||
} else if ((nav_status.angle_error_pitch > 0) && (pitch*100>pitch_min_cd)) {
|
} else if ((nav_status.angle_error_pitch > 0) && (pitch*100>pitch_min_cd)) {
|
||||||
// positive error means we are pointing too low, so push the
|
// positive error means we are pointing too low, so push the
|
||||||
// servo up
|
// servo up
|
||||||
channel_pitch.set_servo_out(-9000);
|
SRV_Channels::set_output_scaled(SRV_Channel::k_elevator, -9000);
|
||||||
} else if (pitch*100<pitch_max_cd) {
|
} else if (pitch*100<pitch_max_cd) {
|
||||||
// negative error means we are pointing too high, so push the
|
// negative error means we are pointing too high, so push the
|
||||||
// servo down
|
// servo down
|
||||||
channel_pitch.set_servo_out(9000);
|
SRV_Channels::set_output_scaled(SRV_Channel::k_elevator, 9000);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -131,7 +132,7 @@ void Tracker::update_pitch_cr_servo(float pitch)
|
|||||||
int32_t pitch_max_cd = g.pitch_max*100;
|
int32_t pitch_max_cd = g.pitch_max*100;
|
||||||
if ((pitch>pitch_min_cd) && (pitch<pitch_max_cd)) {
|
if ((pitch>pitch_min_cd) && (pitch<pitch_max_cd)) {
|
||||||
g.pidPitch2Srv.set_input_filter_all(nav_status.angle_error_pitch);
|
g.pidPitch2Srv.set_input_filter_all(nav_status.angle_error_pitch);
|
||||||
channel_pitch.set_servo_out(g.pidPitch2Srv.get_pid());
|
SRV_Channels::set_output_scaled(SRV_Channel::k_elevator, g.pidPitch2Srv.get_pid());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -156,8 +157,8 @@ void Tracker::update_yaw_servo(float yaw)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// convert servo_out to radio_out and send to servo
|
// convert servo_out to radio_out and send to servo
|
||||||
channel_yaw.calc_pwm();
|
SRV_Channels::calc_pwm();
|
||||||
channel_yaw.output();
|
SRV_Channels::output_ch_all();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -200,7 +201,7 @@ void Tracker::update_yaw_position_servo()
|
|||||||
g.pidYaw2Srv.set_input_filter_all(nav_status.angle_error_yaw);
|
g.pidYaw2Srv.set_input_filter_all(nav_status.angle_error_yaw);
|
||||||
float servo_change = g.pidYaw2Srv.get_pid();
|
float servo_change = g.pidYaw2Srv.get_pid();
|
||||||
servo_change = constrain_float(servo_change, -18000, 18000);
|
servo_change = constrain_float(servo_change, -18000, 18000);
|
||||||
float new_servo_out = constrain_float(channel_yaw.get_servo_out() + servo_change, -18000, 18000);
|
float new_servo_out = constrain_float(SRV_Channels::get_output_scaled(SRV_Channel::k_steering) + servo_change, -18000, 18000);
|
||||||
|
|
||||||
// position limit yaw servo
|
// position limit yaw servo
|
||||||
if (new_servo_out <= -yaw_limit_cd) {
|
if (new_servo_out <= -yaw_limit_cd) {
|
||||||
@ -212,7 +213,7 @@ void Tracker::update_yaw_position_servo()
|
|||||||
g.pidYaw2Srv.reset_I();
|
g.pidYaw2Srv.reset_I();
|
||||||
}
|
}
|
||||||
|
|
||||||
channel_yaw.set_servo_out(new_servo_out);
|
SRV_Channels::set_output_scaled(SRV_Channel::k_steering, new_servo_out);
|
||||||
|
|
||||||
if (yaw_servo_out_filt_init) {
|
if (yaw_servo_out_filt_init) {
|
||||||
yaw_servo_out_filt.apply(new_servo_out, G_Dt);
|
yaw_servo_out_filt.apply(new_servo_out, G_Dt);
|
||||||
@ -232,15 +233,15 @@ void Tracker::update_yaw_onoff_servo(float yaw)
|
|||||||
{
|
{
|
||||||
float acceptable_error = g.onoff_yaw_rate * g.onoff_yaw_mintime;
|
float acceptable_error = g.onoff_yaw_rate * g.onoff_yaw_mintime;
|
||||||
if (fabsf(nav_status.angle_error_yaw * 0.01f) < acceptable_error) {
|
if (fabsf(nav_status.angle_error_yaw * 0.01f) < acceptable_error) {
|
||||||
channel_yaw.set_servo_out(0);
|
SRV_Channels::set_output_scaled(SRV_Channel::k_steering, 0);
|
||||||
} else if (nav_status.angle_error_yaw * 0.01f > 0) {
|
} else if (nav_status.angle_error_yaw * 0.01f > 0) {
|
||||||
// positive error means we are counter-clockwise of the target, so
|
// positive error means we are counter-clockwise of the target, so
|
||||||
// move clockwise
|
// move clockwise
|
||||||
channel_yaw.set_servo_out(18000);
|
SRV_Channels::set_output_scaled(SRV_Channel::k_steering, 18000);
|
||||||
} else {
|
} else {
|
||||||
// negative error means we are clockwise of the target, so
|
// negative error means we are clockwise of the target, so
|
||||||
// move counter-clockwise
|
// move counter-clockwise
|
||||||
channel_yaw.set_servo_out(-18000);
|
SRV_Channels::set_output_scaled(SRV_Channel::k_steering, -18000);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -250,5 +251,5 @@ void Tracker::update_yaw_onoff_servo(float yaw)
|
|||||||
void Tracker::update_yaw_cr_servo(float yaw)
|
void Tracker::update_yaw_cr_servo(float yaw)
|
||||||
{
|
{
|
||||||
g.pidYaw2Srv.set_input_filter_all(nav_status.angle_error_yaw);
|
g.pidYaw2Srv.set_input_filter_all(nav_status.angle_error_yaw);
|
||||||
channel_yaw.set_servo_out(-g.pidYaw2Srv.get_pid());
|
SRV_Channels::set_output_scaled(SRV_Channel::k_steering, -g.pidYaw2Srv.get_pid());
|
||||||
}
|
}
|
||||||
|
@ -163,14 +163,12 @@ void Tracker::set_home(struct Location temp)
|
|||||||
|
|
||||||
void Tracker::arm_servos()
|
void Tracker::arm_servos()
|
||||||
{
|
{
|
||||||
channel_yaw.enable_out();
|
hal.util->set_soft_armed(true);
|
||||||
channel_pitch.enable_out();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void Tracker::disarm_servos()
|
void Tracker::disarm_servos()
|
||||||
{
|
{
|
||||||
channel_yaw.disable_out();
|
hal.util->set_soft_armed(false);
|
||||||
channel_pitch.disable_out();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -179,10 +177,10 @@ void Tracker::disarm_servos()
|
|||||||
void Tracker::prepare_servos()
|
void Tracker::prepare_servos()
|
||||||
{
|
{
|
||||||
start_time_ms = AP_HAL::millis();
|
start_time_ms = AP_HAL::millis();
|
||||||
channel_yaw.set_radio_out(channel_yaw.get_radio_trim());
|
SRV_Channels::set_output_limit(SRV_Channel::k_steering, SRV_Channel::SRV_CHANNEL_LIMIT_TRIM);
|
||||||
channel_pitch.set_radio_out(channel_pitch.get_radio_trim());
|
SRV_Channels::set_output_limit(SRV_Channel::k_elevator, SRV_Channel::SRV_CHANNEL_LIMIT_TRIM);
|
||||||
channel_yaw.output();
|
SRV_Channels::calc_pwm();
|
||||||
channel_pitch.output();
|
SRV_Channels::output_ch_all();
|
||||||
}
|
}
|
||||||
|
|
||||||
void Tracker::set_mode(enum ControlMode mode)
|
void Tracker::set_mode(enum ControlMode mode)
|
||||||
|
Loading…
Reference in New Issue
Block a user