mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-25 10:08:28 -04:00
Copter: Jason's faster cos_yaw, sin_yaw
This commit is contained in:
parent
5bf55a9523
commit
3bf847f675
@ -521,8 +521,6 @@ static uint8_t rtl_state;
|
|||||||
// The cos values are defaulted to 1 to get a decent initial value for a level state
|
// The cos values are defaulted to 1 to get a decent initial value for a level state
|
||||||
static float cos_roll_x = 1;
|
static float cos_roll_x = 1;
|
||||||
static float cos_pitch_x = 1;
|
static float cos_pitch_x = 1;
|
||||||
static float cos_yaw_x = 1;
|
|
||||||
static float sin_yaw_y = 1;
|
|
||||||
static float cos_yaw = 1;
|
static float cos_yaw = 1;
|
||||||
static float sin_yaw = 1;
|
static float sin_yaw = 1;
|
||||||
static float sin_roll = 1;
|
static float sin_roll = 1;
|
||||||
@ -1361,7 +1359,7 @@ static void update_optical_flow(void)
|
|||||||
// if new data has arrived, process it
|
// if new data has arrived, process it
|
||||||
if( optflow.last_update != last_of_update ) {
|
if( optflow.last_update != last_of_update ) {
|
||||||
last_of_update = optflow.last_update;
|
last_of_update = optflow.last_update;
|
||||||
optflow.update_position(ahrs.roll, ahrs.pitch, cos_yaw_x, sin_yaw_y, current_loc.alt); // updates internal lon and lat with estimation based on optical flow
|
optflow.update_position(ahrs.roll, ahrs.pitch, sin_yaw, cos_yaw, current_loc.alt); // updates internal lon and lat with estimation based on optical flow
|
||||||
|
|
||||||
// write to log at 5hz
|
// write to log at 5hz
|
||||||
of_log_counter++;
|
of_log_counter++;
|
||||||
@ -2027,21 +2025,18 @@ static void update_trig(void){
|
|||||||
// which it does do in avr-libc
|
// which it does do in avr-libc
|
||||||
cos_roll_x = constrain(cos_roll_x, -1.0, 1.0);
|
cos_roll_x = constrain(cos_roll_x, -1.0, 1.0);
|
||||||
|
|
||||||
sin_yaw_y = yawvector.x; // 1y = north
|
sin_yaw = constrain(yawvector.y, -1.0, 1.0);
|
||||||
cos_yaw_x = yawvector.y; // 0x = north
|
cos_yaw = constrain(yawvector.x, -1.0, 1.0);
|
||||||
|
|
||||||
// added to convert earth frame to body frame for rate controllers
|
// added to convert earth frame to body frame for rate controllers
|
||||||
sin_pitch = -temp.c.x;
|
sin_pitch = -temp.c.x;
|
||||||
sin_roll = temp.c.y / cos_pitch_x;
|
sin_roll = temp.c.y / cos_pitch_x;
|
||||||
|
|
||||||
sin_yaw = constrain(temp.b.x/cos_pitch_x, -1.0, 1.0);
|
|
||||||
cos_yaw = constrain(temp.a.x/cos_pitch_x, -1.0, 1.0);
|
|
||||||
|
|
||||||
//flat:
|
//flat:
|
||||||
// 0 ° = cos_yaw: 0.00, sin_yaw: 1.00,
|
// 0 ° = cos_yaw: 1.00, sin_yaw: 0.00,
|
||||||
// 90° = cos_yaw: 1.00, sin_yaw: 0.00,
|
// 90° = cos_yaw: 0.00, sin_yaw: 1.00,
|
||||||
// 180 = cos_yaw: 0.00, sin_yaw: -1.00,
|
// 180 = cos_yaw: -1.00, sin_yaw: 0.00,
|
||||||
// 270 = cos_yaw: -1.00, sin_yaw: 0.00,
|
// 270 = cos_yaw: 0.00, sin_yaw: -1.00,
|
||||||
}
|
}
|
||||||
|
|
||||||
// read baro and sonar altitude at 10hz
|
// read baro and sonar altitude at 10hz
|
||||||
|
Loading…
Reference in New Issue
Block a user