2015-12-30 18:57:56 -04:00
|
|
|
/*
|
|
|
|
This program is free software: you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
2017-02-03 00:18:27 -04:00
|
|
|
#include "Sub.h"
|
2017-09-12 15:25:20 -03:00
|
|
|
|
|
|
|
#define FORCE_VERSION_H_INCLUDE
|
2017-02-03 00:18:27 -04:00
|
|
|
#include "version.h"
|
2017-09-12 15:25:20 -03:00
|
|
|
#undef FORCE_VERSION_H_INCLUDE
|
2015-12-30 18:57:56 -04:00
|
|
|
|
|
|
|
const AP_HAL::HAL& hal = AP_HAL::get_HAL();
|
|
|
|
|
2017-02-03 00:18:27 -04:00
|
|
|
/*
|
|
|
|
constructor for main Sub class
|
|
|
|
*/
|
2018-06-28 08:09:40 -03:00
|
|
|
Sub::Sub()
|
2018-06-13 07:27:47 -03:00
|
|
|
: DataFlash(g.log_bitmask),
|
2017-02-03 17:33:27 -04:00
|
|
|
control_mode(MANUAL),
|
|
|
|
motors(MAIN_LOOP_RATE),
|
|
|
|
scaleLongDown(1),
|
|
|
|
auto_mode(Auto_WP),
|
|
|
|
guided_mode(Guided_WP),
|
|
|
|
circle_pilot_yaw_override(false),
|
|
|
|
initial_armed_bearing(0),
|
|
|
|
desired_climb_rate(0),
|
|
|
|
loiter_time_max(0),
|
|
|
|
loiter_time(0),
|
|
|
|
climb_rate(0),
|
|
|
|
target_rangefinder_alt(0.0f),
|
|
|
|
auto_yaw_mode(AUTO_YAW_LOOK_AT_NEXT_WP),
|
|
|
|
yaw_look_at_WP_bearing(0.0f),
|
|
|
|
yaw_look_at_heading(0),
|
|
|
|
yaw_look_at_heading_slew(0),
|
|
|
|
yaw_look_ahead_bearing(0.0f),
|
|
|
|
condition_value(0),
|
|
|
|
condition_start(0),
|
|
|
|
G_Dt(MAIN_LOOP_SECONDS),
|
|
|
|
inertial_nav(ahrs),
|
2017-02-20 14:30:35 -04:00
|
|
|
ahrs_view(ahrs, ROTATION_NONE),
|
|
|
|
attitude_control(ahrs_view, aparm, motors, MAIN_LOOP_SECONDS),
|
2018-01-15 07:58:57 -04:00
|
|
|
pos_control(ahrs_view, inertial_nav, motors, attitude_control),
|
2017-02-20 14:30:35 -04:00
|
|
|
wp_nav(inertial_nav, ahrs_view, pos_control, attitude_control),
|
2018-03-28 01:54:24 -03:00
|
|
|
loiter_nav(inertial_nav, ahrs_view, pos_control, attitude_control),
|
2017-02-20 14:30:35 -04:00
|
|
|
circle_nav(inertial_nav, ahrs_view, pos_control),
|
2017-02-03 17:33:27 -04:00
|
|
|
param_loader(var_info),
|
|
|
|
last_pilot_yaw_input_ms(0)
|
2015-12-30 18:57:56 -04:00
|
|
|
{
|
|
|
|
memset(¤t_loc, 0, sizeof(current_loc));
|
|
|
|
|
|
|
|
// init sensor error logging flags
|
|
|
|
sensor_health.baro = true;
|
|
|
|
sensor_health.compass = true;
|
2016-12-14 18:46:09 -04:00
|
|
|
|
|
|
|
failsafe.last_heartbeat_ms = 0;
|
2017-03-06 14:08:12 -04:00
|
|
|
|
|
|
|
#if CONFIG_HAL_BOARD != HAL_BOARD_SITL
|
2017-04-14 16:58:54 -03:00
|
|
|
failsafe.pilot_input = true;
|
2017-03-06 14:08:12 -04:00
|
|
|
#endif
|
2015-12-30 18:57:56 -04:00
|
|
|
}
|
|
|
|
|
2016-01-14 15:30:56 -04:00
|
|
|
Sub sub;
|