AC_WPNav: replace inav, ahrs pointers with references

This commit is contained in:
Randy Mackay 2014-05-02 16:03:58 +09:00
parent 21c93e48ab
commit fd9f8f571f
2 changed files with 17 additions and 17 deletions

View File

@ -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;

View File

@ -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