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:
parent
78c51b945f
commit
46552b4222
@ -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);
|
||||||
}
|
}
|
||||||
|
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user