mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-12 19:08:29 -04:00
AC_Avoidance: bendy ruler format fixes
This commit is contained in:
parent
8d641e1bb3
commit
3177759a1d
@ -236,7 +236,7 @@ bool AP_OABendyRuler::search_xy_path(const Location& current_loc, const Location
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Search for path in the vertical directions
|
// Search for path in the vertical directions
|
||||||
bool AP_OABendyRuler::search_vertical_path(const Location& current_loc, const Location& destination,Location &destination_new, const float &lookahead_step1_dist, const float &lookahead_step2_dist, const float &bearing_to_dest, const float &distance_to_dest, bool proximity_only)
|
bool AP_OABendyRuler::search_vertical_path(const Location ¤t_loc, const Location &destination, Location &destination_new, float lookahead_step1_dist, float lookahead_step2_dist, float bearing_to_dest, float distance_to_dest, bool proximity_only)
|
||||||
{
|
{
|
||||||
// check OA_BEARING_INC_VERTICAL definition allows checking in all directions
|
// check OA_BEARING_INC_VERTICAL definition allows checking in all directions
|
||||||
static_assert(360 % OA_BENDYRULER_BEARING_INC_VERTICAL == 0, "check 360 is a multiple of OA_BEARING_INC_VERTICAL");
|
static_assert(360 % OA_BENDYRULER_BEARING_INC_VERTICAL == 0, "check 360 is a multiple of OA_BEARING_INC_VERTICAL");
|
||||||
@ -285,7 +285,7 @@ bool AP_OABendyRuler::search_vertical_path(const Location& current_loc, const Lo
|
|||||||
for (uint8_t j = 0; j < ARRAY_SIZE(test_pitch_step2); j++) {
|
for (uint8_t j = 0; j < ARRAY_SIZE(test_pitch_step2); j++) {
|
||||||
float bearing_test2 = wrap_180(test_pitch_step2[j]);
|
float bearing_test2 = wrap_180(test_pitch_step2[j]);
|
||||||
Location test_loc2 = test_loc;
|
Location test_loc2 = test_loc;
|
||||||
test_loc2.offset_bearing_and_pitch(bearing_to_dest2, bearing_test2 ,distance2);
|
test_loc2.offset_bearing_and_pitch(bearing_to_dest2, bearing_test2, distance2);
|
||||||
|
|
||||||
// calculate minimum margin to fence and obstacles for this scenario
|
// calculate minimum margin to fence and obstacles for this scenario
|
||||||
float margin2 = calc_avoidance_margin(test_loc, test_loc2, proximity_only);
|
float margin2 = calc_avoidance_margin(test_loc, test_loc2, proximity_only);
|
||||||
@ -309,7 +309,7 @@ bool AP_OABendyRuler::search_vertical_path(const Location& current_loc, const Lo
|
|||||||
}
|
}
|
||||||
// project in the chosen direction by the full distance
|
// project in the chosen direction by the full distance
|
||||||
destination_new = current_loc;
|
destination_new = current_loc;
|
||||||
destination_new.offset_bearing_and_pitch(bearing_to_dest,pitch_delta, distance_to_dest);
|
destination_new.offset_bearing_and_pitch(bearing_to_dest, pitch_delta, distance_to_dest);
|
||||||
_current_lookahead = MIN(_lookahead, _current_lookahead * 1.1f);
|
_current_lookahead = MIN(_lookahead, _current_lookahead * 1.1f);
|
||||||
|
|
||||||
Write_OABendyRuler((uint8_t)OABendyType::OA_BENDY_VERTICAL, active, bearing_to_dest, pitch_delta, false, margin, destination, destination_new);
|
Write_OABendyRuler((uint8_t)OABendyType::OA_BENDY_VERTICAL, active, bearing_to_dest, pitch_delta, false, margin, destination, destination_new);
|
||||||
|
@ -40,7 +40,7 @@ private:
|
|||||||
bool search_xy_path(const Location& current_loc, const Location& destination, float ground_course_deg, Location &destination_new, float lookahead_step_1_dist, float lookahead_step_2_dist, float bearing_to_dest, float distance_to_dest, bool proximity_only);
|
bool search_xy_path(const Location& current_loc, const Location& destination, float ground_course_deg, Location &destination_new, float lookahead_step_1_dist, float lookahead_step_2_dist, float bearing_to_dest, float distance_to_dest, bool proximity_only);
|
||||||
|
|
||||||
// search for path in the Vertical directions
|
// search for path in the Vertical directions
|
||||||
bool search_vertical_path(const Location& current_loc, const Location& destination,Location &destination_new, const float &lookahead_step1_dist, const float &lookahead_step2_dist, const float &bearing_to_dest, const float &distance_to_dest, bool proximity_only);
|
bool search_vertical_path(const Location ¤t_loc, const Location &destination, Location &destination_new, float lookahead_step1_dist, float lookahead_step2_dist, float bearing_to_dest, float distance_to_dest, bool proximity_only);
|
||||||
|
|
||||||
// calculate minimum distance between a path and any obstacle
|
// calculate minimum distance between a path and any obstacle
|
||||||
float calc_avoidance_margin(const Location &start, const Location &end, bool proximity_only) const;
|
float calc_avoidance_margin(const Location &start, const Location &end, bool proximity_only) const;
|
||||||
|
Loading…
Reference in New Issue
Block a user