AC_WPNav: replace inav, ahrs pointers with references
This commit is contained in:
parent
21c93e48ab
commit
fd9f8f571f
@ -77,7 +77,7 @@ const AP_Param::GroupInfo AC_WPNav::var_info[] PROGMEM = {
|
|||||||
// Note that the Vector/Matrix constructors already implicitly zero
|
// Note that the Vector/Matrix constructors already implicitly zero
|
||||||
// their values.
|
// their values.
|
||||||
//
|
//
|
||||||
AC_WPNav::AC_WPNav(const AP_InertialNav* inav, const AP_AHRS* ahrs, AC_PosControl& pos_control) :
|
AC_WPNav::AC_WPNav(const AP_InertialNav& inav, const AP_AHRS& ahrs, AC_PosControl& pos_control) :
|
||||||
_inav(inav),
|
_inav(inav),
|
||||||
_ahrs(ahrs),
|
_ahrs(ahrs),
|
||||||
_pos_control(pos_control),
|
_pos_control(pos_control),
|
||||||
@ -134,7 +134,7 @@ void AC_WPNav::set_loiter_target(const Vector3f& position, bool reset_I)
|
|||||||
/// init_loiter_target - initialize's loiter position and feed-forward velocity from current pos and velocity
|
/// init_loiter_target - initialize's loiter position and feed-forward velocity from current pos and velocity
|
||||||
void AC_WPNav::init_loiter_target()
|
void AC_WPNav::init_loiter_target()
|
||||||
{
|
{
|
||||||
Vector3f curr_vel = _inav->get_velocity();
|
Vector3f curr_vel = _inav.get_velocity();
|
||||||
|
|
||||||
// initialise pos controller speed and acceleration
|
// initialise pos controller speed and acceleration
|
||||||
_pos_control.set_speed_xy(_loiter_speed_cms);
|
_pos_control.set_speed_xy(_loiter_speed_cms);
|
||||||
@ -199,8 +199,8 @@ void AC_WPNav::calc_loiter_desired_velocity(float nav_dt)
|
|||||||
|
|
||||||
// rotate pilot input to lat/lon frame
|
// rotate pilot input to lat/lon frame
|
||||||
Vector2f desired_accel;
|
Vector2f desired_accel;
|
||||||
desired_accel.x = (_pilot_accel_fwd_cms*_ahrs->cos_yaw() - _pilot_accel_rgt_cms*_ahrs->sin_yaw());
|
desired_accel.x = (_pilot_accel_fwd_cms*_ahrs.cos_yaw() - _pilot_accel_rgt_cms*_ahrs.sin_yaw());
|
||||||
desired_accel.y = (_pilot_accel_fwd_cms*_ahrs->sin_yaw() + _pilot_accel_rgt_cms*_ahrs->cos_yaw());
|
desired_accel.y = (_pilot_accel_fwd_cms*_ahrs.sin_yaw() + _pilot_accel_rgt_cms*_ahrs.cos_yaw());
|
||||||
|
|
||||||
// get pos_control's feed forward velocity
|
// get pos_control's feed forward velocity
|
||||||
Vector2f desired_vel = _pos_control.get_desired_velocity();
|
Vector2f desired_vel = _pos_control.get_desired_velocity();
|
||||||
@ -238,7 +238,7 @@ void AC_WPNav::calc_loiter_desired_velocity(float nav_dt)
|
|||||||
/// get_bearing_to_target - get bearing to loiter target in centi-degrees
|
/// get_bearing_to_target - get bearing to loiter target in centi-degrees
|
||||||
int32_t AC_WPNav::get_loiter_bearing_to_target() const
|
int32_t AC_WPNav::get_loiter_bearing_to_target() const
|
||||||
{
|
{
|
||||||
return get_bearing_cd(_inav->get_position(), _pos_control.get_pos_target());
|
return get_bearing_cd(_inav.get_position(), _pos_control.get_pos_target());
|
||||||
}
|
}
|
||||||
|
|
||||||
/// update_loiter - run the loiter controller - should be called at 100hz
|
/// update_loiter - run the loiter controller - should be called at 100hz
|
||||||
@ -349,7 +349,7 @@ void AC_WPNav::set_wp_origin_and_destination(const Vector3f& origin, const Vecto
|
|||||||
_flags.segment_type = SEGMENT_STRAIGHT;
|
_flags.segment_type = SEGMENT_STRAIGHT;
|
||||||
|
|
||||||
// initialise the limited speed to current speed along the track
|
// initialise the limited speed to current speed along the track
|
||||||
const Vector3f &curr_vel = _inav->get_velocity();
|
const Vector3f &curr_vel = _inav.get_velocity();
|
||||||
// get speed along track (note: we convert vertical speed into horizontal speed equivalent)
|
// get speed along track (note: we convert vertical speed into horizontal speed equivalent)
|
||||||
float speed_along_track = curr_vel.x * _pos_delta_unit.x + curr_vel.y * _pos_delta_unit.y + curr_vel.z * _pos_delta_unit.z;
|
float speed_along_track = curr_vel.x * _pos_delta_unit.x + curr_vel.y * _pos_delta_unit.y + curr_vel.z * _pos_delta_unit.z;
|
||||||
_limited_speed_xy_cms = constrain_float(speed_along_track,0,_wp_speed_cms);
|
_limited_speed_xy_cms = constrain_float(speed_along_track,0,_wp_speed_cms);
|
||||||
@ -372,7 +372,7 @@ void AC_WPNav::advance_wp_target_along_track(float dt)
|
|||||||
bool reached_leash_limit = false; // true when track has reached leash limit and we need to slow down the target point
|
bool reached_leash_limit = false; // true when track has reached leash limit and we need to slow down the target point
|
||||||
|
|
||||||
// get current location
|
// get current location
|
||||||
Vector3f curr_pos = _inav->get_position();
|
Vector3f curr_pos = _inav.get_position();
|
||||||
Vector3f curr_delta = curr_pos - _origin;
|
Vector3f curr_delta = curr_pos - _origin;
|
||||||
|
|
||||||
// calculate how far along the track we are
|
// calculate how far along the track we are
|
||||||
@ -410,7 +410,7 @@ void AC_WPNav::advance_wp_target_along_track(float dt)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// get current velocity
|
// get current velocity
|
||||||
const Vector3f &curr_vel = _inav->get_velocity();
|
const Vector3f &curr_vel = _inav.get_velocity();
|
||||||
// get speed along track
|
// get speed along track
|
||||||
float speed_along_track = curr_vel.x * _pos_delta_unit.x + curr_vel.y * _pos_delta_unit.y + curr_vel.z * _pos_delta_unit.z;
|
float speed_along_track = curr_vel.x * _pos_delta_unit.x + curr_vel.y * _pos_delta_unit.y + curr_vel.z * _pos_delta_unit.z;
|
||||||
|
|
||||||
@ -485,14 +485,14 @@ void AC_WPNav::advance_wp_target_along_track(float dt)
|
|||||||
float AC_WPNav::get_wp_distance_to_destination() const
|
float AC_WPNav::get_wp_distance_to_destination() const
|
||||||
{
|
{
|
||||||
// get current location
|
// get current location
|
||||||
Vector3f curr = _inav->get_position();
|
Vector3f curr = _inav.get_position();
|
||||||
return pythagorous2(_destination.x-curr.x,_destination.y-curr.y);
|
return pythagorous2(_destination.x-curr.x,_destination.y-curr.y);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// get_wp_bearing_to_destination - get bearing to next waypoint in centi-degrees
|
/// get_wp_bearing_to_destination - get bearing to next waypoint in centi-degrees
|
||||||
int32_t AC_WPNav::get_wp_bearing_to_destination() const
|
int32_t AC_WPNav::get_wp_bearing_to_destination() const
|
||||||
{
|
{
|
||||||
return get_bearing_cd(_inav->get_position(), _destination);
|
return get_bearing_cd(_inav.get_position(), _destination);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// update_wpnav - run the wp controller - should be called at 100hz or higher
|
/// update_wpnav - run the wp controller - should be called at 100hz or higher
|
||||||
@ -685,7 +685,7 @@ void AC_WPNav::set_spline_origin_and_destination(const Vector3f& origin, const V
|
|||||||
}
|
}
|
||||||
|
|
||||||
// initialise yaw heading to current heading
|
// initialise yaw heading to current heading
|
||||||
_yaw = _ahrs->yaw_sensor;
|
_yaw = _ahrs.yaw_sensor;
|
||||||
|
|
||||||
// store origin and destination locations
|
// store origin and destination locations
|
||||||
_origin = origin;
|
_origin = origin;
|
||||||
|
@ -49,7 +49,7 @@ public:
|
|||||||
};
|
};
|
||||||
|
|
||||||
/// Constructor
|
/// Constructor
|
||||||
AC_WPNav(const AP_InertialNav* inav, const AP_AHRS* ahrs, AC_PosControl& pos_control);
|
AC_WPNav(const AP_InertialNav& inav, const AP_AHRS& ahrs, AC_PosControl& pos_control);
|
||||||
|
|
||||||
///
|
///
|
||||||
/// loiter controller
|
/// loiter controller
|
||||||
@ -244,9 +244,9 @@ protected:
|
|||||||
void calc_spline_pos_vel(float spline_time, Vector3f& position, Vector3f& velocity);
|
void calc_spline_pos_vel(float spline_time, Vector3f& position, Vector3f& velocity);
|
||||||
|
|
||||||
// references to inertial nav and ahrs libraries
|
// references to inertial nav and ahrs libraries
|
||||||
const AP_InertialNav* const _inav;
|
const AP_InertialNav& _inav;
|
||||||
const AP_AHRS* const _ahrs;
|
const AP_AHRS& _ahrs;
|
||||||
AC_PosControl& _pos_control;
|
AC_PosControl& _pos_control;
|
||||||
|
|
||||||
// parameters
|
// parameters
|
||||||
AP_Float _loiter_speed_cms; // maximum horizontal speed in cm/s while in loiter
|
AP_Float _loiter_speed_cms; // maximum horizontal speed in cm/s while in loiter
|
||||||
@ -279,11 +279,11 @@ protected:
|
|||||||
float _slow_down_dist; // vehicle should begin to slow down once it is within this distance from the destination
|
float _slow_down_dist; // vehicle should begin to slow down once it is within this distance from the destination
|
||||||
|
|
||||||
// spline variables
|
// spline variables
|
||||||
float _spline_time; // current spline time between origin and destination
|
float _spline_time; // current spline time between origin and destination
|
||||||
Vector3f _spline_origin_vel; // the target velocity vector at the origin of the spline segment
|
Vector3f _spline_origin_vel; // the target velocity vector at the origin of the spline segment
|
||||||
Vector3f _spline_destination_vel;// the target velocity vector at the destination point of the spline segment
|
Vector3f _spline_destination_vel;// the target velocity vector at the destination point of the spline segment
|
||||||
Vector3f _hermite_spline_solution[4]; // array describing spline path between origin and destination
|
Vector3f _hermite_spline_solution[4]; // array describing spline path between origin and destination
|
||||||
float _spline_vel_scaler; //
|
float _spline_vel_scaler; //
|
||||||
float _yaw; // heading according to yaw
|
float _yaw; // heading according to yaw
|
||||||
};
|
};
|
||||||
#endif // AC_WPNAV_H
|
#endif // AC_WPNAV_H
|
||||||
|
Loading…
Reference in New Issue
Block a user