mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-15 13:18:28 -04:00
109 lines
4.3 KiB
C
109 lines
4.3 KiB
C
|
/*
|
||
|
This program is free software: you can redistribute it and/or modify
|
||
|
it under the terms of the GNU General Public License as published by
|
||
|
the Free Software Foundation, either version 3 of the License, or
|
||
|
(at your option) any later version.
|
||
|
|
||
|
This program is distributed in the hope that it will be useful,
|
||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
|
GNU General Public License for more details.
|
||
|
|
||
|
You should have received a copy of the GNU General Public License
|
||
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||
|
*/
|
||
|
|
||
|
#pragma once
|
||
|
|
||
|
#include <AP_Param/AP_Param.h>
|
||
|
#include <AP_Mission/AP_Mission.h>
|
||
|
#include <AP_Common/AP_Common.h>
|
||
|
#include <AP_SpdHgtControl/AP_SpdHgtControl.h>
|
||
|
#include <AP_Navigation/AP_Navigation.h>
|
||
|
#include <PID/PID.h>
|
||
|
|
||
|
class AP_Landing;
|
||
|
|
||
|
/// @class AP_Landing
|
||
|
/// @brief Class managing ArduPlane landing methods
|
||
|
class AP_Landing_Deepstall
|
||
|
{
|
||
|
private:
|
||
|
friend class AP_Landing;
|
||
|
|
||
|
// constructor
|
||
|
AP_Landing_Deepstall(AP_Landing &_landing) :
|
||
|
landing(_landing)
|
||
|
{
|
||
|
AP_Param::setup_object_defaults(this, var_info);
|
||
|
}
|
||
|
|
||
|
AP_Landing &landing;
|
||
|
|
||
|
static const struct AP_Param::GroupInfo var_info[];
|
||
|
|
||
|
// deepstall members
|
||
|
enum deepstall_stage {
|
||
|
DEEPSTALL_STAGE_FLY_TO_LANDING, // fly to the deepstall landing point
|
||
|
DEEPSTALL_STAGE_ESTIMATE_WIND, // loiter until we have a decent estimate of the wind for the target altitude
|
||
|
DEEPSTALL_STAGE_WAIT_FOR_BREAKOUT, // wait until the aircraft is aligned for the optimal breakout
|
||
|
DEEPSTALL_STAGE_FLY_TO_ARC, // fly to the start of the arc
|
||
|
DEEPSTALL_STAGE_ARC, // fly the arc
|
||
|
DEEPSTALL_STAGE_APPROACH, // fly the approach in, and prepare to deepstall when close
|
||
|
DEEPSTALL_STAGE_LAND, // the aircraft will stall torwards the ground while targeting a given point
|
||
|
};
|
||
|
|
||
|
AP_Float forward_speed;
|
||
|
AP_Float slope_a;
|
||
|
AP_Float slope_b;
|
||
|
AP_Float approach_extension;
|
||
|
AP_Float down_speed;
|
||
|
AP_Float slew_speed;
|
||
|
AP_Int16 elevator_pwm;
|
||
|
AP_Float handoff_airspeed;
|
||
|
AP_Float handoff_lower_limit_airspeed;
|
||
|
AP_Float L1_period;
|
||
|
AP_Float L1_i;
|
||
|
AP_Float yaw_rate_limit;
|
||
|
AP_Float time_constant;
|
||
|
int32_t loiter_sum_cd; // used for tracking the progress on loitering
|
||
|
deepstall_stage stage;
|
||
|
Location landing_point;
|
||
|
Location extended_approach;
|
||
|
Location breakout_location;
|
||
|
Location arc;
|
||
|
Location arc_entry;
|
||
|
Location arc_exit;
|
||
|
float target_heading_deg; // target heading for the deepstall in degrees
|
||
|
uint32_t stall_entry_time; // time when the aircrafted enter the stall (in millis)
|
||
|
uint16_t initial_elevator_pwm; // PWM to start slewing the elevator up from
|
||
|
uint32_t last_time; // last time the controller ran
|
||
|
float L1_xtrack_i; // L1 integrator for navigation
|
||
|
PID ds_PID;
|
||
|
int32_t last_target_bearing; // used for tracking the progress on loitering
|
||
|
|
||
|
//public AP_Landing interface
|
||
|
void do_land(const AP_Mission::Mission_Command& cmd, const float relative_altitude);
|
||
|
void verify_abort_landing(const Location &prev_WP_loc, Location &next_WP_loc, bool &throttle_suppressed);
|
||
|
bool verify_land(const Location &prev_WP_loc, Location &next_WP_loc, const Location ¤t_loc,
|
||
|
const float height, const float sink_rate, const float wp_proportion, const uint32_t last_flying_ms,
|
||
|
const bool is_armed, const bool is_flying, const bool rangefinder_state_in_range);
|
||
|
void setup_landing_glide_slope(const Location &prev_WP_loc, const Location &next_WP_loc,
|
||
|
const Location ¤t_loc, int32_t &target_altitude_offset_cm);
|
||
|
bool override_servos(void);
|
||
|
bool request_go_around(void);
|
||
|
bool get_target_altitude_location(Location &location);
|
||
|
int32_t get_target_airspeed_cm(void) const;
|
||
|
bool is_throttle_suppressed(void) const;
|
||
|
|
||
|
const DataFlash_Class::PID_Info& get_pid_info(void) const;
|
||
|
|
||
|
//private helpers
|
||
|
void build_approach_path();
|
||
|
float predict_travel_distance(const Vector3f wind, const float height) const;
|
||
|
bool verify_breakout(const Location ¤t_loc, const Location &target_loc, const float height_error) const;
|
||
|
float update_steering(void);
|
||
|
|
||
|
#define DEEPSTALL_LOITER_ALT_TOLERANCE 5.0f
|
||
|
};
|