Copter: rename FlightMode class to Mode

also remove unused print_FlightMode method
This commit is contained in:
Randy Mackay 2017-12-11 12:51:13 +09:00
parent 6e9de7e609
commit 06fbe8f3a7
25 changed files with 260 additions and 263 deletions

View File

@ -943,59 +943,59 @@ private:
#include "FlightMode.h" #include "FlightMode.h"
Copter::FlightMode *flightmode; Copter::Mode *flightmode;
#if FRAME_CONFIG == HELI_FRAME #if FRAME_CONFIG == HELI_FRAME
Copter::FlightMode_Acro_Heli flightmode_acro{*this}; Copter::ModeAcro_Heli flightmode_acro{*this};
#else #else
Copter::FlightMode_Acro flightmode_acro{*this}; Copter::ModeAcro flightmode_acro{*this};
#endif #endif
Copter::FlightMode_AltHold flightmode_althold{*this}; Copter::ModeAltHold flightmode_althold{*this};
Copter::FlightMode_Auto flightmode_auto{*this, mission, circle_nav}; Copter::ModeAuto flightmode_auto{*this, mission, circle_nav};
#if AUTOTUNE_ENABLED == ENABLED #if AUTOTUNE_ENABLED == ENABLED
Copter::FlightMode_AutoTune flightmode_autotune{*this}; Copter::ModeAutoTune flightmode_autotune{*this};
#endif #endif
Copter::FlightMode_Brake flightmode_brake{*this}; Copter::ModeBrake flightmode_brake{*this};
Copter::FlightMode_Circle flightmode_circle{*this, circle_nav}; Copter::ModeCircle flightmode_circle{*this, circle_nav};
Copter::FlightMode_Drift flightmode_drift{*this}; Copter::ModeDrift flightmode_drift{*this};
Copter::FlightMode_Flip flightmode_flip{*this}; Copter::ModeFlip flightmode_flip{*this};
Copter::FlightMode_Guided flightmode_guided{*this}; Copter::ModeGuided flightmode_guided{*this};
Copter::FlightMode_Land flightmode_land{*this}; Copter::ModeLand flightmode_land{*this};
Copter::FlightMode_Loiter flightmode_loiter{*this}; Copter::ModeLoiter flightmode_loiter{*this};
Copter::FlightMode_PosHold flightmode_poshold{*this}; Copter::ModePosHold flightmode_poshold{*this};
Copter::FlightMode_RTL flightmode_rtl{*this}; Copter::ModeRTL flightmode_rtl{*this};
#if FRAME_CONFIG == HELI_FRAME #if FRAME_CONFIG == HELI_FRAME
Copter::FlightMode_Stabilize_Heli flightmode_stabilize{*this}; Copter::ModeStabilize_Heli flightmode_stabilize{*this};
#else #else
Copter::FlightMode_Stabilize flightmode_stabilize{*this}; Copter::ModeStabilize flightmode_stabilize{*this};
#endif #endif
Copter::FlightMode_Sport flightmode_sport{*this}; Copter::ModeSport flightmode_sport{*this};
Copter::FlightMode_Avoid_ADSB flightmode_avoid_adsb{*this}; Copter::ModeAvoidADSB flightmode_avoid_adsb{*this};
Copter::FlightMode_Throw flightmode_throw{*this}; Copter::ModeThrow flightmode_throw{*this};
Copter::FlightMode_Guided_NoGPS flightmode_guided_nogps{*this}; Copter::ModeGuidedNoGPS flightmode_guided_nogps{*this};
Copter::FlightMode_SmartRTL flightmode_smartrtl{*this}; Copter::ModeSmartRTL flightmode_smartrtl{*this};
Copter::FlightMode *flightmode_for_mode(const uint8_t mode); Copter::Mode *flightmode_for_mode(const uint8_t mode);
void exit_mode(FlightMode *&old_flightmode, FlightMode *&new_flightmode); void exit_mode(Mode *&old_flightmode, Mode *&new_flightmode);
public: public:
void mavlink_delay_cb(); void mavlink_delay_cb();

View File

