mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-12 10:58:30 -04:00
Update and fix for Circle mode
HIL updates for altitude
This commit is contained in:
parent
a277e117b3
commit
ccdfa13edb
@ -320,13 +320,17 @@ static float simple_sin_y, simple_cos_x;
|
|||||||
static byte jump = -10; // used to track loops in jump command
|
static byte jump = -10; // used to track loops in jump command
|
||||||
static int16_t waypoint_speed_gov;
|
static int16_t waypoint_speed_gov;
|
||||||
|
|
||||||
|
static float circle_angle;
|
||||||
|
// replace with param
|
||||||
|
static const float circle_rate = 0.174532925;
|
||||||
|
|
||||||
// Acro
|
// Acro
|
||||||
#if CH7_OPTION == CH7_FLIP
|
#if CH7_OPTION == CH7_FLIP
|
||||||
static bool do_flip = false;
|
static bool do_flip = false;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static boolean trim_flag;
|
static boolean trim_flag;
|
||||||
static int16_t CH7_wp_index = 0;
|
static int8_t CH7_wp_index;
|
||||||
|
|
||||||
// Airspeed
|
// Airspeed
|
||||||
// --------
|
// --------
|
||||||
@ -1209,32 +1213,51 @@ static void update_trig(void){
|
|||||||
static void update_altitude()
|
static void update_altitude()
|
||||||
{
|
{
|
||||||
altitude_sensor = BARO;
|
altitude_sensor = BARO;
|
||||||
|
//current_loc.alt = g_gps->altitude - gps_base_alt;
|
||||||
|
//climb_rate = (g_gps->altitude - old_baro_alt) * 10;
|
||||||
|
//old_baro_alt = g_gps->altitude;
|
||||||
|
//baro_alt = g_gps->altitude;
|
||||||
|
|
||||||
#if HIL_MODE == HIL_MODE_ATTITUDE
|
#if HIL_MODE == HIL_MODE_ATTITUDE
|
||||||
current_loc.alt = g_gps->altitude - gps_base_alt;
|
// we are in the SIM, fake out the baro and Sonar
|
||||||
climb_rate = (g_gps->altitude - old_baro_alt) * 10;
|
int fake_relative_alt = g_gps->altitude - gps_base_alt;
|
||||||
old_baro_alt = g_gps->altitude;
|
int temp_baro_alt = fake_relative_alt;
|
||||||
return;
|
baro_rate = (temp_baro_alt - old_baro_alt) * 10;
|
||||||
#else
|
old_baro_alt = temp_baro_alt;
|
||||||
|
baro_alt = fake_relative_alt;
|
||||||
|
sonar_alt = fake_relative_alt;
|
||||||
|
|
||||||
|
#else
|
||||||
|
// This is real life
|
||||||
|
// calc the vertical accel rate
|
||||||
|
int temp_baro_alt = (barometer._offset_press - barometer.RawPress) << 1; // invert and scale
|
||||||
|
baro_rate = (temp_baro_alt - old_baro_alt) * 10;
|
||||||
|
old_baro_alt = temp_baro_alt;
|
||||||
|
|
||||||
|
// read in Actual Baro Altitude
|
||||||
|
baro_alt = (baro_alt + read_barometer()) >> 1;
|
||||||
|
|
||||||
|
// sonar_alt is calculaed in a faster loop and filtered with a mode filter
|
||||||
|
#endif
|
||||||
|
|
||||||
// calc the vertical accel rate
|
|
||||||
int temp_alt = (barometer._offset_press - barometer.RawPress) << 1; // invert and scale
|
|
||||||
baro_rate = (temp_alt - old_baro_alt) * 10;
|
|
||||||
old_baro_alt = temp_alt;
|
|
||||||
|
|
||||||
if(g.sonar_enabled){
|
if(g.sonar_enabled){
|
||||||
// filter out offset
|
// filter out offset
|
||||||
float scale;
|
float scale;
|
||||||
|
|
||||||
// read barometer
|
|
||||||
baro_alt = (baro_alt + read_barometer()) >> 1;
|
|
||||||
|
|
||||||
// calc rate of change for Sonar
|
// calc rate of change for Sonar
|
||||||
sonar_rate = (sonar_alt - old_sonar_alt) * 10;
|
#if HIL_MODE == HIL_MODE_ATTITUDE
|
||||||
old_sonar_alt = sonar_alt;
|
// we are in the SIM, fake outthe Sonar rate
|
||||||
|
sonar_rate = baro_rate;
|
||||||
|
#else
|
||||||
|
// This is real life
|
||||||
|
// calc the vertical accel rate
|
||||||
|
sonar_rate = (sonar_alt - old_sonar_alt) * 10;
|
||||||
|
old_sonar_alt = sonar_alt;
|
||||||
|
#endif
|
||||||
|
|
||||||
if(baro_alt < 700){
|
|
||||||
|
|
||||||
|
if(baro_alt < 800){
|
||||||
#if SONAR_TILT_CORRECTION == 1
|
#if SONAR_TILT_CORRECTION == 1
|
||||||
// correct alt for angle of the sonar
|
// correct alt for angle of the sonar
|
||||||
float temp = cos_pitch_x * cos_roll_x;
|
float temp = cos_pitch_x * cos_roll_x;
|
||||||
@ -1246,22 +1269,23 @@ static void update_altitude()
|
|||||||
scale = constrain(scale, 0, 1);
|
scale = constrain(scale, 0, 1);
|
||||||
|
|
||||||
current_loc.alt = ((float)sonar_alt * (1.0 - scale)) + ((float)baro_alt * scale) + home.alt;
|
current_loc.alt = ((float)sonar_alt * (1.0 - scale)) + ((float)baro_alt * scale) + home.alt;
|
||||||
|
|
||||||
|
// solve for a blended climb_rate
|
||||||
climb_rate = ((float)sonar_rate * (1.0 - scale)) + (float)baro_rate * scale;
|
climb_rate = ((float)sonar_rate * (1.0 - scale)) + (float)baro_rate * scale;
|
||||||
|
|
||||||
}else{
|
}else{
|
||||||
current_loc.alt = baro_alt + home.alt;
|
// we must be higher than sonar, don't get tricked by bad sonar reads
|
||||||
climb_rate = baro_rate;
|
current_loc.alt = baro_alt + home.alt; // home alt = 0
|
||||||
|
// dont blend, go straight baro
|
||||||
|
climb_rate = baro_rate;
|
||||||
}
|
}
|
||||||
|
|
||||||
}else{
|
}else{
|
||||||
// No Sonar Case
|
|
||||||
baro_alt = read_barometer();
|
// NO Sonar case
|
||||||
current_loc.alt = baro_alt + home.alt;
|
current_loc.alt = baro_alt + home.alt;
|
||||||
climb_rate = baro_rate;
|
climb_rate = baro_rate;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -1419,10 +1443,17 @@ static void update_nav_wp()
|
|||||||
|
|
||||||
// create a virtual waypoint that circles the next_WP
|
// create a virtual waypoint that circles the next_WP
|
||||||
// Count the degrees we have circulated the WP
|
// Count the degrees we have circulated the WP
|
||||||
int circle_angle = wrap_360(target_bearing + 3000 + 18000) / 100;
|
//int circle_angle = wrap_360(target_bearing + 3000 + 18000) / 100;
|
||||||
|
|
||||||
target_WP.lng = next_WP.lng + (g.loiter_radius * cos(radians(90 - circle_angle)));
|
circle_angle += (circle_rate * dTnav);
|
||||||
target_WP.lat = next_WP.lat + (g.loiter_radius * sin(radians(90 - circle_angle)));
|
//1° = 0.0174532925 radians
|
||||||
|
|
||||||
|
// wrap
|
||||||
|
if (circle_angle > 6.28318531)
|
||||||
|
circle_angle -= 6.28318531;
|
||||||
|
|
||||||
|
target_WP.lng = next_WP.lng + (g.loiter_radius * cos(1.57 - circle_angle));
|
||||||
|
target_WP.lat = next_WP.lat + (g.loiter_radius * sin(1.57 - circle_angle));
|
||||||
|
|
||||||
// calc the lat and long error to the target
|
// calc the lat and long error to the target
|
||||||
calc_location_error(&target_WP);
|
calc_location_error(&target_WP);
|
||||||
@ -1431,9 +1462,14 @@ static void update_nav_wp()
|
|||||||
// nav_lon, nav_lat is calculated
|
// nav_lon, nav_lat is calculated
|
||||||
calc_loiter(long_error, lat_error);
|
calc_loiter(long_error, lat_error);
|
||||||
|
|
||||||
|
//CIRCLE: angle:29, dist:0, lat:400, lon:242
|
||||||
|
|
||||||
// rotate pitch and roll to the copter frame of reference
|
// rotate pitch and roll to the copter frame of reference
|
||||||
calc_loiter_pitch_roll();
|
calc_loiter_pitch_roll();
|
||||||
|
int angleTest = degrees(circle_angle);
|
||||||
|
int nroll = nav_roll;
|
||||||
|
int npitch = nav_pitch;
|
||||||
|
//Serial.printf("CIRCLE: angle:%d, dist:%d, X:%d, Y:%d, P:%d, R:%d \n", angleTest, (int)wp_distance , (int)long_error, (int)lat_error, npitch, nroll);
|
||||||
} else {
|
} else {
|
||||||
// use error as the desired rate towards the target
|
// use error as the desired rate towards the target
|
||||||
calc_nav_rate(g.waypoint_speed_max);
|
calc_nav_rate(g.waypoint_speed_max);
|
||||||
|
Loading…
Reference in New Issue
Block a user