AP_Follow: added APIs for plane ship landing

This commit is contained in:
Andrew Tridgell 2022-01-04 15:52:47 +11:00
parent 431330c651
commit ab64744ccd
2 changed files with 63 additions and 1 deletions

View File

@ -33,6 +33,14 @@ extern const AP_HAL::HAL& hal;
#define AP_FOLLOW_POS_P_DEFAULT 0.1f // position error gain default #define AP_FOLLOW_POS_P_DEFAULT 0.1f // position error gain default
#if APM_BUILD_TYPE(APM_BUILD_ArduPlane)
#define AP_FOLLOW_ALT_TYPE_DEFAULT 0
#else
#define AP_FOLLOW_ALT_TYPE_DEFAULT AP_FOLLOW_ALTITUDE_TYPE_RELATIVE
#endif
AP_Follow *AP_Follow::_singleton;
// table of user settable parameters // table of user settable parameters
const AP_Param::GroupInfo AP_Follow::var_info[] = { const AP_Param::GroupInfo AP_Follow::var_info[] = {
@ -117,7 +125,7 @@ const AP_Param::GroupInfo AP_Follow::var_info[] = {
// @Description: Follow altitude type // @Description: Follow altitude type
// @Values: 0:absolute, 1:relative // @Values: 0:absolute, 1:relative
// @User: Standard // @User: Standard
AP_GROUPINFO("_ALT_TYPE", 10, AP_Follow, _alt_type, AP_FOLLOW_ALTITUDE_TYPE_RELATIVE), AP_GROUPINFO("_ALT_TYPE", 10, AP_Follow, _alt_type, AP_FOLLOW_ALT_TYPE_DEFAULT),
#endif #endif
AP_GROUPEND AP_GROUPEND
@ -131,6 +139,7 @@ const AP_Param::GroupInfo AP_Follow::var_info[] = {
AP_Follow::AP_Follow() : AP_Follow::AP_Follow() :
_p_pos(AP_FOLLOW_POS_P_DEFAULT) _p_pos(AP_FOLLOW_POS_P_DEFAULT)
{ {
_singleton = this;
AP_Param::setup_object_defaults(this, var_info); AP_Param::setup_object_defaults(this, var_info);
} }
@ -479,3 +488,40 @@ void AP_Follow::clear_dist_and_bearing_to_target()
_dist_to_target = 0.0f; _dist_to_target = 0.0f;
_bearing_to_target = 0.0f; _bearing_to_target = 0.0f;
} }
// get target's estimated location and velocity (in NED), with offsets added
bool AP_Follow::get_target_location_and_velocity_ofs(Location &loc, Vector3f &vel_ned) const
{
Vector3f ofs;
if (!get_offsets_ned(ofs) ||
!get_target_location_and_velocity(loc, vel_ned)) {
return false;
}
// apply offsets
loc.offset(ofs.x, ofs.y);
loc.alt -= ofs.z*100;
return true;
}
// return true if we have a target
bool AP_Follow::have_target(void) const
{
if (!_enabled) {
return false;
}
// check for timeout
if ((_last_location_update_ms == 0) || (AP_HAL::millis() - _last_location_update_ms > AP_FOLLOW_TIMEOUT_MS)) {
return false;
}
return true;
}
namespace AP {
AP_Follow &follow()
{
return *AP_Follow::get_singleton();
}
}

View File

@ -39,6 +39,11 @@ public:
// constructor // constructor
AP_Follow(); AP_Follow();
// enable as singleton
static AP_Follow *get_singleton(void) {
return _singleton;
}
// returns true if library is enabled // returns true if library is enabled
bool enabled() const { return _enabled; } bool enabled() const { return _enabled; }
@ -58,6 +63,9 @@ public:
// get target's estimated location and velocity (in NED) // get target's estimated location and velocity (in NED)
bool get_target_location_and_velocity(Location &loc, Vector3f &vel_ned) const; bool get_target_location_and_velocity(Location &loc, Vector3f &vel_ned) const;
// get target's estimated location and velocity (in NED), with offsets added
bool get_target_location_and_velocity_ofs(Location &loc, Vector3f &vel_ned) const;
// get distance vector to target (in meters), target plus offsets, and target's velocity all in NED frame // get distance vector to target (in meters), target plus offsets, and target's velocity all in NED frame
bool get_target_dist_and_vel_ned(Vector3f &dist_ned, Vector3f &dist_with_ofs, Vector3f &vel_ned); bool get_target_dist_and_vel_ned(Vector3f &dist_ned, Vector3f &dist_with_ofs, Vector3f &vel_ned);
@ -87,10 +95,14 @@ public:
// get bearing to target (including offset) in degrees (for reporting purposes) // get bearing to target (including offset) in degrees (for reporting purposes)
float get_bearing_to_target() const { return _bearing_to_target; } float get_bearing_to_target() const { return _bearing_to_target; }
// get system time of last position update
uint32_t get_last_update_ms() const { return _last_location_update_ms; }
// parameter list // parameter list
static const struct AP_Param::GroupInfo var_info[]; static const struct AP_Param::GroupInfo var_info[];
private: private:
static AP_Follow *_singleton;
// get velocity estimate in m/s in NED frame using dt since last update // get velocity estimate in m/s in NED frame using dt since last update
bool get_velocity_ned(Vector3f &vel_ned, float dt) const; bool get_velocity_ned(Vector3f &vel_ned, float dt) const;
@ -133,3 +145,7 @@ private:
// setup jitter correction with max transport lag of 3s // setup jitter correction with max transport lag of 3s
JitterCorrection _jitter{3000}; JitterCorrection _jitter{3000};
}; };
namespace AP {
AP_Follow &follow();
};