@ -2,13 +2,13 @@
// this class is #included into the Copter:: namespace // this class is #included into the Copter:: namespace
class FlightMode { class Mode {
friend class Copter; friend class Copter;
friend class AP_Arming_Copter; friend class AP_Arming_Copter;
public: public:
FlightMode(Copter &copter) : Mode(Copter &copter) :
_copter(copter), _copter(copter),
g(copter.g), g(copter.g),
g2(copter.g2), g2(copter.g2),
@ -42,9 +42,6 @@ protected:
virtual bool requires_GPS() const = 0; virtual bool requires_GPS() const = 0;
virtual bool has_manual_throttle() const = 0; virtual bool has_manual_throttle() const = 0;
virtual bool allows_arming(bool from_gcs) const = 0; virtual bool allows_arming(bool from_gcs) const = 0;
void print_FlightMode(AP_HAL::BetterStream *port) const {
port->print(name());
}
virtual const char *name() const = 0; virtual const char *name() const = 0;
// returns a string for this flightmode, exactly 4 bytes // returns a string for this flightmode, exactly 4 bytes
@ -90,7 +87,7 @@ protected:
#endif #endif
// pass-through functions to reduce code churn on conversion; // pass-through functions to reduce code churn on conversion;
// these are candidates for moving into the FlightMode base // these are candidates for moving into the Mode base
// class. // class.
void get_pilot_desired_lean_angles(float roll_in, float pitch_in, float &roll_out, float &pitch_out, float angle_max) { void get_pilot_desired_lean_angles(float roll_in, float pitch_in, float &roll_out, float &pitch_out, float angle_max) {
_copter.get_pilot_desired_lean_angles(roll_in, pitch_in, roll_out, pitch_out, angle_max); _copter.get_pilot_desired_lean_angles(roll_in, pitch_in, roll_out, pitch_out, angle_max);
@ -166,12 +163,12 @@ protected:
}; };
class FlightMode_Acro : public FlightMode { class ModeAcro : public Mode {
public: public:
FlightMode_Acro(Copter &copter) : ModeAcro(Copter &copter) :
Copter::FlightMode(copter) Copter::Mode(copter)
{ } { }
virtual bool init(bool ignore_checks) override; virtual bool init(bool ignore_checks) override;
virtual void run() override; virtual void run() override;
@ -193,12 +190,12 @@ private:
}; };
#if FRAME_CONFIG == HELI_FRAME #if FRAME_CONFIG == HELI_FRAME
class FlightMode_Acro_Heli : public FlightMode_Acro { class ModeAcro_Heli : public ModeAcro {
public: public:
FlightMode_Acro_Heli(Copter &copter) : ModeAcro_Heli(Copter &copter) :
Copter::FlightMode_Acro(copter) Copter::ModeAcro(copter)
{ } { }
bool init(bool ignore_checks) override; bool init(bool ignore_checks) override;
@ -210,12 +207,12 @@ private:
#endif #endif
class FlightMode_AltHold : public FlightMode { class ModeAltHold : public Mode {
public: public:
FlightMode_AltHold(Copter &copter) : ModeAltHold(Copter &copter) :
Copter::FlightMode(copter) Copter::Mode(copter)
{ } { }
bool init(bool ignore_checks) override; bool init(bool ignore_checks) override;
@ -236,12 +233,12 @@ private:
}; };
class FlightMode_Auto : public FlightMode { class ModeAuto : public Mode {
public: public:
FlightMode_Auto(Copter &copter, AP_Mission &_mission, AC_Circle *& _circle_nav) : ModeAuto(Copter &copter, AP_Mission &_mission, AC_Circle *& _circle_nav) :
Copter::FlightMode(copter), Copter::Mode(copter),
mission(_mission), mission(_mission),
circle_nav(_circle_nav) circle_nav(_circle_nav)
{ } { }
@ -313,12 +310,12 @@ private:
#if AUTOTUNE_ENABLED == ENABLED #if AUTOTUNE_ENABLED == ENABLED
class FlightMode_AutoTune : public FlightMode { class ModeAutoTune : public Mode {
public: public:
FlightMode_AutoTune(Copter &copter) : ModeAutoTune(Copter &copter) :
Copter::FlightMode(copter) Copter::Mode(copter)
{ } { }
bool init(bool ignore_checks) override; bool init(bool ignore_checks) override;
@ -465,12 +462,12 @@ private:
#endif #endif
class FlightMode_Brake : public FlightMode { class ModeBrake : public Mode {
public: public:
FlightMode_Brake(Copter &copter) : ModeBrake(Copter &copter) :
Copter::FlightMode(copter) Copter::Mode(copter)
{ } { }
bool init(bool ignore_checks) override; bool init(bool ignore_checks) override;
@ -496,12 +493,12 @@ private:
}; };
class FlightMode_Circle : public FlightMode { class ModeCircle : public Mode {
public: public:
FlightMode_Circle(Copter &copter, AC_Circle *& _circle_nav) : ModeCircle(Copter &copter, AC_Circle *& _circle_nav) :
Copter::FlightMode(copter), Copter::Mode(copter),
circle_nav(_circle_nav) circle_nav(_circle_nav)
{ } { }
@ -534,12 +531,12 @@ private:
}; };
class FlightMode_Drift : public FlightMode { class ModeDrift : public Mode {
public: public:
FlightMode_Drift(Copter &copter) : ModeDrift(Copter &copter) :
Copter::FlightMode(copter) Copter::Mode(copter)
{ } { }
virtual bool init(bool ignore_checks) override; virtual bool init(bool ignore_checks) override;
@ -562,12 +559,12 @@ private:
}; };
class FlightMode_Flip : public FlightMode { class ModeFlip : public Mode {
public: public:
FlightMode_Flip(Copter &copter) : ModeFlip(Copter &copter) :
Copter::FlightMode(copter) Copter::Mode(copter)
{ } { }
virtual bool init(bool ignore_checks) override; virtual bool init(bool ignore_checks) override;
@ -591,12 +588,12 @@ private:
}; };
class FlightMode_Guided : public FlightMode { class ModeGuided : public Mode {
public: public:
FlightMode_Guided(Copter &copter) : ModeGuided(Copter &copter) :
Copter::FlightMode(copter) { } Copter::Mode(copter) { }
bool init(bool ignore_checks) override; bool init(bool ignore_checks) override;
void run() override; void run() override;
@ -650,12 +647,12 @@ private:
}; };
class FlightMode_Guided_NoGPS : public FlightMode_Guided { class ModeGuidedNoGPS : public ModeGuided {
public: public:
FlightMode_Guided_NoGPS(Copter &copter) : ModeGuidedNoGPS(Copter &copter) :
Copter::FlightMode_Guided(copter) { } Copter::ModeGuided(copter) { }
bool init(bool ignore_checks) override; bool init(bool ignore_checks) override;
void run() override; void run() override;
@ -675,12 +672,12 @@ private:
}; };
class FlightMode_Land : public FlightMode { class ModeLand : public Mode {
public: public:
FlightMode_Land(Copter &copter) : ModeLand(Copter &copter) :
Copter::FlightMode(copter) Copter::Mode(copter)
{ } { }
bool init(bool ignore_checks) override; bool init(bool ignore_checks) override;
@ -709,12 +706,12 @@ private:
}; };
class FlightMode_Loiter : public FlightMode { class ModeLoiter : public Mode {
public: public:
FlightMode_Loiter(Copter &copter) : ModeLoiter(Copter &copter) :
Copter::FlightMode(copter) Copter::Mode(copter)
{ } { }
bool init(bool ignore_checks) override; bool init(bool ignore_checks) override;
@ -755,12 +752,12 @@ private:
}; };
class FlightMode_PosHold : public FlightMode { class ModePosHold : public Mode {
public: public:
FlightMode_PosHold(Copter &copter) : ModePosHold(Copter &copter) :
Copter::FlightMode(copter) Copter::Mode(copter)
{ } { }
bool init(bool ignore_checks) override; bool init(bool ignore_checks) override;
@ -789,12 +786,12 @@ private:
}; };
class FlightMode_RTL : public FlightMode { class ModeRTL : public Mode {
public: public:
FlightMode_RTL(Copter &copter) : ModeRTL(Copter &copter) :
Copter::FlightMode(copter) Copter::Mode(copter)
{ } { }
bool init(bool ignore_checks) override; bool init(bool ignore_checks) override;
@ -865,12 +862,12 @@ private:
}; };
class FlightMode_SmartRTL : public FlightMode_RTL { class ModeSmartRTL : public ModeRTL {
public: public:
FlightMode_SmartRTL(Copter &copter) : ModeSmartRTL(Copter &copter) :
FlightMode_SmartRTL::FlightMode_RTL(copter) ModeSmartRTL::ModeRTL(copter)
{ } { }
bool init(bool ignore_checks) override; bool init(bool ignore_checks) override;
@ -907,12 +904,12 @@ private:
}; };
class FlightMode_Sport : public FlightMode { class ModeSport : public Mode {
public: public:
FlightMode_Sport(Copter &copter) : ModeSport(Copter &copter) :
Copter::FlightMode(copter) Copter::Mode(copter)
{ } { }
virtual bool init(bool ignore_checks) override; virtual bool init(bool ignore_checks) override;
@ -933,12 +930,12 @@ private:
}; };
class FlightMode_Stabilize : public FlightMode { class ModeStabilize : public Mode {
public: public:
FlightMode_Stabilize(Copter &copter) : ModeStabilize(Copter &copter) :
Copter::FlightMode(copter) Copter::Mode(copter)
{ } { }
virtual bool init(bool ignore_checks) override; virtual bool init(bool ignore_checks) override;
@ -959,12 +956,12 @@ private:
}; };
#if FRAME_CONFIG == HELI_FRAME #if FRAME_CONFIG == HELI_FRAME
class FlightMode_Stabilize_Heli : public FlightMode_Stabilize { class ModeStabilize_Heli : public ModeStabilize {
public: public:
FlightMode_Stabilize_Heli(Copter &copter) : ModeStabilize_Heli(Copter &copter) :
Copter::FlightMode_Stabilize(copter) Copter::ModeStabilize(copter)
{ } { }
bool init(bool ignore_checks) override; bool init(bool ignore_checks) override;
@ -978,12 +975,12 @@ private:
#endif #endif
class FlightMode_Throw : public FlightMode { class ModeThrow : public Mode {
public: public:
FlightMode_Throw(Copter &copter) : ModeThrow(Copter &copter) :
Copter::FlightMode(copter) Copter::Mode(copter)
{ } { }
bool init(bool ignore_checks) override; bool init(bool ignore_checks) override;
@ -1017,12 +1014,12 @@ private:
}; };
class FlightMode_Avoid_ADSB : public FlightMode_Guided { class ModeAvoidADSB : public ModeGuided {
public: public:
FlightMode_Avoid_ADSB(Copter &copter) : ModeAvoidADSB(Copter &copter) :
Copter::FlightMode_Guided(copter) { } Copter::ModeGuided(copter) { }
bool init(bool ignore_checks) override; bool init(bool ignore_checks) override;
void run() override; void run() override;

View File

@ -21,7 +21,7 @@ struct PACKED log_AutoTune {
}; };
// Write an Autotune data packet // Write an Autotune data packet
void Copter::FlightMode_AutoTune::Log_Write_AutoTune(uint8_t _axis, uint8_t tune_step, float meas_target, float meas_min, float meas_max, float new_gain_rp, float new_gain_rd, float new_gain_sp, float new_ddt) void Copter::ModeAutoTune::Log_Write_AutoTune(uint8_t _axis, uint8_t tune_step, float meas_target, float meas_min, float meas_max, float new_gain_rp, float new_gain_rd, float new_gain_sp, float new_ddt)
{ {
struct log_AutoTune pkt = { struct log_AutoTune pkt = {
LOG_PACKET_HEADER_INIT(LOG_AUTOTUNE_MSG), LOG_PACKET_HEADER_INIT(LOG_AUTOTUNE_MSG),
@ -47,7 +47,7 @@ struct PACKED log_AutoTuneDetails {
}; };
// Write an Autotune data packet // Write an Autotune data packet
void Copter::FlightMode_AutoTune::Log_Write_AutoTuneDetails(float angle_cd, float rate_cds) void Copter::ModeAutoTune::Log_Write_AutoTuneDetails(float angle_cd, float rate_cds)
{ {
struct log_AutoTuneDetails pkt = { struct log_AutoTuneDetails pkt = {
LOG_PACKET_HEADER_INIT(LOG_AUTOTUNEDETAILS_MSG), LOG_PACKET_HEADER_INIT(LOG_AUTOTUNEDETAILS_MSG),

View File

@ -6,7 +6,7 @@
* Init and run calls for acro flight mode * Init and run calls for acro flight mode
*/ */
bool Copter::FlightMode_Acro::init(bool ignore_checks) bool Copter::ModeAcro::init(bool ignore_checks)
{ {
// if landed and the mode we're switching from does not have manual throttle and the throttle stick is too high // if landed and the mode we're switching from does not have manual throttle and the throttle stick is too high
if (motors->armed() && ap.land_complete && !_copter.flightmode->has_manual_throttle() && if (motors->armed() && ap.land_complete && !_copter.flightmode->has_manual_throttle() &&
@ -19,7 +19,7 @@ bool Copter::FlightMode_Acro::init(bool ignore_checks)
return true; return true;
} }
void Copter::FlightMode_Acro::run() void Copter::ModeAcro::run()
{ {
float target_roll, target_pitch, target_yaw; float target_roll, target_pitch, target_yaw;
float pilot_throttle_scaled; float pilot_throttle_scaled;
@ -52,7 +52,7 @@ void Copter::FlightMode_Acro::run()
// get_pilot_desired_angle_rates - transform pilot's roll pitch and yaw input into a desired lean angle rates // get_pilot_desired_angle_rates - transform pilot's roll pitch and yaw input into a desired lean angle rates
// returns desired angle rates in centi-degrees-per-second // returns desired angle rates in centi-degrees-per-second
void Copter::FlightMode_Acro::get_pilot_desired_angle_rates(int16_t roll_in, int16_t pitch_in, int16_t yaw_in, float &roll_out, float &pitch_out, float &yaw_out) void Copter::ModeAcro::get_pilot_desired_angle_rates(int16_t roll_in, int16_t pitch_in, int16_t yaw_in, float &roll_out, float &pitch_out, float &yaw_out)
{ {
float rate_limit; float rate_limit;
Vector3f rate_ef_level, rate_bf_level, rate_bf_request; Vector3f rate_ef_level, rate_bf_level, rate_bf_request;

View File

@ -6,7 +6,7 @@
*/ */
// althold_init - initialise althold controller // althold_init - initialise althold controller
bool Copter::FlightMode_AltHold::init(bool ignore_checks) bool Copter::ModeAltHold::init(bool ignore_checks)
{ {
// initialize vertical speeds and leash lengths // initialize vertical speeds and leash lengths
pos_control->set_speed_z(-get_pilot_speed_dn(), g.pilot_speed_up); pos_control->set_speed_z(-get_pilot_speed_dn(), g.pilot_speed_up);
@ -26,7 +26,7 @@ bool Copter::FlightMode_AltHold::init(bool ignore_checks)
// althold_run - runs the althold controller // althold_run - runs the althold controller
// should be called at 100hz or more // should be called at 100hz or more
void Copter::FlightMode_AltHold::run() void Copter::ModeAltHold::run()
{ {
AltHoldModeState althold_state; AltHoldModeState althold_state;
float takeoff_climb_rate = 0.0f; float takeoff_climb_rate = 0.0f;

View File

@ -18,7 +18,7 @@
*/ */
// auto_init - initialise auto controller // auto_init - initialise auto controller
bool Copter::FlightMode_Auto::init(bool ignore_checks) bool Copter::ModeAuto::init(bool ignore_checks)
{ {
if ((_copter.position_ok() && mission.num_commands() > 1) || ignore_checks) { if ((_copter.position_ok() && mission.num_commands() > 1) || ignore_checks) {
_mode = Auto_Loiter; _mode = Auto_Loiter;
@ -52,7 +52,7 @@ bool Copter::FlightMode_Auto::init(bool ignore_checks)
// auto_run - runs the auto controller // auto_run - runs the auto controller
// should be called at 100hz or more // should be called at 100hz or more
// relies on run_autopilot being called at 10hz which handles decision making and non-navigation related commands // relies on run_autopilot being called at 10hz which handles decision making and non-navigation related commands
void Copter::FlightMode_Auto::run() void Copter::ModeAuto::run()
{ {
// call the correct auto controller // call the correct auto controller
switch (_mode) { switch (_mode) {
@ -99,7 +99,7 @@ void Copter::FlightMode_Auto::run()
} }
// auto_takeoff_start - initialises waypoint controller to implement take-off // auto_takeoff_start - initialises waypoint controller to implement take-off
void Copter::FlightMode_Auto::takeoff_start(const Location& dest_loc) void Copter::ModeAuto::takeoff_start(const Location& dest_loc)
{ {
_mode = Auto_TakeOff; _mode = Auto_TakeOff;
@ -147,7 +147,7 @@ void Copter::FlightMode_Auto::takeoff_start(const Location& dest_loc)
// auto_takeoff_run - takeoff in auto mode // auto_takeoff_run - takeoff in auto mode
// called by auto_run at 100hz or more // called by auto_run at 100hz or more
void Copter::FlightMode_Auto::takeoff_run() void Copter::ModeAuto::takeoff_run()
{ {
// if not auto armed or motor interlock not enabled set throttle to zero and exit immediately // if not auto armed or motor interlock not enabled set throttle to zero and exit immediately
if (!motors->armed() || !ap.auto_armed || !motors->get_interlock()) { if (!motors->armed() || !ap.auto_armed || !motors->get_interlock()) {
@ -200,7 +200,7 @@ void Copter::FlightMode_Auto::takeoff_run()
} }
// auto_wp_start - initialises waypoint controller to implement flying to a particular destination // auto_wp_start - initialises waypoint controller to implement flying to a particular destination
void Copter::FlightMode_Auto::wp_start(const Vector3f& destination) void Copter::ModeAuto::wp_start(const Vector3f& destination)
{ {
_mode = Auto_WP; _mode = Auto_WP;
@ -215,7 +215,7 @@ void Copter::FlightMode_Auto::wp_start(const Vector3f& destination)
} }
// auto_wp_start - initialises waypoint controller to implement flying to a particular destination // auto_wp_start - initialises waypoint controller to implement flying to a particular destination
void Copter::FlightMode_Auto::wp_start(const Location_Class& dest_loc) void Copter::ModeAuto::wp_start(const Location_Class& dest_loc)
{ {
_mode = Auto_WP; _mode = Auto_WP;
@ -235,7 +235,7 @@ void Copter::FlightMode_Auto::wp_start(const Location_Class& dest_loc)
// auto_wp_run - runs the auto waypoint controller // auto_wp_run - runs the auto waypoint controller
// called by auto_run at 100hz or more // called by auto_run at 100hz or more
void Copter::FlightMode_Auto::wp_run() void Copter::ModeAuto::wp_run()
{ {
// if not auto armed or motor interlock not enabled set throttle to zero and exit immediately // if not auto armed or motor interlock not enabled set throttle to zero and exit immediately
if (!motors->armed() || !ap.auto_armed || !motors->get_interlock()) { if (!motors->armed() || !ap.auto_armed || !motors->get_interlock()) {
@ -285,7 +285,7 @@ void Copter::FlightMode_Auto::wp_run()
// auto_spline_start - initialises waypoint controller to implement flying to a particular destination using the spline controller // auto_spline_start - initialises waypoint controller to implement flying to a particular destination using the spline controller
// seg_end_type can be SEGMENT_END_STOP, SEGMENT_END_STRAIGHT or SEGMENT_END_SPLINE. If Straight or Spline the next_destination should be provided // seg_end_type can be SEGMENT_END_STOP, SEGMENT_END_STRAIGHT or SEGMENT_END_SPLINE. If Straight or Spline the next_destination should be provided
void Copter::FlightMode_Auto::spline_start(const Location_Class& destination, bool stopped_at_start, void Copter::ModeAuto::spline_start(const Location_Class& destination, bool stopped_at_start,
AC_WPNav::spline_segment_end_type seg_end_type, AC_WPNav::spline_segment_end_type seg_end_type,
const Location_Class& next_destination) const Location_Class& next_destination)
{ {
@ -307,7 +307,7 @@ void Copter::FlightMode_Auto::spline_start(const Location_Class& destination, bo
// auto_spline_run - runs the auto spline controller // auto_spline_run - runs the auto spline controller
// called by auto_run at 100hz or more // called by auto_run at 100hz or more
void Copter::FlightMode_Auto::spline_run() void Copter::ModeAuto::spline_run()
{ {
// if not auto armed or motor interlock not enabled set throttle to zero and exit immediately // if not auto armed or motor interlock not enabled set throttle to zero and exit immediately
if (!motors->armed() || !ap.auto_armed || !motors->get_interlock()) { if (!motors->armed() || !ap.auto_armed || !motors->get_interlock()) {
@ -356,7 +356,7 @@ void Copter::FlightMode_Auto::spline_run()
} }
// auto_land_start - initialises controller to implement a landing // auto_land_start - initialises controller to implement a landing
void Copter::FlightMode_Auto::land_start() void Copter::ModeAuto::land_start()
{ {
// set target to stopping point // set target to stopping point
Vector3f stopping_point; Vector3f stopping_point;
@ -367,7 +367,7 @@ void Copter::FlightMode_Auto::land_start()
} }
// auto_land_start - initialises controller to implement a landing // auto_land_start - initialises controller to implement a landing
void Copter::FlightMode_Auto::land_start(const Vector3f& destination) void Copter::ModeAuto::land_start(const Vector3f& destination)
{ {
_mode = Auto_Land; _mode = Auto_Land;
@ -386,7 +386,7 @@ void Copter::FlightMode_Auto::land_start(const Vector3f& destination)
// auto_land_run - lands in auto mode // auto_land_run - lands in auto mode
// called by auto_run at 100hz or more // called by auto_run at 100hz or more
void Copter::FlightMode_Auto::land_run() void Copter::ModeAuto::land_run()
{ {
// if not auto armed or landed or motor interlock not enabled set throttle to zero and exit immediately // if not auto armed or landed or motor interlock not enabled set throttle to zero and exit immediately
if (!motors->armed() || !ap.auto_armed || ap.land_complete || !motors->get_interlock()) { if (!motors->armed() || !ap.auto_armed || ap.land_complete || !motors->get_interlock()) {
@ -411,7 +411,7 @@ void Copter::FlightMode_Auto::land_run()
_copter.land_run_vertical_control(); _copter.land_run_vertical_control();
} }
bool Copter::FlightMode_Auto::landing_gear_should_be_deployed() bool Copter::ModeAuto::landing_gear_should_be_deployed()
{ {
switch(_mode) { switch(_mode) {
case Auto_Land: case Auto_Land:
@ -433,7 +433,7 @@ bool Copter::FlightMode_Auto::landing_gear_should_be_deployed()
} }
// auto_rtl_start - initialises RTL in AUTO flight mode // auto_rtl_start - initialises RTL in AUTO flight mode
void Copter::FlightMode_Auto::rtl_start() void Copter::ModeAuto::rtl_start()
{ {
_mode = Auto_RTL; _mode = Auto_RTL;
@ -443,7 +443,7 @@ void Copter::FlightMode_Auto::rtl_start()
// auto_rtl_run - rtl in AUTO flight mode // auto_rtl_run - rtl in AUTO flight mode
// called by auto_run at 100hz or more // called by auto_run at 100hz or more
void Copter::FlightMode_Auto::rtl_run() void Copter::ModeAuto::rtl_run()
{ {
// call regular rtl flight mode run function // call regular rtl flight mode run function
_copter.flightmode_rtl.run(false); _copter.flightmode_rtl.run(false);
@ -451,7 +451,7 @@ void Copter::FlightMode_Auto::rtl_run()
// auto_circle_movetoedge_start - initialise waypoint controller to move to edge of a circle with it's center at the specified location // auto_circle_movetoedge_start - initialise waypoint controller to move to edge of a circle with it's center at the specified location
// we assume the caller has performed all required GPS_ok checks // we assume the caller has performed all required GPS_ok checks
void Copter::FlightMode_Auto::circle_movetoedge_start(const Location_Class &circle_center, float radius_m) void Copter::ModeAuto::circle_movetoedge_start(const Location_Class &circle_center, float radius_m)
{ {
// convert location to vector from ekf origin // convert location to vector from ekf origin
Vector3f circle_center_neu; Vector3f circle_center_neu;
@ -505,7 +505,7 @@ void Copter::FlightMode_Auto::circle_movetoedge_start(const Location_Class &circ
// auto_circle_start - initialises controller to fly a circle in AUTO flight mode // auto_circle_start - initialises controller to fly a circle in AUTO flight mode
// assumes that circle_nav object has already been initialised with circle center and radius // assumes that circle_nav object has already been initialised with circle center and radius
void Copter::FlightMode_Auto::circle_start() void Copter::ModeAuto::circle_start()
{ {
_mode = Auto_Circle; _mode = Auto_Circle;
@ -515,7 +515,7 @@ void Copter::FlightMode_Auto::circle_start()
// auto_circle_run - circle in AUTO flight mode // auto_circle_run - circle in AUTO flight mode
// called by auto_run at 100hz or more // called by auto_run at 100hz or more
void Copter::FlightMode_Auto::circle_run() void Copter::ModeAuto::circle_run()
{ {
// call circle controller // call circle controller
circle_nav->update(); circle_nav->update();
@ -529,7 +529,7 @@ void Copter::FlightMode_Auto::circle_run()
#if NAV_GUIDED == ENABLED #if NAV_GUIDED == ENABLED
// auto_nav_guided_start - hand over control to external navigation controller in AUTO mode // auto_nav_guided_start - hand over control to external navigation controller in AUTO mode
void Copter::FlightMode_Auto::nav_guided_start() void Copter::ModeAuto::nav_guided_start()
{ {
_mode = Auto_NavGuided; _mode = Auto_NavGuided;
@ -542,7 +542,7 @@ void Copter::FlightMode_Auto::nav_guided_start()
// auto_nav_guided_run - allows control by external navigation controller // auto_nav_guided_run - allows control by external navigation controller
// called by auto_run at 100hz or more // called by auto_run at 100hz or more
void Copter::FlightMode_Auto::nav_guided_run() void Copter::ModeAuto::nav_guided_run()
{ {
// call regular guided flight mode run function // call regular guided flight mode run function
_copter.flightmode_guided.run(); _copter.flightmode_guided.run();
@ -551,7 +551,7 @@ void Copter::FlightMode_Auto::nav_guided_run()
// auto_loiter_start - initialises loitering in auto mode // auto_loiter_start - initialises loitering in auto mode
// returns success/failure because this can be called by exit_mission // returns success/failure because this can be called by exit_mission
bool Copter::FlightMode_Auto::loiter_start() bool Copter::ModeAuto::loiter_start()
{ {
// return failure if GPS is bad // return failure if GPS is bad
if (!_copter.position_ok()) { if (!_copter.position_ok()) {
@ -574,7 +574,7 @@ bool Copter::FlightMode_Auto::loiter_start()
// auto_loiter_run - loiter in AUTO flight mode // auto_loiter_run - loiter in AUTO flight mode
// called by auto_run at 100hz or more // called by auto_run at 100hz or more
void Copter::FlightMode_Auto::loiter_run() void Copter::ModeAuto::loiter_run()
{ {
// if not auto armed or motor interlock not enabled set throttle to zero and exit immediately // if not auto armed or motor interlock not enabled set throttle to zero and exit immediately
if (!motors->armed() || !ap.auto_armed || ap.land_complete || !motors->get_interlock()) { if (!motors->armed() || !ap.auto_armed || ap.land_complete || !motors->get_interlock()) {
@ -792,7 +792,7 @@ float Copter::get_auto_yaw_rate_cds(void)
} }
// auto_payload_place_start - initialises controller to implement a placing // auto_payload_place_start - initialises controller to implement a placing
void Copter::FlightMode_Auto::payload_place_start() void Copter::ModeAuto::payload_place_start()
{ {
// set target to stopping point // set target to stopping point
Vector3f stopping_point; Vector3f stopping_point;
@ -804,7 +804,7 @@ void Copter::FlightMode_Auto::payload_place_start()
} }
// auto_payload_place_start - initialises controller to implement placement of a load // auto_payload_place_start - initialises controller to implement placement of a load
void Copter::FlightMode_Auto::payload_place_start(const Vector3f& destination) void Copter::ModeAuto::payload_place_start(const Vector3f& destination)
{ {
_mode = Auto_NavPayloadPlace; _mode = Auto_NavPayloadPlace;
_copter.nav_payload_place.state = PayloadPlaceStateType_Calibrating_Hover_Start; _copter.nav_payload_place.state = PayloadPlaceStateType_Calibrating_Hover_Start;
@ -822,7 +822,7 @@ void Copter::FlightMode_Auto::payload_place_start(const Vector3f& destination)
set_auto_yaw_mode(AUTO_YAW_HOLD); set_auto_yaw_mode(AUTO_YAW_HOLD);
} }
bool Copter::FlightMode_Auto::payload_place_run_should_run() bool Copter::ModeAuto::payload_place_run_should_run()
{ {
// muts be armed // muts be armed
if (!motors->armed()) { if (!motors->armed()) {
@ -846,7 +846,7 @@ bool Copter::FlightMode_Auto::payload_place_run_should_run()
// auto_payload_place_run - places an object in auto mode // auto_payload_place_run - places an object in auto mode
// called by auto_run at 100hz or more // called by auto_run at 100hz or more
void Copter::FlightMode_Auto::payload_place_run() void Copter::ModeAuto::payload_place_run()
{ {
if (!payload_place_run_should_run()) { if (!payload_place_run_should_run()) {
#if FRAME_CONFIG == HELI_FRAME // Helicopters always stabilize roll/pitch/yaw #if FRAME_CONFIG == HELI_FRAME // Helicopters always stabilize roll/pitch/yaw
@ -884,7 +884,7 @@ void Copter::FlightMode_Auto::payload_place_run()
} }
} }
void Copter::FlightMode_Auto::payload_place_run_loiter() void Copter::ModeAuto::payload_place_run_loiter()
{ {
// loiter... // loiter...
_copter.land_run_horizontal_control(); _copter.land_run_horizontal_control();
@ -900,7 +900,7 @@ void Copter::FlightMode_Auto::payload_place_run_loiter()
pos_control->update_z_controller(); pos_control->update_z_controller();
} }
void Copter::FlightMode_Auto::payload_place_run_descend() void Copter::ModeAuto::payload_place_run_descend()
{ {
_copter.land_run_horizontal_control(); _copter.land_run_horizontal_control();
_copter.land_run_vertical_control(); _copter.land_run_vertical_control();

View File

@ -93,7 +93,7 @@
#define AUTOTUNE_ANNOUNCE_INTERVAL_MS 2000 #define AUTOTUNE_ANNOUNCE_INTERVAL_MS 2000
// autotune_init - should be called when autotune mode is selected // autotune_init - should be called when autotune mode is selected
bool Copter::FlightMode_AutoTune::init(bool ignore_checks) bool Copter::ModeAutoTune::init(bool ignore_checks)
{ {
bool success = true; bool success = true;
@ -145,7 +145,7 @@ bool Copter::FlightMode_AutoTune::init(bool ignore_checks)
} }
// stop - should be called when the ch7/ch8 switch is switched OFF // stop - should be called when the ch7/ch8 switch is switched OFF
void Copter::FlightMode_AutoTune::stop() void Copter::ModeAutoTune::stop()
{ {
// set gains to their original values // set gains to their original values
load_orig_gains(); load_orig_gains();
@ -162,7 +162,7 @@ void Copter::FlightMode_AutoTune::stop()
} }
// start - Initialize autotune flight mode // start - Initialize autotune flight mode
bool Copter::FlightMode_AutoTune::start(bool ignore_checks) bool Copter::ModeAutoTune::start(bool ignore_checks)
{ {
// only allow flip from Stabilize, AltHold, PosHold or Loiter modes // only allow flip from Stabilize, AltHold, PosHold or Loiter modes
if (_copter.control_mode != STABILIZE && _copter.control_mode != ALT_HOLD && if (_copter.control_mode != STABILIZE && _copter.control_mode != ALT_HOLD &&
@ -193,7 +193,7 @@ bool Copter::FlightMode_AutoTune::start(bool ignore_checks)
return true; return true;
} }
const char *Copter::FlightMode_AutoTune::level_issue_string() const const char *Copter::ModeAutoTune::level_issue_string() const
{ {
switch (level_problem.issue) { switch (level_problem.issue) {
case LEVEL_ISSUE_NONE: case LEVEL_ISSUE_NONE:
@ -214,7 +214,7 @@ const char *Copter::FlightMode_AutoTune::level_issue_string() const
return "Bug"; return "Bug";
} }
void Copter::FlightMode_AutoTune::send_step_string() void Copter::ModeAutoTune::send_step_string()
{ {
if (pilot_override) { if (pilot_override) {
gcs().send_text(MAV_SEVERITY_INFO, "AutoTune: Paused: Pilot Override Active"); gcs().send_text(MAV_SEVERITY_INFO, "AutoTune: Paused: Pilot Override Active");
@ -234,7 +234,7 @@ void Copter::FlightMode_AutoTune::send_step_string()
gcs().send_text(MAV_SEVERITY_INFO, "AutoTune: unknown step"); gcs().send_text(MAV_SEVERITY_INFO, "AutoTune: unknown step");
} }
const char *Copter::FlightMode_AutoTune::type_string() const const char *Copter::ModeAutoTune::type_string() const
{ {
switch (tune_type) { switch (tune_type) {
case RD_UP: case RD_UP:
@ -251,7 +251,7 @@ const char *Copter::FlightMode_AutoTune::type_string() const
return "Bug"; return "Bug";
} }
void Copter::FlightMode_AutoTune::do_gcs_announcements() void Copter::ModeAutoTune::do_gcs_announcements()
{ {
const uint32_t now = millis(); const uint32_t now = millis();
if (now - announce_time < AUTOTUNE_ANNOUNCE_INTERVAL_MS) { if (now - announce_time < AUTOTUNE_ANNOUNCE_INTERVAL_MS) {
@ -312,7 +312,7 @@ void Copter::FlightMode_AutoTune::do_gcs_announcements()
// run - runs the autotune flight mode // run - runs the autotune flight mode
// should be called at 100hz or more // should be called at 100hz or more
void Copter::FlightMode_AutoTune::run() void Copter::ModeAutoTune::run()
{ {
float target_roll, target_pitch; float target_roll, target_pitch;
float target_yaw_rate; float target_yaw_rate;
@ -419,7 +419,7 @@ void Copter::FlightMode_AutoTune::run()
} }
} }
bool Copter::FlightMode_AutoTune::check_level(const LEVEL_ISSUE issue, const float current, const float maximum) bool Copter::ModeAutoTune::check_level(const LEVEL_ISSUE issue, const float current, const float maximum)
{ {
if (current > maximum) { if (current > maximum) {
level_problem.current = current; level_problem.current = current;
@ -430,7 +430,7 @@ bool Copter::FlightMode_AutoTune::check_level(const LEVEL_ISSUE issue, const flo
return true; return true;
} }
bool Copter::FlightMode_AutoTune::currently_level() bool Copter::ModeAutoTune::currently_level()
{ {
if (!check_level(LEVEL_ISSUE_ANGLE_ROLL, if (!check_level(LEVEL_ISSUE_ANGLE_ROLL,
labs(ahrs.roll_sensor - roll_cd), labs(ahrs.roll_sensor - roll_cd),
@ -467,7 +467,7 @@ bool Copter::FlightMode_AutoTune::currently_level()
} }
// attitude_controller - sets attitude control targets during tuning // attitude_controller - sets attitude control targets during tuning
void Copter::FlightMode_AutoTune::autotune_attitude_control() void Copter::ModeAutoTune::autotune_attitude_control()
{ {
rotation_rate = 0.0f; // rotation rate in radians/second rotation_rate = 0.0f; // rotation rate in radians/second
lean_angle = 0.0f; lean_angle = 0.0f;
@ -871,7 +871,7 @@ void Copter::FlightMode_AutoTune::autotune_attitude_control()
// backup_gains_and_initialise - store current gains as originals // backup_gains_and_initialise - store current gains as originals
// called before tuning starts to backup original gains // called before tuning starts to backup original gains
void Copter::FlightMode_AutoTune::backup_gains_and_initialise() void Copter::ModeAutoTune::backup_gains_and_initialise()
{ {
// initialise state because this is our first time // initialise state because this is our first time
if (roll_enabled()) { if (roll_enabled()) {
@ -929,7 +929,7 @@ void Copter::FlightMode_AutoTune::backup_gains_and_initialise()
// load_orig_gains - set gains to their original values // load_orig_gains - set gains to their original values
// called by stop and failed functions // called by stop and failed functions
void Copter::FlightMode_AutoTune::load_orig_gains() void Copter::ModeAutoTune::load_orig_gains()
{ {
attitude_control->bf_feedforward(orig_bf_feedforward); attitude_control->bf_feedforward(orig_bf_feedforward);
if (roll_enabled()) { if (roll_enabled()) {
@ -963,7 +963,7 @@ void Copter::FlightMode_AutoTune::load_orig_gains()
} }
// load_tuned_gains - load tuned gains // load_tuned_gains - load tuned gains
void Copter::FlightMode_AutoTune::load_tuned_gains() void Copter::ModeAutoTune::load_tuned_gains()
{ {
if (!attitude_control->get_bf_feedforward()) { if (!attitude_control->get_bf_feedforward()) {
attitude_control->bf_feedforward(true); attitude_control->bf_feedforward(true);
@ -1002,7 +1002,7 @@ void Copter::FlightMode_AutoTune::load_tuned_gains()
// load_intra_test_gains - gains used between tests // load_intra_test_gains - gains used between tests
// called during testing mode's update-gains step to set gains ahead of return-to-level step // called during testing mode's update-gains step to set gains ahead of return-to-level step
void Copter::FlightMode_AutoTune::load_intra_test_gains() void Copter::ModeAutoTune::load_intra_test_gains()
{ {
// we are restarting tuning so reset gains to tuning-start gains (i.e. low I term) // we are restarting tuning so reset gains to tuning-start gains (i.e. low I term)
// sanity check the gains // sanity check the gains
@ -1030,7 +1030,7 @@ void Copter::FlightMode_AutoTune::load_intra_test_gains()
// load_twitch_gains - load the to-be-tested gains for a single axis // load_twitch_gains - load the to-be-tested gains for a single axis
// called by attitude_control() just before it beings testing a gain (i.e. just before it twitches) // called by attitude_control() just before it beings testing a gain (i.e. just before it twitches)
void Copter::FlightMode_AutoTune::load_twitch_gains() void Copter::ModeAutoTune::load_twitch_gains()
{ {
switch (axis) { switch (axis) {
case ROLL: case ROLL:
@ -1057,7 +1057,7 @@ void Copter::FlightMode_AutoTune::load_twitch_gains()
// save_tuning_gains - save the final tuned gains for each axis // save_tuning_gains - save the final tuned gains for each axis
// save discovered gains to eeprom if autotuner is enabled (i.e. switch is in the high position) // save discovered gains to eeprom if autotuner is enabled (i.e. switch is in the high position)
void Copter::FlightMode_AutoTune::save_tuning_gains() void Copter::ModeAutoTune::save_tuning_gains()
{ {
// if we successfully completed tuning // if we successfully completed tuning
if (mode == SUCCESS) { if (mode == SUCCESS) {
@ -1145,7 +1145,7 @@ void Copter::FlightMode_AutoTune::save_tuning_gains()
} }
// update_gcs - send message to ground station // update_gcs - send message to ground station
void Copter::FlightMode_AutoTune::update_gcs(uint8_t message_id) void Copter::ModeAutoTune::update_gcs(uint8_t message_id)
{ {
switch (message_id) { switch (message_id) {
case AUTOTUNE_MESSAGE_STARTED: case AUTOTUNE_MESSAGE_STARTED:
@ -1167,21 +1167,21 @@ void Copter::FlightMode_AutoTune::update_gcs(uint8_t message_id)
} }
// axis helper functions // axis helper functions
inline bool Copter::FlightMode_AutoTune::roll_enabled() { inline bool Copter::ModeAutoTune::roll_enabled() {
return g.autotune_axis_bitmask & AUTOTUNE_AXIS_BITMASK_ROLL; return g.autotune_axis_bitmask & AUTOTUNE_AXIS_BITMASK_ROLL;
} }
inline bool Copter::FlightMode_AutoTune::pitch_enabled() { inline bool Copter::ModeAutoTune::pitch_enabled() {
return g.autotune_axis_bitmask & AUTOTUNE_AXIS_BITMASK_PITCH; return g.autotune_axis_bitmask & AUTOTUNE_AXIS_BITMASK_PITCH;
} }
inline bool Copter::FlightMode_AutoTune::yaw_enabled() { inline bool Copter::ModeAutoTune::yaw_enabled() {
return g.autotune_axis_bitmask & AUTOTUNE_AXIS_BITMASK_YAW; return g.autotune_axis_bitmask & AUTOTUNE_AXIS_BITMASK_YAW;
} }
// twitching_test - twitching tests // twitching_test - twitching tests
// update min and max and test for end conditions // update min and max and test for end conditions
void Copter::FlightMode_AutoTune::twitching_test(float measurement, float target, float &measurement_min, float &measurement_max) void Copter::ModeAutoTune::twitching_test(float measurement, float target, float &measurement_min, float &measurement_max)
{ {
// capture maximum measurement // capture maximum measurement
if (measurement > measurement_max) { if (measurement > measurement_max) {
@ -1221,7 +1221,7 @@ void Copter::FlightMode_AutoTune::twitching_test(float measurement, float target
// updating_d_up - increase D and adjust P to optimize the D term for a little bounce back // updating_d_up - increase D and adjust P to optimize the D term for a little bounce back
// optimize D term while keeping the maximum just below the target by adjusting P // optimize D term while keeping the maximum just below the target by adjusting P
void Copter::FlightMode_AutoTune::updating_d_up(float &tune_d, float tune_d_min, float tune_d_max, float tune_d_step_ratio, float &tune_p, float tune_p_min, float tune_p_max, float tune_p_step_ratio, float target, float measurement_min, float measurement_max) void Copter::ModeAutoTune::updating_d_up(float &tune_d, float tune_d_min, float tune_d_max, float tune_d_step_ratio, float &tune_p, float tune_p_min, float tune_p_max, float tune_p_step_ratio, float target, float measurement_min, float measurement_max)
{ {
if (measurement_max > target) { if (measurement_max > target) {
// if maximum measurement was higher than target // if maximum measurement was higher than target
@ -1276,7 +1276,7 @@ void Copter::FlightMode_AutoTune::updating_d_up(float &tune_d, float tune_d_min,
// updating_d_down - decrease D and adjust P to optimize the D term for no bounce back // updating_d_down - decrease D and adjust P to optimize the D term for no bounce back
// optimize D term while keeping the maximum just below the target by adjusting P // optimize D term while keeping the maximum just below the target by adjusting P
void Copter::FlightMode_AutoTune::updating_d_down(float &tune_d, float tune_d_min, float tune_d_step_ratio, float &tune_p, float tune_p_min, float tune_p_max, float tune_p_step_ratio, float target, float measurement_min, float measurement_max) void Copter::ModeAutoTune::updating_d_down(float &tune_d, float tune_d_min, float tune_d_step_ratio, float &tune_p, float tune_p_min, float tune_p_max, float tune_p_step_ratio, float target, float measurement_min, float measurement_max)
{ {
if (measurement_max > target) { if (measurement_max > target) {
// if maximum measurement was higher than target // if maximum measurement was higher than target
@ -1331,7 +1331,7 @@ void Copter::FlightMode_AutoTune::updating_d_down(float &tune_d, float tune_d_mi
// updating_p_down - decrease P until we don't reach the target before time out // updating_p_down - decrease P until we don't reach the target before time out
// P is decreased to ensure we are not overshooting the target // P is decreased to ensure we are not overshooting the target
void Copter::FlightMode_AutoTune::updating_p_down(float &tune_p, float tune_p_min, float tune_p_step_ratio, float target, float measurement_max) void Copter::ModeAutoTune::updating_p_down(float &tune_p, float tune_p_min, float tune_p_step_ratio, float target, float measurement_max)
{ {
if (measurement_max < target*(1+0.5f*g.autotune_aggressiveness)) { if (measurement_max < target*(1+0.5f*g.autotune_aggressiveness)) {
if (ignore_next == false) { if (ignore_next == false) {
@ -1360,7 +1360,7 @@ void Copter::FlightMode_AutoTune::updating_p_down(float &tune_p, float tune_p_mi
// updating_p_up - increase P to ensure the target is reached // updating_p_up - increase P to ensure the target is reached
// P is increased until we achieve our target within a reasonable time // P is increased until we achieve our target within a reasonable time
void Copter::FlightMode_AutoTune::updating_p_up(float &tune_p, float tune_p_max, float tune_p_step_ratio, float target, float measurement_max) void Copter::ModeAutoTune::updating_p_up(float &tune_p, float tune_p_max, float tune_p_step_ratio, float target, float measurement_max)
{ {
if (measurement_max > target*(1+0.5f*g.autotune_aggressiveness)) { if (measurement_max > target*(1+0.5f*g.autotune_aggressiveness)) {
// ignore the next result unless it is the same as this one // ignore the next result unless it is the same as this one
@ -1389,7 +1389,7 @@ void Copter::FlightMode_AutoTune::updating_p_up(float &tune_p, float tune_p_max,
// updating_p_up - increase P to ensure the target is reached while checking bounce back isn't increasing // updating_p_up - increase P to ensure the target is reached while checking bounce back isn't increasing
// P is increased until we achieve our target within a reasonable time while reducing D if bounce back increases above the threshold // P is increased until we achieve our target within a reasonable time while reducing D if bounce back increases above the threshold
void Copter::FlightMode_AutoTune::updating_p_up_d_down(float &tune_d, float tune_d_min, float tune_d_step_ratio, float &tune_p, float tune_p_min, float tune_p_max, float tune_p_step_ratio, float target, float measurement_min, float measurement_max) void Copter::ModeAutoTune::updating_p_up_d_down(float &tune_d, float tune_d_min, float tune_d_step_ratio, float &tune_p, float tune_p_min, float tune_p_max, float tune_p_step_ratio, float target, float measurement_min, float measurement_max)
{ {
if (measurement_max > target*(1+0.5f*g.autotune_aggressiveness)) { if (measurement_max > target*(1+0.5f*g.autotune_aggressiveness)) {
// ignore the next result unless it is the same as this one // ignore the next result unless it is the same as this one
@ -1438,7 +1438,7 @@ void Copter::FlightMode_AutoTune::updating_p_up_d_down(float &tune_d, float tune
} }
// twitching_measure_acceleration - measure rate of change of measurement // twitching_measure_acceleration - measure rate of change of measurement
void Copter::FlightMode_AutoTune::twitching_measure_acceleration(float &rate_of_change, float rate_measurement, float &rate_measurement_max) void Copter::ModeAutoTune::twitching_measure_acceleration(float &rate_of_change, float rate_measurement, float &rate_measurement_max)
{ {
if (rate_measurement_max < rate_measurement) { if (rate_measurement_max < rate_measurement) {
rate_measurement_max = rate_measurement; rate_measurement_max = rate_measurement;
@ -1447,7 +1447,7 @@ void Copter::FlightMode_AutoTune::twitching_measure_acceleration(float &rate_of_
} }
// get attitude for slow position hold in autotune mode // get attitude for slow position hold in autotune mode
void Copter::FlightMode_AutoTune::get_poshold_attitude(float &roll_cd_out, float &pitch_cd_out, float &yaw_cd_out) void Copter::ModeAutoTune::get_poshold_attitude(float &roll_cd_out, float &pitch_cd_out, float &yaw_cd_out)
{ {
roll_cd_out = pitch_cd_out = 0; roll_cd_out = pitch_cd_out = 0;

View File

@ -10,13 +10,13 @@
*/ */
// initialise avoid_adsb controller // initialise avoid_adsb controller
bool Copter::FlightMode_Avoid_ADSB::init(const bool ignore_checks) bool Copter::ModeAvoidADSB::init(const bool ignore_checks)
{ {
// re-use guided mode // re-use guided mode
return Copter::FlightMode_Guided::init(ignore_checks); return Copter::ModeGuided::init(ignore_checks);
} }
bool Copter::FlightMode_Avoid_ADSB::set_velocity(const Vector3f& velocity_neu) bool Copter::ModeAvoidADSB::set_velocity(const Vector3f& velocity_neu)
{ {
// check flight mode // check flight mode
if (_copter.control_mode != AVOID_ADSB) { if (_copter.control_mode != AVOID_ADSB) {
@ -24,15 +24,15 @@ bool Copter::FlightMode_Avoid_ADSB::set_velocity(const Vector3f& velocity_neu)
} }
// re-use guided mode's velocity controller // re-use guided mode's velocity controller
Copter::FlightMode_Guided::set_velocity(velocity_neu); Copter::ModeGuided::set_velocity(velocity_neu);
return true; return true;
} }
// runs the AVOID_ADSB controller // runs the AVOID_ADSB controller
void Copter::FlightMode_Avoid_ADSB::run() void Copter::ModeAvoidADSB::run()
{ {
// re-use guided mode's velocity controller // re-use guided mode's velocity controller
// Note: this is safe from interference from GCSs and companion computer's whose guided mode // Note: this is safe from interference from GCSs and companion computer's whose guided mode
// position and velocity requests will be ignored while the vehicle is not in guided mode // position and velocity requests will be ignored while the vehicle is not in guided mode
Copter::FlightMode_Guided::run(); Copter::ModeGuided::run();
} }

View File

@ -5,7 +5,7 @@
*/ */
// brake_init - initialise brake controller // brake_init - initialise brake controller
bool Copter::FlightMode_Brake::init(bool ignore_checks) bool Copter::ModeBrake::init(bool ignore_checks)
{ {
if (_copter.position_ok() || ignore_checks) { if (_copter.position_ok() || ignore_checks) {
@ -35,7 +35,7 @@ bool Copter::FlightMode_Brake::init(bool ignore_checks)
// brake_run - runs the brake controller // brake_run - runs the brake controller
// should be called at 100hz or more // should be called at 100hz or more
void Copter::FlightMode_Brake::run() void Copter::ModeBrake::run()
{ {
// if not auto armed set throttle to zero and exit immediately // if not auto armed set throttle to zero and exit immediately
if (!motors->armed() || !ap.auto_armed || !motors->get_interlock()) { if (!motors->armed() || !ap.auto_armed || !motors->get_interlock()) {
@ -85,7 +85,7 @@ void Copter::FlightMode_Brake::run()
} }
} }
void Copter::FlightMode_Brake::timeout_to_loiter_ms(uint32_t timeout_ms) void Copter::ModeBrake::timeout_to_loiter_ms(uint32_t timeout_ms)
{ {
_timeout_start = millis(); _timeout_start = millis();
_timeout_ms = timeout_ms; _timeout_ms = timeout_ms;

View File

@ -5,7 +5,7 @@
*/ */
// circle_init - initialise circle controller flight mode // circle_init - initialise circle controller flight mode
bool Copter::FlightMode_Circle::init(bool ignore_checks) bool Copter::ModeCircle::init(bool ignore_checks)
{ {
if (_copter.position_ok() || ignore_checks) { if (_copter.position_ok() || ignore_checks) {
pilot_yaw_override = false; pilot_yaw_override = false;
@ -28,7 +28,7 @@ bool Copter::FlightMode_Circle::init(bool ignore_checks)
// circle_run - runs the circle flight mode // circle_run - runs the circle flight mode
// should be called at 100hz or more // should be called at 100hz or more
void Copter::FlightMode_Circle::run() void Copter::ModeCircle::run()
{ {
float target_yaw_rate = 0; float target_yaw_rate = 0;
float target_climb_rate = 0; float target_climb_rate = 0;

View File

@ -27,7 +27,7 @@
#endif #endif
// drift_init - initialise drift controller // drift_init - initialise drift controller
bool Copter::FlightMode_Drift::init(bool ignore_checks) bool Copter::ModeDrift::init(bool ignore_checks)
{ {
if (_copter.position_ok() || ignore_checks) { if (_copter.position_ok() || ignore_checks) {
return true; return true;
@ -38,7 +38,7 @@ bool Copter::FlightMode_Drift::init(bool ignore_checks)
// drift_run - runs the drift controller // drift_run - runs the drift controller
// should be called at 100hz or more // should be called at 100hz or more
void Copter::FlightMode_Drift::run() void Copter::ModeDrift::run()
{ {
static float breaker = 0.0f; static float breaker = 0.0f;
static float roll_input = 0.0f; static float roll_input = 0.0f;
@ -108,7 +108,7 @@ void Copter::FlightMode_Drift::run()
} }
// get_throttle_assist - return throttle output (range 0 ~ 1) based on pilot input and z-axis velocity // get_throttle_assist - return throttle output (range 0 ~ 1) based on pilot input and z-axis velocity
float Copter::FlightMode_Drift::get_throttle_assist(float velz, float pilot_throttle_scaled) float Copter::ModeDrift::get_throttle_assist(float velz, float pilot_throttle_scaled)
{ {
// throttle assist - adjusts throttle to slow the vehicle's vertical velocity // throttle assist - adjusts throttle to slow the vehicle's vertical velocity
// Only active when pilot's throttle is between 213 ~ 787 // Only active when pilot's throttle is between 213 ~ 787

View File

@ -38,7 +38,7 @@ int8_t flip_roll_dir; // roll direction (-1 = roll left, 1 = roll
int8_t flip_pitch_dir; // pitch direction (-1 = pitch forward, 1 = pitch back) int8_t flip_pitch_dir; // pitch direction (-1 = pitch forward, 1 = pitch back)
// flip_init - initialise flip controller // flip_init - initialise flip controller
bool Copter::FlightMode_Flip::init(bool ignore_checks) bool Copter::ModeFlip::init(bool ignore_checks)
{ {
// only allow flip from ACRO, Stabilize, AltHold or Drift flight modes // only allow flip from ACRO, Stabilize, AltHold or Drift flight modes
if (_copter.control_mode != ACRO && _copter.control_mode != STABILIZE && _copter.control_mode != ALT_HOLD) { if (_copter.control_mode != ACRO && _copter.control_mode != STABILIZE && _copter.control_mode != ALT_HOLD) {
@ -94,7 +94,7 @@ bool Copter::FlightMode_Flip::init(bool ignore_checks)
// flip_run - runs the flip controller // flip_run - runs the flip controller
// should be called at 100hz or more // should be called at 100hz or more
void Copter::FlightMode_Flip::run() void Copter::ModeFlip::run()
{ {
float throttle_out; float throttle_out;
float recovery_angle; float recovery_angle;

View File

@ -36,7 +36,7 @@ struct Guided_Limit {
} guided_limit; } guided_limit;
// guided_init - initialise guided controller // guided_init - initialise guided controller
bool Copter::FlightMode_Guided::init(bool ignore_checks) bool Copter::ModeGuided::init(bool ignore_checks)
{ {
if (_copter.position_ok() || ignore_checks) { if (_copter.position_ok() || ignore_checks) {
// initialise yaw // initialise yaw
@ -51,7 +51,7 @@ bool Copter::FlightMode_Guided::init(bool ignore_checks)
// guided_takeoff_start - initialises waypoint controller to implement take-off // guided_takeoff_start - initialises waypoint controller to implement take-off
bool Copter::FlightMode_Guided::takeoff_start(float final_alt_above_home) bool Copter::ModeGuided::takeoff_start(float final_alt_above_home)
{ {
guided_mode = Guided_TakeOff; guided_mode = Guided_TakeOff;
@ -79,7 +79,7 @@ bool Copter::FlightMode_Guided::takeoff_start(float final_alt_above_home)
} }
// initialise guided mode's position controller // initialise guided mode's position controller
void Copter::FlightMode_Guided::pos_control_start() void Copter::ModeGuided::pos_control_start()
{ {
// set to position control mode // set to position control mode
guided_mode = Guided_WP; guided_mode = Guided_WP;
@ -99,7 +99,7 @@ void Copter::FlightMode_Guided::pos_control_start()
} }
// initialise guided mode's velocity controller // initialise guided mode's velocity controller
void Copter::FlightMode_Guided::vel_control_start() void Copter::ModeGuided::vel_control_start()
{ {
// set guided_mode to velocity controller // set guided_mode to velocity controller
guided_mode = Guided_Velocity; guided_mode = Guided_Velocity;
@ -118,7 +118,7 @@ void Copter::FlightMode_Guided::vel_control_start()
} }
// initialise guided mode's posvel controller // initialise guided mode's posvel controller
void Copter::FlightMode_Guided::posvel_control_start() void Copter::ModeGuided::posvel_control_start()
{ {
// set guided_mode to velocity controller // set guided_mode to velocity controller
guided_mode = Guided_PosVel; guided_mode = Guided_PosVel;
@ -146,7 +146,7 @@ void Copter::FlightMode_Guided::posvel_control_start()
} }
// initialise guided mode's angle controller // initialise guided mode's angle controller
void Copter::FlightMode_Guided::angle_control_start() void Copter::ModeGuided::angle_control_start()
{ {
// set guided_mode to velocity controller // set guided_mode to velocity controller
guided_mode = Guided_Angle; guided_mode = Guided_Angle;
@ -177,7 +177,7 @@ void Copter::FlightMode_Guided::angle_control_start()
// guided_set_destination - sets guided mode's target destination // guided_set_destination - sets guided mode's target destination
// Returns true if the fence is enabled and guided waypoint is within the fence // Returns true if the fence is enabled and guided waypoint is within the fence
// else return false if the waypoint is outside the fence // else return false if the waypoint is outside the fence
bool Copter::FlightMode_Guided::set_destination(const Vector3f& destination, bool use_yaw, float yaw_cd, bool use_yaw_rate, float yaw_rate_cds, bool relative_yaw) bool Copter::ModeGuided::set_destination(const Vector3f& destination, bool use_yaw, float yaw_cd, bool use_yaw_rate, float yaw_rate_cds, bool relative_yaw)
{ {
// ensure we are in position control mode // ensure we are in position control mode
if (guided_mode != Guided_WP) { if (guided_mode != Guided_WP) {
@ -208,7 +208,7 @@ bool Copter::FlightMode_Guided::set_destination(const Vector3f& destination, boo
// sets guided mode's target from a Location object // sets guided mode's target from a Location object
// returns false if destination could not be set (probably caused by missing terrain data) // returns false if destination could not be set (probably caused by missing terrain data)
// or if the fence is enabled and guided waypoint is outside the fence // or if the fence is enabled and guided waypoint is outside the fence
bool Copter::FlightMode_Guided::set_destination(const Location_Class& dest_loc, bool use_yaw, float yaw_cd, bool use_yaw_rate, float yaw_rate_cds, bool relative_yaw) bool Copter::ModeGuided::set_destination(const Location_Class& dest_loc, bool use_yaw, float yaw_cd, bool use_yaw_rate, float yaw_rate_cds, bool relative_yaw)
{ {
// ensure we are in position control mode // ensure we are in position control mode
if (guided_mode != Guided_WP) { if (guided_mode != Guided_WP) {
@ -241,7 +241,7 @@ bool Copter::FlightMode_Guided::set_destination(const Location_Class& dest_loc,
} }
// guided_set_velocity - sets guided mode's target velocity // guided_set_velocity - sets guided mode's target velocity
void Copter::FlightMode_Guided::set_velocity(const Vector3f& velocity, bool use_yaw, float yaw_cd, bool use_yaw_rate, float yaw_rate_cds, bool relative_yaw) void Copter::ModeGuided::set_velocity(const Vector3f& velocity, bool use_yaw, float yaw_cd, bool use_yaw_rate, float yaw_rate_cds, bool relative_yaw)
{ {
// check we are in velocity control mode // check we are in velocity control mode
if (guided_mode != Guided_Velocity) { if (guided_mode != Guided_Velocity) {
@ -260,7 +260,7 @@ void Copter::FlightMode_Guided::set_velocity(const Vector3f& velocity, bool use_
} }
// set guided mode posvel target // set guided mode posvel target
bool Copter::FlightMode_Guided::set_destination_posvel(const Vector3f& destination, const Vector3f& velocity, bool use_yaw, float yaw_cd, bool use_yaw_rate, float yaw_rate_cds, bool relative_yaw) bool Copter::ModeGuided::set_destination_posvel(const Vector3f& destination, const Vector3f& velocity, bool use_yaw, float yaw_cd, bool use_yaw_rate, float yaw_rate_cds, bool relative_yaw)
{ {
// check we are in velocity control mode // check we are in velocity control mode
if (guided_mode != Guided_PosVel) { if (guided_mode != Guided_PosVel) {
@ -292,7 +292,7 @@ bool Copter::FlightMode_Guided::set_destination_posvel(const Vector3f& destinati
} }
// set guided mode angle target // set guided mode angle target
void Copter::FlightMode_Guided::set_angle(const Quaternion &q, float climb_rate_cms, bool use_yaw_rate, float yaw_rate_rads) void Copter::ModeGuided::set_angle(const Quaternion &q, float climb_rate_cms, bool use_yaw_rate, float yaw_rate_rads)
{ {
// check we are in velocity control mode // check we are in velocity control mode
if (guided_mode != Guided_Angle) { if (guided_mode != Guided_Angle) {
@ -323,7 +323,7 @@ void Copter::FlightMode_Guided::set_angle(const Quaternion &q, float climb_rate_
// guided_run - runs the guided controller // guided_run - runs the guided controller
// should be called at 100hz or more // should be called at 100hz or more
void Copter::FlightMode_Guided::run() void Copter::ModeGuided::run()
{ {
// call the correct auto controller // call the correct auto controller
switch (guided_mode) { switch (guided_mode) {
@ -357,7 +357,7 @@ void Copter::FlightMode_Guided::run()
// guided_takeoff_run - takeoff in guided mode // guided_takeoff_run - takeoff in guided mode
// called by guided_run at 100hz or more // called by guided_run at 100hz or more
void Copter::FlightMode_Guided::takeoff_run() void Copter::ModeGuided::takeoff_run()
{ {
// if not auto armed or motor interlock not enabled set throttle to zero and exit immediately // if not auto armed or motor interlock not enabled set throttle to zero and exit immediately
if (!motors->armed() || !ap.auto_armed || !motors->get_interlock()) { if (!motors->armed() || !ap.auto_armed || !motors->get_interlock()) {
@ -411,7 +411,7 @@ void Copter::FlightMode_Guided::takeoff_run()
// guided_pos_control_run - runs the guided position controller // guided_pos_control_run - runs the guided position controller
// called from guided_run // called from guided_run
void Copter::FlightMode_Guided::pos_control_run() void Copter::ModeGuided::pos_control_run()
{ {
// if not auto armed or motors not enabled set throttle to zero and exit immediately // if not auto armed or motors not enabled set throttle to zero and exit immediately
if (!motors->armed() || !ap.auto_armed || !motors->get_interlock() || ap.land_complete) { if (!motors->armed() || !ap.auto_armed || !motors->get_interlock() || ap.land_complete) {
@ -461,7 +461,7 @@ void Copter::FlightMode_Guided::pos_control_run()
// guided_vel_control_run - runs the guided velocity controller // guided_vel_control_run - runs the guided velocity controller
// called from guided_run // called from guided_run
void Copter::FlightMode_Guided::vel_control_run() void Copter::ModeGuided::vel_control_run()
{ {
// if not auto armed or motors not enabled set throttle to zero and exit immediately // if not auto armed or motors not enabled set throttle to zero and exit immediately
if (!motors->armed() || !ap.auto_armed || !motors->get_interlock() || ap.land_complete) { if (!motors->armed() || !ap.auto_armed || !motors->get_interlock() || ap.land_complete) {
@ -523,7 +523,7 @@ void Copter::FlightMode_Guided::vel_control_run()
// guided_posvel_control_run - runs the guided spline controller // guided_posvel_control_run - runs the guided spline controller
// called from guided_run // called from guided_run
void Copter::FlightMode_Guided::posvel_control_run() void Copter::ModeGuided::posvel_control_run()
{ {
// if not auto armed or motors not enabled set throttle to zero and exit immediately // if not auto armed or motors not enabled set throttle to zero and exit immediately
if (!motors->armed() || !ap.auto_armed || !motors->get_interlock() || ap.land_complete) { if (!motors->armed() || !ap.auto_armed || !motors->get_interlock() || ap.land_complete) {
@ -603,7 +603,7 @@ void Copter::FlightMode_Guided::posvel_control_run()
// guided_angle_control_run - runs the guided angle controller // guided_angle_control_run - runs the guided angle controller
// called from guided_run // called from guided_run
void Copter::FlightMode_Guided::angle_control_run() void Copter::ModeGuided::angle_control_run()
{ {
// if not auto armed or motors not enabled set throttle to zero and exit immediately // if not auto armed or motors not enabled set throttle to zero and exit immediately
if (!motors->armed() || !ap.auto_armed || !motors->get_interlock() || (ap.land_complete && guided_angle_state.climb_rate_cms <= 0.0f)) { if (!motors->armed() || !ap.auto_armed || !motors->get_interlock() || (ap.land_complete && guided_angle_state.climb_rate_cms <= 0.0f)) {
@ -667,7 +667,7 @@ void Copter::FlightMode_Guided::angle_control_run()
} }
// helper function to update position controller's desired velocity while respecting acceleration limits // helper function to update position controller's desired velocity while respecting acceleration limits
void Copter::FlightMode_Guided::set_desired_velocity_with_accel_and_fence_limits(const Vector3f& vel_des) void Copter::ModeGuided::set_desired_velocity_with_accel_and_fence_limits(const Vector3f& vel_des)
{ {
// get current desired velocity // get current desired velocity
Vector3f curr_vel_des = pos_control->get_desired_velocity(); Vector3f curr_vel_des = pos_control->get_desired_velocity();
@ -701,7 +701,7 @@ void Copter::FlightMode_Guided::set_desired_velocity_with_accel_and_fence_limits
} }
// helper function to set yaw state and targets // helper function to set yaw state and targets
void Copter::FlightMode_Guided::set_yaw_state(bool use_yaw, float yaw_cd, bool use_yaw_rate, float yaw_rate_cds, bool relative_angle) void Copter::ModeGuided::set_yaw_state(bool use_yaw, float yaw_cd, bool use_yaw_rate, float yaw_rate_cds, bool relative_angle)
{ {
if (use_yaw) { if (use_yaw) {
set_auto_yaw_look_at_heading(yaw_cd / 100.0f, 0.0f, 0, relative_angle); set_auto_yaw_look_at_heading(yaw_cd / 100.0f, 0.0f, 0, relative_angle);
@ -713,7 +713,7 @@ void Copter::FlightMode_Guided::set_yaw_state(bool use_yaw, float yaw_cd, bool u
// Guided Limit code // Guided Limit code
// guided_limit_clear - clear/turn off guided limits // guided_limit_clear - clear/turn off guided limits
void Copter::FlightMode_Guided::limit_clear() void Copter::ModeGuided::limit_clear()
{ {
guided_limit.timeout_ms = 0; guided_limit.timeout_ms = 0;
guided_limit.alt_min_cm = 0.0f; guided_limit.alt_min_cm = 0.0f;
@ -722,7 +722,7 @@ void Copter::FlightMode_Guided::limit_clear()
} }
// guided_limit_set - set guided timeout and movement limits // guided_limit_set - set guided timeout and movement limits
void Copter::FlightMode_Guided::limit_set(uint32_t timeout_ms, float alt_min_cm, float alt_max_cm, float horiz_max_cm) void Copter::ModeGuided::limit_set(uint32_t timeout_ms, float alt_min_cm, float alt_max_cm, float horiz_max_cm)
{ {
guided_limit.timeout_ms = timeout_ms; guided_limit.timeout_ms = timeout_ms;
guided_limit.alt_min_cm = alt_min_cm; guided_limit.alt_min_cm = alt_min_cm;
@ -732,7 +732,7 @@ void Copter::FlightMode_Guided::limit_set(uint32_t timeout_ms, float alt_min_cm,
// guided_limit_init_time_and_pos - initialise guided start time and position as reference for limit checking // guided_limit_init_time_and_pos - initialise guided start time and position as reference for limit checking
// only called from AUTO mode's auto_nav_guided_start function // only called from AUTO mode's auto_nav_guided_start function
void Copter::FlightMode_Guided::limit_init_time_and_pos() void Copter::ModeGuided::limit_init_time_and_pos()
{ {
// initialise start time // initialise start time
guided_limit.start_time = AP_HAL::millis(); guided_limit.start_time = AP_HAL::millis();
@ -743,7 +743,7 @@ void Copter::FlightMode_Guided::limit_init_time_and_pos()
// guided_limit_check - returns true if guided mode has breached a limit // guided_limit_check - returns true if guided mode has breached a limit
// used when guided is invoked from the NAV_GUIDED_ENABLE mission command // used when guided is invoked from the NAV_GUIDED_ENABLE mission command
bool Copter::FlightMode_Guided::limit_check() bool Copter::ModeGuided::limit_check()
{ {
// check if we have passed the timeout // check if we have passed the timeout
if ((guided_limit.timeout_ms > 0) && (millis() - guided_limit.start_time >= guided_limit.timeout_ms)) { if ((guided_limit.timeout_ms > 0) && (millis() - guided_limit.start_time >= guided_limit.timeout_ms)) {
@ -776,7 +776,7 @@ bool Copter::FlightMode_Guided::limit_check()
} }
uint32_t Copter::FlightMode_Guided::wp_distance() const uint32_t Copter::ModeGuided::wp_distance() const
{ {
switch(mode()) { switch(mode()) {
case Guided_WP: case Guided_WP:
@ -790,7 +790,7 @@ uint32_t Copter::FlightMode_Guided::wp_distance() const
} }
} }
int32_t Copter::FlightMode_Guided::wp_bearing() const int32_t Copter::ModeGuided::wp_bearing() const
{ {
switch(mode()) { switch(mode()) {
case Guided_WP: case Guided_WP:

View File

@ -5,17 +5,17 @@
*/ */
// initialise guided_nogps controller // initialise guided_nogps controller
bool Copter::FlightMode_Guided_NoGPS::init(bool ignore_checks) bool Copter::ModeGuidedNoGPS::init(bool ignore_checks)
{ {
// start in angle control mode // start in angle control mode
Copter::FlightMode_Guided::angle_control_start(); Copter::ModeGuided::angle_control_start();
return true; return true;
} }
// guided_run - runs the guided controller // guided_run - runs the guided controller
// should be called at 100hz or more // should be called at 100hz or more
void Copter::FlightMode_Guided_NoGPS::run() void Copter::ModeGuidedNoGPS::run()
{ {
// run angle controller // run angle controller
Copter::FlightMode_Guided::angle_control_run(); Copter::ModeGuided::angle_control_run();
} }

View File

@ -7,7 +7,7 @@ static uint32_t land_start_time;
static bool land_pause; static bool land_pause;
// land_init - initialise land controller // land_init - initialise land controller
bool Copter::FlightMode_Land::init(bool ignore_checks) bool Copter::ModeLand::init(bool ignore_checks)
{ {
// check if we have GPS and decide which LAND we're going to do // check if we have GPS and decide which LAND we're going to do
land_with_gps = _copter.position_ok(); land_with_gps = _copter.position_ok();
@ -40,7 +40,7 @@ bool Copter::FlightMode_Land::init(bool ignore_checks)
// land_run - runs the land controller // land_run - runs the land controller
// should be called at 100hz or more // should be called at 100hz or more
void Copter::FlightMode_Land::run() void Copter::ModeLand::run()
{ {
if (land_with_gps) { if (land_with_gps) {
gps_run(); gps_run();
@ -52,7 +52,7 @@ void Copter::FlightMode_Land::run()
// land_gps_run - runs the land controller // land_gps_run - runs the land controller
// horizontal position controlled with loiter controller // horizontal position controlled with loiter controller
// should be called at 100hz or more // should be called at 100hz or more
void Copter::FlightMode_Land::gps_run() void Copter::ModeLand::gps_run()
{ {
// if not auto armed or landed or motor interlock not enabled set throttle to zero and exit immediately // if not auto armed or landed or motor interlock not enabled set throttle to zero and exit immediately
if (!motors->armed() || !ap.auto_armed || ap.land_complete || !motors->get_interlock()) { if (!motors->armed() || !ap.auto_armed || ap.land_complete || !motors->get_interlock()) {
@ -89,7 +89,7 @@ void Copter::FlightMode_Land::gps_run()
// land_nogps_run - runs the land controller // land_nogps_run - runs the land controller
// pilot controls roll and pitch angles // pilot controls roll and pitch angles
// should be called at 100hz or more // should be called at 100hz or more
void Copter::FlightMode_Land::nogps_run() void Copter::ModeLand::nogps_run()
{ {
float target_roll = 0.0f, target_pitch = 0.0f; float target_roll = 0.0f, target_pitch = 0.0f;
float target_yaw_rate = 0; float target_yaw_rate = 0;
@ -150,7 +150,7 @@ void Copter::FlightMode_Land::nogps_run()
/* /*
get a height above ground estimate for landing get a height above ground estimate for landing
*/ */
int32_t Copter::FlightMode_Land::get_alt_above_ground(void) int32_t Copter::ModeLand::get_alt_above_ground(void)
{ {
int32_t alt_above_ground; int32_t alt_above_ground;
if (_copter.rangefinder_alt_ok()) { if (_copter.rangefinder_alt_ok()) {
@ -303,7 +303,7 @@ void Copter::land_run_horizontal_control()
// do_not_use_GPS - forces land-mode to not use the GPS but instead rely on pilot input for roll and pitch // do_not_use_GPS - forces land-mode to not use the GPS but instead rely on pilot input for roll and pitch
// called during GPS failsafe to ensure that if we were already in LAND mode that we do not use the GPS // called during GPS failsafe to ensure that if we were already in LAND mode that we do not use the GPS
// has no effect if we are not already in LAND mode // has no effect if we are not already in LAND mode
void Copter::FlightMode_Land::do_not_use_GPS() void Copter::ModeLand::do_not_use_GPS()
{ {
land_with_gps = false; land_with_gps = false;
} }

View File

@ -5,7 +5,7 @@
*/ */
// loiter_init - initialise loiter controller // loiter_init - initialise loiter controller
bool Copter::FlightMode_Loiter::init(bool ignore_checks) bool Copter::ModeLoiter::init(bool ignore_checks)
{ {
if (_copter.position_ok() || ignore_checks) { if (_copter.position_ok() || ignore_checks) {
@ -29,7 +29,7 @@ bool Copter::FlightMode_Loiter::init(bool ignore_checks)
} }
#if PRECISION_LANDING == ENABLED #if PRECISION_LANDING == ENABLED
bool Copter::FlightMode_Loiter::do_precision_loiter() bool Copter::ModeLoiter::do_precision_loiter()
{ {
if (!_precision_loiter_enabled) { if (!_precision_loiter_enabled) {
return false; return false;
@ -47,7 +47,7 @@ bool Copter::FlightMode_Loiter::do_precision_loiter()
return true; return true;
} }
void Copter::FlightMode_Loiter::precision_loiter_xy() void Copter::ModeLoiter::precision_loiter_xy()
{ {
wp_nav->clear_pilot_desired_acceleration(); wp_nav->clear_pilot_desired_acceleration();
Vector2f target_pos, target_vel_rel; Vector2f target_pos, target_vel_rel;
@ -66,7 +66,7 @@ void Copter::FlightMode_Loiter::precision_loiter_xy()
// loiter_run - runs the loiter controller // loiter_run - runs the loiter controller
// should be called at 100hz or more // should be called at 100hz or more
void Copter::FlightMode_Loiter::run() void Copter::ModeLoiter::run()
{ {
LoiterModeState loiter_state; LoiterModeState loiter_state;
float target_yaw_rate = 0.0f; float target_yaw_rate = 0.0f;

View File

@ -71,7 +71,7 @@ static struct {
} poshold; } poshold;
// poshold_init - initialise PosHold controller // poshold_init - initialise PosHold controller
bool Copter::FlightMode_PosHold::init(bool ignore_checks) bool Copter::ModePosHold::init(bool ignore_checks)
{ {
// fail to initialise PosHold mode if no GPS lock // fail to initialise PosHold mode if no GPS lock
if (!_copter.position_ok() && !ignore_checks) { if (!_copter.position_ok() && !ignore_checks) {
@ -122,7 +122,7 @@ bool Copter::FlightMode_PosHold::init(bool ignore_checks)
// poshold_run - runs the PosHold controller // poshold_run - runs the PosHold controller
// should be called at 100hz or more // should be called at 100hz or more
void Copter::FlightMode_PosHold::run() void Copter::ModePosHold::run()
{ {
float target_roll, target_pitch; // pilot's roll and pitch angle inputs float target_roll, target_pitch; // pilot's roll and pitch angle inputs
float target_yaw_rate = 0; // pilot desired yaw rate in centi-degrees/sec float target_yaw_rate = 0; // pilot desired yaw rate in centi-degrees/sec
@ -542,7 +542,7 @@ void Copter::FlightMode_PosHold::run()
} }
// poshold_update_pilot_lean_angle - update the pilot's filtered lean angle with the latest raw input received // poshold_update_pilot_lean_angle - update the pilot's filtered lean angle with the latest raw input received
void Copter::FlightMode_PosHold::poshold_update_pilot_lean_angle(float &lean_angle_filtered, float &lean_angle_raw) void Copter::ModePosHold::poshold_update_pilot_lean_angle(float &lean_angle_filtered, float &lean_angle_raw)
{ {
// if raw input is large or reversing the vehicle's lean angle immediately set the fitlered angle to the new raw angle // if raw input is large or reversing the vehicle's lean angle immediately set the fitlered angle to the new raw angle
if ((lean_angle_filtered > 0 && lean_angle_raw < 0) || (lean_angle_filtered < 0 && lean_angle_raw > 0) || (fabsf(lean_angle_raw) > POSHOLD_STICK_RELEASE_SMOOTH_ANGLE)) { if ((lean_angle_filtered > 0 && lean_angle_raw < 0) || (lean_angle_filtered < 0 && lean_angle_raw > 0) || (fabsf(lean_angle_raw) > POSHOLD_STICK_RELEASE_SMOOTH_ANGLE)) {
@ -564,7 +564,7 @@ void Copter::FlightMode_PosHold::poshold_update_pilot_lean_angle(float &lean_ang
// poshold_mix_controls - mixes two controls based on the mix_ratio // poshold_mix_controls - mixes two controls based on the mix_ratio
// mix_ratio of 1 = use first_control completely, 0 = use second_control completely, 0.5 = mix evenly // mix_ratio of 1 = use first_control completely, 0 = use second_control completely, 0.5 = mix evenly
int16_t Copter::FlightMode_PosHold::poshold_mix_controls(float mix_ratio, int16_t first_control, int16_t second_control) int16_t Copter::ModePosHold::poshold_mix_controls(float mix_ratio, int16_t first_control, int16_t second_control)
{ {
mix_ratio = constrain_float(mix_ratio, 0.0f, 1.0f); mix_ratio = constrain_float(mix_ratio, 0.0f, 1.0f);
return (int16_t)((mix_ratio * first_control) + ((1.0f-mix_ratio)*second_control)); return (int16_t)((mix_ratio * first_control) + ((1.0f-mix_ratio)*second_control));
@ -573,7 +573,7 @@ int16_t Copter::FlightMode_PosHold::poshold_mix_controls(float mix_ratio, int16_
// poshold_update_brake_angle_from_velocity - updates the brake_angle based on the vehicle's velocity and brake_gain // poshold_update_brake_angle_from_velocity - updates the brake_angle based on the vehicle's velocity and brake_gain
// brake_angle is slewed with the wpnav.poshold_brake_rate and constrained by the wpnav.poshold_braking_angle_max // brake_angle is slewed with the wpnav.poshold_brake_rate and constrained by the wpnav.poshold_braking_angle_max
// velocity is assumed to be in the same direction as lean angle so for pitch you should provide the velocity backwards (i.e. -ve forward velocity) // velocity is assumed to be in the same direction as lean angle so for pitch you should provide the velocity backwards (i.e. -ve forward velocity)
void Copter::FlightMode_PosHold::poshold_update_brake_angle_from_velocity(int16_t &brake_angle, float velocity) void Copter::ModePosHold::poshold_update_brake_angle_from_velocity(int16_t &brake_angle, float velocity)
{ {
float lean_angle; float lean_angle;
int16_t brake_rate = g.poshold_brake_rate; int16_t brake_rate = g.poshold_brake_rate;
@ -599,7 +599,7 @@ void Copter::FlightMode_PosHold::poshold_update_brake_angle_from_velocity(int16_
// poshold_update_wind_comp_estimate - updates wind compensation estimate // poshold_update_wind_comp_estimate - updates wind compensation estimate
// should be called at the maximum loop rate when loiter is engaged // should be called at the maximum loop rate when loiter is engaged
void Copter::FlightMode_PosHold::poshold_update_wind_comp_estimate() void Copter::ModePosHold::poshold_update_wind_comp_estimate()
{ {
// check wind estimate start has not been delayed // check wind estimate start has not been delayed
if (poshold.wind_comp_start_timer > 0) { if (poshold.wind_comp_start_timer > 0) {
@ -635,7 +635,7 @@ void Copter::FlightMode_PosHold::poshold_update_wind_comp_estimate()
// poshold_get_wind_comp_lean_angles - retrieve wind compensation angles in body frame roll and pitch angles // poshold_get_wind_comp_lean_angles - retrieve wind compensation angles in body frame roll and pitch angles
// should be called at the maximum loop rate // should be called at the maximum loop rate
void Copter::FlightMode_PosHold::poshold_get_wind_comp_lean_angles(int16_t &roll_angle, int16_t &pitch_angle) void Copter::ModePosHold::poshold_get_wind_comp_lean_angles(int16_t &roll_angle, int16_t &pitch_angle)
{ {
// reduce rate to 10hz // reduce rate to 10hz
poshold.wind_comp_timer++; poshold.wind_comp_timer++;
@ -650,7 +650,7 @@ void Copter::FlightMode_PosHold::poshold_get_wind_comp_lean_angles(int16_t &roll
} }
// poshold_roll_controller_to_pilot_override - initialises transition from a controller submode (brake or loiter) to a pilot override on roll axis // poshold_roll_controller_to_pilot_override - initialises transition from a controller submode (brake or loiter) to a pilot override on roll axis
void Copter::FlightMode_PosHold::poshold_roll_controller_to_pilot_override() void Copter::ModePosHold::poshold_roll_controller_to_pilot_override()
{ {
poshold.roll_mode = POSHOLD_CONTROLLER_TO_PILOT_OVERRIDE; poshold.roll_mode = POSHOLD_CONTROLLER_TO_PILOT_OVERRIDE;
poshold.controller_to_pilot_timer_roll = POSHOLD_CONTROLLER_TO_PILOT_MIX_TIMER; poshold.controller_to_pilot_timer_roll = POSHOLD_CONTROLLER_TO_PILOT_MIX_TIMER;
@ -661,7 +661,7 @@ void Copter::FlightMode_PosHold::poshold_roll_controller_to_pilot_override()
} }
// poshold_pitch_controller_to_pilot_override - initialises transition from a controller submode (brake or loiter) to a pilot override on roll axis // poshold_pitch_controller_to_pilot_override - initialises transition from a controller submode (brake or loiter) to a pilot override on roll axis
void Copter::FlightMode_PosHold::poshold_pitch_controller_to_pilot_override() void Copter::ModePosHold::poshold_pitch_controller_to_pilot_override()
{ {
poshold.pitch_mode = POSHOLD_CONTROLLER_TO_PILOT_OVERRIDE; poshold.pitch_mode = POSHOLD_CONTROLLER_TO_PILOT_OVERRIDE;
poshold.controller_to_pilot_timer_pitch = POSHOLD_CONTROLLER_TO_PILOT_MIX_TIMER; poshold.controller_to_pilot_timer_pitch = POSHOLD_CONTROLLER_TO_PILOT_MIX_TIMER;

View File

@ -8,7 +8,7 @@
*/ */
// rtl_init - initialise rtl controller // rtl_init - initialise rtl controller
bool Copter::FlightMode_RTL::init(bool ignore_checks) bool Copter::ModeRTL::init(bool ignore_checks)
{ {
if (_copter.position_ok() || ignore_checks) { if (_copter.position_ok() || ignore_checks) {
// initialise waypoint and spline controller // initialise waypoint and spline controller
@ -22,7 +22,7 @@ bool Copter::FlightMode_RTL::init(bool ignore_checks)
} }
// re-start RTL with terrain following disabled // re-start RTL with terrain following disabled
void Copter::FlightMode_RTL::restart_without_terrain() void Copter::ModeRTL::restart_without_terrain()
{ {
// log an error // log an error
_copter.Log_Write_Error(ERROR_SUBSYSTEM_NAVIGATION, ERROR_CODE_RESTARTED_RTL); _copter.Log_Write_Error(ERROR_SUBSYSTEM_NAVIGATION, ERROR_CODE_RESTARTED_RTL);
@ -35,7 +35,7 @@ void Copter::FlightMode_RTL::restart_without_terrain()
// rtl_run - runs the return-to-launch controller // rtl_run - runs the return-to-launch controller
// should be called at 100hz or more // should be called at 100hz or more
void Copter::FlightMode_RTL::run(bool disarm_on_land) void Copter::ModeRTL::run(bool disarm_on_land)
{ {
// check if we need to move to next state // check if we need to move to next state
if (_state_complete) { if (_state_complete) {
@ -88,7 +88,7 @@ void Copter::FlightMode_RTL::run(bool disarm_on_land)
} }
// rtl_climb_start - initialise climb to RTL altitude // rtl_climb_start - initialise climb to RTL altitude
void Copter::FlightMode_RTL::climb_start() void Copter::ModeRTL::climb_start()
{ {
_state = RTL_InitialClimb; _state = RTL_InitialClimb;
_state_complete = false; _state_complete = false;
@ -112,7 +112,7 @@ void Copter::FlightMode_RTL::climb_start()
} }
// rtl_return_start - initialise return to home // rtl_return_start - initialise return to home
void Copter::FlightMode_RTL::return_start() void Copter::ModeRTL::return_start()
{ {
_state = RTL_ReturnHome; _state = RTL_ReturnHome;
_state_complete = false; _state_complete = false;
@ -128,7 +128,7 @@ void Copter::FlightMode_RTL::return_start()
// rtl_climb_return_run - implements the initial climb, return home and descent portions of RTL which all rely on the wp controller // rtl_climb_return_run - implements the initial climb, return home and descent portions of RTL which all rely on the wp controller
// called by rtl_run at 100hz or more // called by rtl_run at 100hz or more
void Copter::FlightMode_RTL::climb_return_run() void Copter::ModeRTL::climb_return_run()
{ {
// if not auto armed or motor interlock not enabled set throttle to zero and exit immediately // if not auto armed or motor interlock not enabled set throttle to zero and exit immediately
if (!motors->armed() || !ap.auto_armed || !motors->get_interlock()) { if (!motors->armed() || !ap.auto_armed || !motors->get_interlock()) {
@ -179,7 +179,7 @@ void Copter::FlightMode_RTL::climb_return_run()
} }
// rtl_loiterathome_start - initialise return to home // rtl_loiterathome_start - initialise return to home
void Copter::FlightMode_RTL::loiterathome_start() void Copter::ModeRTL::loiterathome_start()
{ {
_state = RTL_LoiterAtHome; _state = RTL_LoiterAtHome;
_state_complete = false; _state_complete = false;
@ -195,7 +195,7 @@ void Copter::FlightMode_RTL::loiterathome_start()
// rtl_climb_return_descent_run - implements the initial climb, return home and descent portions of RTL which all rely on the wp controller // rtl_climb_return_descent_run - implements the initial climb, return home and descent portions of RTL which all rely on the wp controller
// called by rtl_run at 100hz or more // called by rtl_run at 100hz or more
void Copter::FlightMode_RTL::loiterathome_run() void Copter::ModeRTL::loiterathome_run()
{ {
// if not auto armed or motor interlock not enabled set throttle to zero and exit immediately // if not auto armed or motor interlock not enabled set throttle to zero and exit immediately
if (!motors->armed() || !ap.auto_armed || !motors->get_interlock()) { if (!motors->armed() || !ap.auto_armed || !motors->get_interlock()) {
@ -256,7 +256,7 @@ void Copter::FlightMode_RTL::loiterathome_run()
} }
// rtl_descent_start - initialise descent to final alt // rtl_descent_start - initialise descent to final alt
void Copter::FlightMode_RTL::descent_start() void Copter::ModeRTL::descent_start()
{ {
_state = RTL_FinalDescent; _state = RTL_FinalDescent;
_state_complete = false; _state_complete = false;
@ -273,7 +273,7 @@ void Copter::FlightMode_RTL::descent_start()
// rtl_descent_run - implements the final descent to the RTL_ALT // rtl_descent_run - implements the final descent to the RTL_ALT
// called by rtl_run at 100hz or more // called by rtl_run at 100hz or more
void Copter::FlightMode_RTL::descent_run() void Copter::ModeRTL::descent_run()
{ {
int16_t roll_control = 0, pitch_control = 0; int16_t roll_control = 0, pitch_control = 0;
float target_yaw_rate = 0; float target_yaw_rate = 0;
@ -338,7 +338,7 @@ void Copter::FlightMode_RTL::descent_run()
} }
// rtl_loiterathome_start - initialise controllers to loiter over home // rtl_loiterathome_start - initialise controllers to loiter over home
void Copter::FlightMode_RTL::land_start() void Copter::ModeRTL::land_start()
{ {
_state = RTL_Land; _state = RTL_Land;
_state_complete = false; _state_complete = false;
@ -356,7 +356,7 @@ void Copter::FlightMode_RTL::land_start()
set_auto_yaw_mode(AUTO_YAW_HOLD); set_auto_yaw_mode(AUTO_YAW_HOLD);
} }
bool Copter::FlightMode_RTL::landing_gear_should_be_deployed() bool Copter::ModeRTL::landing_gear_should_be_deployed()
{ {
switch(_state) { switch(_state) {
case RTL_LoiterAtHome: case RTL_LoiterAtHome:
@ -371,7 +371,7 @@ bool Copter::FlightMode_RTL::landing_gear_should_be_deployed()
// rtl_returnhome_run - return home // rtl_returnhome_run - return home
// called by rtl_run at 100hz or more // called by rtl_run at 100hz or more
void Copter::FlightMode_RTL::land_run(bool disarm_on_land) void Copter::ModeRTL::land_run(bool disarm_on_land)
{ {
// if not auto armed or landing completed or motor interlock not enabled set throttle to zero and exit immediately // if not auto armed or landing completed or motor interlock not enabled set throttle to zero and exit immediately
if (!motors->armed() || !ap.auto_armed || ap.land_complete || !motors->get_interlock()) { if (!motors->armed() || !ap.auto_armed || ap.land_complete || !motors->get_interlock()) {
@ -407,7 +407,7 @@ void Copter::FlightMode_RTL::land_run(bool disarm_on_land)
_state_complete = ap.land_complete; _state_complete = ap.land_complete;
} }
void Copter::FlightMode_RTL::build_path(bool terrain_following_allowed) void Copter::ModeRTL::build_path(bool terrain_following_allowed)
{ {
// origin point is our stopping point // origin point is our stopping point
Vector3f stopping_point; Vector3f stopping_point;
@ -432,7 +432,7 @@ void Copter::FlightMode_RTL::build_path(bool terrain_following_allowed)
// compute the return target - home or rally point // compute the return target - home or rally point
// return altitude in cm above home at which vehicle should return home // return altitude in cm above home at which vehicle should return home
// return target's altitude is updated to a higher altitude that the vehicle can safely return at (frame may also be set) // return target's altitude is updated to a higher altitude that the vehicle can safely return at (frame may also be set)
void Copter::FlightMode_RTL::compute_return_target(bool terrain_following_allowed) void Copter::ModeRTL::compute_return_target(bool terrain_following_allowed)
{ {
// set return target to nearest rally point or home position (Note: alt is absolute) // set return target to nearest rally point or home position (Note: alt is absolute)
#if AC_RALLY == ENABLED #if AC_RALLY == ENABLED

View File

@ -7,7 +7,7 @@
* Once the copter is close to home, it will run a standard land controller. * Once the copter is close to home, it will run a standard land controller.
*/ */
bool Copter::FlightMode_SmartRTL::init(bool ignore_checks) bool Copter::ModeSmartRTL::init(bool ignore_checks)
{ {
if ((copter.position_ok() || ignore_checks) && g2.smart_rtl.is_active()) { if ((copter.position_ok() || ignore_checks) && g2.smart_rtl.is_active()) {
// initialise waypoint and spline controller // initialise waypoint and spline controller
@ -31,12 +31,12 @@ bool Copter::FlightMode_SmartRTL::init(bool ignore_checks)
} }
// perform cleanup required when leaving smart_rtl // perform cleanup required when leaving smart_rtl
void Copter::FlightMode_SmartRTL::exit() void Copter::ModeSmartRTL::exit()
{ {
g2.smart_rtl.cancel_request_for_thorough_cleanup(); g2.smart_rtl.cancel_request_for_thorough_cleanup();
} }
void Copter::FlightMode_SmartRTL::run() void Copter::ModeSmartRTL::run()
{ {
switch (smart_rtl_state) { switch (smart_rtl_state) {
case SmartRTL_WaitForPathCleanup: case SmartRTL_WaitForPathCleanup:
@ -57,7 +57,7 @@ void Copter::FlightMode_SmartRTL::run()
} }
} }
void Copter::FlightMode_SmartRTL::wait_cleanup_run() void Copter::ModeSmartRTL::wait_cleanup_run()
{ {
// hover at current target position // hover at current target position
motors->set_desired_spool_state(AP_Motors::DESIRED_THROTTLE_UNLIMITED); motors->set_desired_spool_state(AP_Motors::DESIRED_THROTTLE_UNLIMITED);
@ -71,7 +71,7 @@ void Copter::FlightMode_SmartRTL::wait_cleanup_run()
} }
} }
void Copter::FlightMode_SmartRTL::path_follow_run() void Copter::ModeSmartRTL::path_follow_run()
{ {
// if we are close to current target point, switch the next point to be our target. // if we are close to current target point, switch the next point to be our target.
if (wp_nav->reached_wp_destination()) { if (wp_nav->reached_wp_destination()) {
@ -108,7 +108,7 @@ void Copter::FlightMode_SmartRTL::path_follow_run()
} }
} }
void Copter::FlightMode_SmartRTL::pre_land_position_run() void Copter::ModeSmartRTL::pre_land_position_run()
{ {
// if we are close to 2m above start point, we are ready to land. // if we are close to 2m above start point, we are ready to land.
if (wp_nav->reached_wp_destination()) { if (wp_nav->reached_wp_destination()) {
@ -131,7 +131,7 @@ void Copter::FlightMode_SmartRTL::pre_land_position_run()
} }
// save current position for use by the smart_rtl flight mode // save current position for use by the smart_rtl flight mode
void Copter::FlightMode_SmartRTL::save_position() void Copter::ModeSmartRTL::save_position()
{ {
const bool should_save_position = motors->armed() && (copter.control_mode != SMART_RTL); const bool should_save_position = motors->armed() && (copter.control_mode != SMART_RTL);

View File

@ -5,7 +5,7 @@
*/ */
// sport_init - initialise sport controller // sport_init - initialise sport controller
bool Copter::FlightMode_Sport::init(bool ignore_checks) bool Copter::ModeSport::init(bool ignore_checks)
{ {
// initialize vertical speed and acceleration // initialize vertical speed and acceleration
pos_control->set_speed_z(-get_pilot_speed_dn(), g.pilot_speed_up); pos_control->set_speed_z(-get_pilot_speed_dn(), g.pilot_speed_up);
@ -22,7 +22,7 @@ bool Copter::FlightMode_Sport::init(bool ignore_checks)
// sport_run - runs the sport controller // sport_run - runs the sport controller
// should be called at 100hz or more // should be called at 100hz or more
void Copter::FlightMode_Sport::run() void Copter::ModeSport::run()
{ {
SportModeState sport_state; SportModeState sport_state;
float takeoff_climb_rate = 0.0f; float takeoff_climb_rate = 0.0f;

View File

@ -5,7 +5,7 @@
*/ */
// stabilize_init - initialise stabilize controller // stabilize_init - initialise stabilize controller
bool Copter::FlightMode_Stabilize::init(bool ignore_checks) bool Copter::ModeStabilize::init(bool ignore_checks)
{ {
// if landed and the mode we're switching from does not have manual throttle and the throttle stick is too high // if landed and the mode we're switching from does not have manual throttle and the throttle stick is too high
if (motors->armed() && ap.land_complete && !_copter.flightmode->has_manual_throttle() && if (motors->armed() && ap.land_complete && !_copter.flightmode->has_manual_throttle() &&
@ -20,7 +20,7 @@ bool Copter::FlightMode_Stabilize::init(bool ignore_checks)
// stabilize_run - runs the main stabilize controller // stabilize_run - runs the main stabilize controller
// should be called at 100hz or more // should be called at 100hz or more
void Copter::FlightMode_Stabilize::run() void Copter::ModeStabilize::run()
{ {
float target_roll, target_pitch; float target_roll, target_pitch;
float target_yaw_rate; float target_yaw_rate;

View File

@ -2,7 +2,7 @@
// throw_init - initialise throw controller // throw_init - initialise throw controller
bool Copter::FlightMode_Throw::init(bool ignore_checks) bool Copter::ModeThrow::init(bool ignore_checks)
{ {
#if FRAME_CONFIG == HELI_FRAME #if FRAME_CONFIG == HELI_FRAME
// do not allow helis to use throw to start // do not allow helis to use throw to start
@ -23,7 +23,7 @@ bool Copter::FlightMode_Throw::init(bool ignore_checks)
// runs the throw to start controller // runs the throw to start controller
// should be called at 100hz or more // should be called at 100hz or more
void Copter::FlightMode_Throw::run() void Copter::ModeThrow::run()
{ {
/* Throw State Machine /* Throw State Machine
Throw_Disarmed - motors are off Throw_Disarmed - motors are off
@ -204,7 +204,7 @@ void Copter::FlightMode_Throw::run()
} }
} }
bool Copter::FlightMode_Throw::throw_detected() bool Copter::ModeThrow::throw_detected()
{ {
// Check that we have a valid navigation solution // Check that we have a valid navigation solution
nav_filter_status filt_status = inertial_nav.get_filter_status(); nav_filter_status filt_status = inertial_nav.get_filter_status();
@ -249,20 +249,20 @@ bool Copter::FlightMode_Throw::throw_detected()
} }
} }
bool Copter::FlightMode_Throw::throw_attitude_good() bool Copter::ModeThrow::throw_attitude_good()
{ {
// Check that we have uprighted the copter // Check that we have uprighted the copter
const Matrix3f &rotMat = ahrs.get_rotation_body_to_ned(); const Matrix3f &rotMat = ahrs.get_rotation_body_to_ned();
return (rotMat.c.z > 0.866f); // is_upright return (rotMat.c.z > 0.866f); // is_upright
} }
bool Copter::FlightMode_Throw::throw_height_good() bool Copter::ModeThrow::throw_height_good()
{ {
// Check that we are no more than 0.5m below the demanded height // Check that we are no more than 0.5m below the demanded height
return (pos_control->get_alt_error() < 50.0f); return (pos_control->get_alt_error() < 50.0f);
} }
bool Copter::FlightMode_Throw::throw_position_good() bool Copter::ModeThrow::throw_position_good()
{ {
// check that our horizontal position error is within 50cm // check that our horizontal position error is within 50cm
return (pos_control->get_horizontal_error() < 50.0f); return (pos_control->get_horizontal_error() < 50.0f);

View File

@ -6,9 +6,9 @@
*/ */
// return the static controller object corresponding to supplied mode // return the static controller object corresponding to supplied mode
Copter::FlightMode *Copter::flightmode_for_mode(const uint8_t mode) Copter::Mode *Copter::flightmode_for_mode(const uint8_t mode)
{ {
Copter::FlightMode *ret = nullptr; Copter::Mode *ret = nullptr;
switch (mode) { switch (mode) {
case ACRO: case ACRO:
@ -110,7 +110,7 @@ bool Copter::set_mode(control_mode_t mode, mode_reason_t reason)
return true; return true;
} }
Copter::FlightMode *new_flightmode = flightmode_for_mode(mode); Copter::Mode *new_flightmode = flightmode_for_mode(mode);
if (new_flightmode == nullptr) { if (new_flightmode == nullptr) {
gcs().send_text(MAV_SEVERITY_WARNING,"No such mode"); gcs().send_text(MAV_SEVERITY_WARNING,"No such mode");
Log_Write_Error(ERROR_SUBSYSTEM_FLIGHT_MODE,mode); Log_Write_Error(ERROR_SUBSYSTEM_FLIGHT_MODE,mode);
@ -176,8 +176,8 @@ void Copter::update_flight_mode()
} }
// exit_mode - high level call to organise cleanup as a flight mode is exited // exit_mode - high level call to organise cleanup as a flight mode is exited
void Copter::exit_mode(Copter::FlightMode *&old_flightmode, void Copter::exit_mode(Copter::Mode *&old_flightmode,
Copter::FlightMode *&new_flightmode) Copter::Mode *&new_flightmode)
{ {
#if AUTOTUNE_ENABLED == ENABLED #if AUTOTUNE_ENABLED == ENABLED
if (old_flightmode == &flightmode_autotune) { if (old_flightmode == &flightmode_autotune) {
@ -235,7 +235,7 @@ void Copter::notify_flight_mode() {
notify.set_flight_mode_str(flightmode->name4()); notify.set_flight_mode_str(flightmode->name4());
} }
void Copter::FlightMode::update_navigation() void Copter::Mode::update_navigation()
{ {
// run autopilot to make high level decisions about control modes // run autopilot to make high level decisions about control modes
run_autopilot(); run_autopilot();

View File

@ -6,7 +6,7 @@
*/ */
// heli_acro_init - initialise acro controller // heli_acro_init - initialise acro controller
bool Copter::FlightMode_Acro_Heli::init(bool ignore_checks) bool Copter::ModeAcro_Heli::init(bool ignore_checks)
{ {
// if heli is equipped with a flybar, then tell the attitude controller to pass through controls directly to servos // if heli is equipped with a flybar, then tell the attitude controller to pass through controls directly to servos
attitude_control->use_flybar_passthrough(motors->has_flybar(), motors->supports_yaw_passthrough()); attitude_control->use_flybar_passthrough(motors->has_flybar(), motors->supports_yaw_passthrough());
@ -22,7 +22,7 @@ bool Copter::FlightMode_Acro_Heli::init(bool ignore_checks)
// heli_acro_run - runs the acro controller // heli_acro_run - runs the acro controller
// should be called at 100hz or more // should be called at 100hz or more
void Copter::FlightMode_Acro_Heli::run() void Copter::ModeAcro_Heli::run()
{ {
float target_roll, target_pitch, target_yaw; float target_roll, target_pitch, target_yaw;
float pilot_throttle_scaled; float pilot_throttle_scaled;

View File

@ -6,7 +6,7 @@
*/ */
// stabilize_init - initialise stabilize controller // stabilize_init - initialise stabilize controller
bool Copter::FlightMode_Stabilize_Heli::init(bool ignore_checks) bool Copter::ModeStabilize_Heli::init(bool ignore_checks)
{ {
// set target altitude to zero for reporting // set target altitude to zero for reporting
// To-Do: make pos controller aware when it's active/inactive so it can always report the altitude error? // To-Do: make pos controller aware when it's active/inactive so it can always report the altitude error?
@ -20,7 +20,7 @@ bool Copter::FlightMode_Stabilize_Heli::init(bool ignore_checks)
// stabilize_run - runs the main stabilize controller // stabilize_run - runs the main stabilize controller
// should be called at 100hz or more // should be called at 100hz or more
void Copter::FlightMode_Stabilize_Heli::run() void Copter::ModeStabilize_Heli::run()
{ {
float target_roll, target_pitch; float target_roll, target_pitch;
float target_yaw_rate; float target_yaw_rate;