AP_Mount: Fix radians/degrees scaling regressions

Rename calculate() into stabilize()
Implement MAV_MOUNT_MODE_RC_TARGETING initialization
Document to make sure this radians/degrees mess up does not happen again
This commit is contained in:
Amilcar Lucas 2012-07-07 21:56:56 +02:00
parent 78c51b945f
commit 46552b4222
2 changed files with 32 additions and 16 deletions

View File

@ -134,10 +134,10 @@ void AP_Mount::update_mount_position()
case MAV_MOUNT_MODE_MAVLINK_TARGETING: case MAV_MOUNT_MODE_MAVLINK_TARGETING:
{ {
Vector3f vec = _control_angles.get(); Vector3f vec = _control_angles.get();
_roll_control_angle = vec.x; _roll_control_angle = radians(vec.x);
_pitch_control_angle = vec.y; _pitch_control_angle = radians(vec.y);
_yaw_control_angle = vec.z; _yaw_control_angle = radians(vec.z);
calculate(); stabilize();
break; break;
} }
@ -149,7 +149,7 @@ void AP_Mount::update_mount_position()
G_RC_AUX(k_mount_pitch)->rc_input(&_pitch_control_angle, _pitch_angle*100); G_RC_AUX(k_mount_pitch)->rc_input(&_pitch_control_angle, _pitch_angle*100);
G_RC_AUX(k_mount_yaw)->rc_input(&_yaw_control_angle, _yaw_angle*100); G_RC_AUX(k_mount_yaw)->rc_input(&_yaw_control_angle, _yaw_angle*100);
if (_ahrs){ if (_ahrs){
calculate(); stabilize();
} else { } else {
if (g_rc_function[RC_Channel_aux::k_mount_roll]) if (g_rc_function[RC_Channel_aux::k_mount_roll])
_roll_angle = rc_map(g_rc_function[RC_Channel_aux::k_mount_roll]); _roll_angle = rc_map(g_rc_function[RC_Channel_aux::k_mount_roll]);
@ -166,7 +166,7 @@ void AP_Mount::update_mount_position()
{ {
if(_gps->fix){ if(_gps->fix){
calc_GPS_target_angle(&_target_GPS_location); calc_GPS_target_angle(&_target_GPS_location);
calculate(); stabilize();
} }
break; break;
} }
@ -237,6 +237,12 @@ void AP_Mount::control_msg(mavlink_message_t *msg)
break; break;
case MAV_MOUNT_MODE_RC_TARGETING: // Load neutral position and start RC Roll,Pitch,Yaw control with stabilization case MAV_MOUNT_MODE_RC_TARGETING: // Load neutral position and start RC Roll,Pitch,Yaw control with stabilization
{
Vector3f vec = _neutral_angles.get();
_roll_angle = vec.x;
_pitch_angle = vec.y;
_yaw_angle = vec.z;
}
break; break;
case MAV_MOUNT_MODE_GPS_POINT: // Load neutral position and start to point to Lat,Lon,Alt case MAV_MOUNT_MODE_GPS_POINT: // Load neutral position and start to point to Lat,Lon,Alt
@ -322,10 +328,17 @@ AP_Mount::calc_GPS_target_angle(struct Location *target)
} }
} }
// Inputs desired _roll_control_angle, _pitch_control_angle and _yaw_control_angle stabilizes them relative to the airframe /// Stabilizes mount relative to the Earth's frame
// and calculates output _roll_angle, _pitch_angle and _yaw_angle /// Inputs:
/// _roll_control_angle desired roll angle in radians,
/// _pitch_control_angle desired pitch/tilt angle in radians,
/// _yaw_control_angle desired yaw/pan angle in radians
/// Outputs:
/// _roll_angle stabilized roll angle in degrees,
/// _pitch_angle stabilized pitch/tilt angle in degrees,
/// _yaw_angle stabilized yaw/pan angle in degrees
void void
AP_Mount::calculate() AP_Mount::stabilize()
{ {
if (_ahrs) { if (_ahrs) {
// only do the full 3D frame transform if we are doing yaw control // only do the full 3D frame transform if we are doing yaw control
@ -338,12 +351,15 @@ AP_Mount::calculate()
cam.from_euler(_roll_control_angle, _pitch_control_angle, _yaw_control_angle); cam.from_euler(_roll_control_angle, _pitch_control_angle, _yaw_control_angle);
gimbal_target = m * cam; gimbal_target = m * cam;
gimbal_target.to_euler(&_roll_angle, &_pitch_angle, &_yaw_angle); gimbal_target.to_euler(&_roll_angle, &_pitch_angle, &_yaw_angle);
_roll_angle = degrees(_roll_angle);
_pitch_angle = degrees(_pitch_angle);
_yaw_angle = degrees(_yaw_angle);
} else { } else {
// otherwise base mount roll and pitch on the ahrs // otherwise base mount roll and pitch on the ahrs
// roll/pitch attitude, plus any requested angle // roll/pitch attitude, plus any requested angle
_roll_angle = _roll_control_angle; _roll_angle = degrees(_roll_control_angle);
_pitch_angle = _pitch_control_angle; _pitch_angle = degrees(_pitch_control_angle);
_yaw_angle = _yaw_control_angle; _yaw_angle = degrees(_yaw_control_angle);
if (_stab_roll) { if (_stab_roll) {
_roll_angle -= degrees(_ahrs->roll); _roll_angle -= degrees(_ahrs->roll);
} }

View File

@ -63,7 +63,7 @@ private:
// internal methods // internal methods
void calc_GPS_target_angle(struct Location *target); void calc_GPS_target_angle(struct Location *target);
void calculate(); void stabilize();
long rc_map(RC_Channel_aux* rc_ch); long rc_map(RC_Channel_aux* rc_ch);
//members //members
@ -71,9 +71,9 @@ private:
GPS *&_gps; GPS *&_gps;
const struct Location *_current_loc; const struct Location *_current_loc;
static const float t7 = 10000000.0; static const float t7 = 10000000.0;
float _roll_control_angle; float _roll_control_angle; ///< radians
float _pitch_control_angle; float _pitch_control_angle; ///< radians
float _yaw_control_angle; float _yaw_control_angle; ///< radians
float _roll_angle; ///< degrees float _roll_angle; ///< degrees
float _pitch_angle; ///< degrees float _pitch_angle; ///< degrees