mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-11 02:18:29 -04:00
lots of minor changes, Logs should be working better now.
Pos hold is now called "Loiter" - I don't want to have a flight mode called HOLD POS... git-svn-id: https://arducopter.googlecode.com/svn/trunk@1759 f9c3cf11-9bcb-44bc-f272-b75c42450872
This commit is contained in:
parent
7f330fbb6c
commit
8114b717f2
@ -189,10 +189,8 @@ const char* flight_mode_strings[] = {
|
|||||||
"FBW",
|
"FBW",
|
||||||
"AUTO",
|
"AUTO",
|
||||||
"GCS_AUTO",
|
"GCS_AUTO",
|
||||||
"POS_HOLD",
|
"LOITER",
|
||||||
"RTL",
|
"RTL"};
|
||||||
"TAKEOFF",
|
|
||||||
"LAND"};
|
|
||||||
|
|
||||||
/* Radio values
|
/* Radio values
|
||||||
Channel assignments
|
Channel assignments
|
||||||
@ -304,6 +302,9 @@ boolean land_complete;
|
|||||||
int landing_distance; // meters;
|
int landing_distance; // meters;
|
||||||
long old_alt; // used for managing altitude rates
|
long old_alt; // used for managing altitude rates
|
||||||
int velocity_land;
|
int velocity_land;
|
||||||
|
bool nav_yaw_towards_wp; // point at the next WP
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// Loiter management
|
// Loiter management
|
||||||
// -----------------
|
// -----------------
|
||||||
@ -363,7 +364,7 @@ struct Location next_WP; // next waypoint
|
|||||||
struct Location tell_command; // command for telemetry
|
struct Location tell_command; // command for telemetry
|
||||||
struct Location next_command; // command preloaded
|
struct Location next_command; // command preloaded
|
||||||
long target_altitude; // used for
|
long target_altitude; // used for
|
||||||
long offset_altitude; // used for
|
//long offset_altitude; // used for
|
||||||
boolean home_is_set; // Flag for if we have g_gps lock and have set the home location
|
boolean home_is_set; // Flag for if we have g_gps lock and have set the home location
|
||||||
|
|
||||||
|
|
||||||
@ -415,6 +416,8 @@ float load; // % MCU cycles used
|
|||||||
|
|
||||||
byte counter_one_herz;
|
byte counter_one_herz;
|
||||||
|
|
||||||
|
byte GPS_failure_counter = 255;
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
// Top-level logic
|
// Top-level logic
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
@ -506,7 +509,10 @@ void medium_loop()
|
|||||||
//-------------------------------
|
//-------------------------------
|
||||||
case 0:
|
case 0:
|
||||||
medium_loopCounter++;
|
medium_loopCounter++;
|
||||||
update_GPS();
|
|
||||||
|
if(GPS_failure_counter > 0){
|
||||||
|
update_GPS();
|
||||||
|
}
|
||||||
//readCommands();
|
//readCommands();
|
||||||
|
|
||||||
if(g.compass_enabled){
|
if(g.compass_enabled){
|
||||||
@ -643,7 +649,7 @@ void slow_loop()
|
|||||||
|
|
||||||
if(superslow_loopCounter >= 200){ // Execute every minute
|
if(superslow_loopCounter >= 200){ // Execute every minute
|
||||||
#if HIL_MODE != HIL_MODE_ATTITUDE
|
#if HIL_MODE != HIL_MODE_ATTITUDE
|
||||||
if(g.compass_enabled) {
|
if(g.compass_enabled){
|
||||||
compass.save_offsets();
|
compass.save_offsets();
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@ -678,11 +684,8 @@ void slow_loop()
|
|||||||
// between 1 and 5 Hz
|
// between 1 and 5 Hz
|
||||||
#else
|
#else
|
||||||
gcs.send_message(MSG_LOCATION);
|
gcs.send_message(MSG_LOCATION);
|
||||||
// XXX
|
|
||||||
// gcs.send_message(MSG_CPU_LOAD, load*100);
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
gcs.send_message(MSG_HEARTBEAT); // XXX This is running at 3 1/3 Hz instead of 1 Hz
|
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -693,10 +696,15 @@ void slow_loop()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 1Hz loop
|
||||||
void super_slow_loop()
|
void super_slow_loop()
|
||||||
{
|
{
|
||||||
if (g.log_bitmask & MASK_LOG_CUR)
|
if (g.log_bitmask & MASK_LOG_CUR)
|
||||||
Log_Write_Current();
|
Log_Write_Current();
|
||||||
|
|
||||||
|
gcs.send_message(MSG_HEARTBEAT); // XXX This is running at 3 1/3 Hz instead of 1 Hz
|
||||||
|
// gcs.send_message(MSG_CPU_LOAD, load*100);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void update_GPS(void)
|
void update_GPS(void)
|
||||||
@ -705,6 +713,8 @@ void update_GPS(void)
|
|||||||
update_GPS_light();
|
update_GPS_light();
|
||||||
|
|
||||||
if (g_gps->new_data && g_gps->fix) {
|
if (g_gps->new_data && g_gps->fix) {
|
||||||
|
GPS_failure_counter = 255;
|
||||||
|
|
||||||
// XXX We should be sending GPS data off one of the regular loops so that we send
|
// XXX We should be sending GPS data off one of the regular loops so that we send
|
||||||
// no-GPS-fix data too
|
// no-GPS-fix data too
|
||||||
#if GCS_PROTOCOL != GCS_PROTOCOL_MAVLINK
|
#if GCS_PROTOCOL != GCS_PROTOCOL_MAVLINK
|
||||||
@ -746,6 +756,9 @@ void update_GPS(void)
|
|||||||
current_loc.lng = g_gps->longitude; // Lon * 10 * *7
|
current_loc.lng = g_gps->longitude; // Lon * 10 * *7
|
||||||
current_loc.lat = g_gps->latitude; // Lat * 10 * *7
|
current_loc.lat = g_gps->latitude; // Lat * 10 * *7
|
||||||
|
|
||||||
|
}else{
|
||||||
|
if(GPS_failure_counter > 0)
|
||||||
|
GPS_failure_counter--;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -928,7 +941,7 @@ void update_current_flight_mode(void)
|
|||||||
output_stabilize_pitch();
|
output_stabilize_pitch();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case POSITION_HOLD:
|
case LOITER:
|
||||||
|
|
||||||
// Yaw control
|
// Yaw control
|
||||||
// -----------
|
// -----------
|
||||||
@ -1047,7 +1060,10 @@ void update_alt()
|
|||||||
|
|
||||||
// altitude smoothing
|
// altitude smoothing
|
||||||
// ------------------
|
// ------------------
|
||||||
calc_altitude_error();
|
calc_altitude_smoothing_error();
|
||||||
|
|
||||||
|
|
||||||
|
//calc_altitude_error();
|
||||||
|
|
||||||
// Amount of throttle to apply for hovering
|
// Amount of throttle to apply for hovering
|
||||||
// ----------------------------------------
|
// ----------------------------------------
|
||||||
|
@ -231,7 +231,7 @@ void calc_nav_throttle()
|
|||||||
float scaler = 1.0;
|
float scaler = 1.0;
|
||||||
|
|
||||||
if(error < 0){
|
if(error < 0){
|
||||||
scaler = (altitude_sensor == BARO) ? .5 : .9;
|
scaler = (altitude_sensor == BARO) ? .5 : .8;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(altitude_sensor == BARO){
|
if(altitude_sensor == BARO){
|
||||||
@ -276,7 +276,7 @@ void output_manual_yaw()
|
|||||||
|
|
||||||
void auto_yaw()
|
void auto_yaw()
|
||||||
{
|
{
|
||||||
if(next_WP.options & WP_OPT_YAW){
|
if(nav_yaw_towards_wp){
|
||||||
nav_yaw = target_bearing;
|
nav_yaw = target_bearing;
|
||||||
}
|
}
|
||||||
output_yaw_with_hold(true); // hold yaw
|
output_yaw_with_hold(true); // hold yaw
|
||||||
|
@ -201,7 +201,7 @@ void GCS_MAVLINK::handleMessage(mavlink_message_t* msg)
|
|||||||
{
|
{
|
||||||
|
|
||||||
case MAV_ACTION_LAUNCH:
|
case MAV_ACTION_LAUNCH:
|
||||||
set_mode(TAKEOFF);
|
//set_mode(TAKEOFF);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case MAV_ACTION_RETURN:
|
case MAV_ACTION_RETURN:
|
||||||
@ -209,7 +209,7 @@ void GCS_MAVLINK::handleMessage(mavlink_message_t* msg)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case MAV_ACTION_EMCY_LAND:
|
case MAV_ACTION_EMCY_LAND:
|
||||||
set_mode(LAND);
|
//set_mode(LAND);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case MAV_ACTION_HALT:
|
case MAV_ACTION_HALT:
|
||||||
@ -263,7 +263,7 @@ void GCS_MAVLINK::handleMessage(mavlink_message_t* msg)
|
|||||||
case MAV_ACTION_REC_STOP: break;
|
case MAV_ACTION_REC_STOP: break;
|
||||||
|
|
||||||
case MAV_ACTION_TAKEOFF:
|
case MAV_ACTION_TAKEOFF:
|
||||||
set_mode(TAKEOFF);
|
//set_mode(TAKEOFF);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case MAV_ACTION_NAVIGATE:
|
case MAV_ACTION_NAVIGATE:
|
||||||
@ -271,7 +271,7 @@ void GCS_MAVLINK::handleMessage(mavlink_message_t* msg)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case MAV_ACTION_LAND:
|
case MAV_ACTION_LAND:
|
||||||
set_mode(LAND);
|
//set_mode(LAND);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case MAV_ACTION_LOITER:
|
case MAV_ACTION_LOITER:
|
||||||
|
@ -59,7 +59,7 @@ print_log_menu(void)
|
|||||||
// Pass it the capitalised name of the log option, as defined
|
// Pass it the capitalised name of the log option, as defined
|
||||||
// in defines.h but without the LOG_ prefix. It will check for
|
// in defines.h but without the LOG_ prefix. It will check for
|
||||||
// the bit being set and print the name of the log option to suit.
|
// the bit being set and print the name of the log option to suit.
|
||||||
#define PLOG(_s) if (g.log_bitmask & LOGBIT_ ## _s) Serial.printf_P(PSTR(" %S"), PSTR(#_s))
|
#define PLOG(_s) if (g.log_bitmask & MASK_LOG_ ## _s) Serial.printf_P(PSTR(" %S"), PSTR(#_s))
|
||||||
PLOG(ATTITUDE_FAST);
|
PLOG(ATTITUDE_FAST);
|
||||||
PLOG(ATTITUDE_MED);
|
PLOG(ATTITUDE_MED);
|
||||||
PLOG(GPS);
|
PLOG(GPS);
|
||||||
@ -69,8 +69,8 @@ print_log_menu(void)
|
|||||||
PLOG(MODE);
|
PLOG(MODE);
|
||||||
PLOG(RAW);
|
PLOG(RAW);
|
||||||
PLOG(CMD);
|
PLOG(CMD);
|
||||||
PLOG(CURRENT);
|
PLOG(CUR);
|
||||||
#undef PLOG
|
#undef PLOG
|
||||||
}
|
}
|
||||||
Serial.println();
|
Serial.println();
|
||||||
|
|
||||||
@ -107,7 +107,10 @@ dump_log(uint8_t argc, const Menu::arg *argv)
|
|||||||
|
|
||||||
get_log_boundaries(last_log_num, dump_log, dump_log_start, dump_log_end);
|
get_log_boundaries(last_log_num, dump_log, dump_log_start, dump_log_end);
|
||||||
Serial.printf_P(PSTR("Dumping Log number %d, start page %d, end page %d\n"),
|
Serial.printf_P(PSTR("Dumping Log number %d, start page %d, end page %d\n"),
|
||||||
dump_log, dump_log_start, dump_log_end);
|
dump_log,
|
||||||
|
dump_log_start,
|
||||||
|
dump_log_end);
|
||||||
|
|
||||||
Log_Read(dump_log_start, dump_log_end);
|
Log_Read(dump_log_start, dump_log_end);
|
||||||
Serial.printf_P(PSTR("Log read complete\n"));
|
Serial.printf_P(PSTR("Log read complete\n"));
|
||||||
}
|
}
|
||||||
@ -128,6 +131,7 @@ erase_logs(uint8_t argc, const Menu::arg *argv)
|
|||||||
DataFlash.WriteByte(LOG_INDEX_MSG);
|
DataFlash.WriteByte(LOG_INDEX_MSG);
|
||||||
DataFlash.WriteByte(0);
|
DataFlash.WriteByte(0);
|
||||||
DataFlash.WriteByte(END_BYTE);
|
DataFlash.WriteByte(END_BYTE);
|
||||||
|
DataFlash.FinishWrite();
|
||||||
Serial.printf_P(PSTR("\nLog erased.\n"));
|
Serial.printf_P(PSTR("\nLog erased.\n"));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -151,8 +155,8 @@ select_logs(uint8_t argc, const Menu::arg *argv)
|
|||||||
//
|
//
|
||||||
if (!strcasecmp_P(argv[1].str, PSTR("all"))) {
|
if (!strcasecmp_P(argv[1].str, PSTR("all"))) {
|
||||||
bits = ~(bits = 0);
|
bits = ~(bits = 0);
|
||||||
}else{
|
} else {
|
||||||
#define TARG(_s) if (!strcasecmp_P(argv[1].str, PSTR(#_s))) bits |= LOGBIT_ ## _s
|
#define TARG(_s) if (!strcasecmp_P(argv[1].str, PSTR(#_s))) bits |= MASK_LOG_ ## _s
|
||||||
TARG(ATTITUDE_FAST);
|
TARG(ATTITUDE_FAST);
|
||||||
TARG(ATTITUDE_MED);
|
TARG(ATTITUDE_MED);
|
||||||
TARG(GPS);
|
TARG(GPS);
|
||||||
@ -162,8 +166,8 @@ select_logs(uint8_t argc, const Menu::arg *argv)
|
|||||||
TARG(MODE);
|
TARG(MODE);
|
||||||
TARG(RAW);
|
TARG(RAW);
|
||||||
TARG(CMD);
|
TARG(CMD);
|
||||||
TARG(CURRENT);
|
TARG(CUR);
|
||||||
#undef TARG
|
#undef TARG
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!strcasecmp_P(argv[0].str, PSTR("enable"))) {
|
if (!strcasecmp_P(argv[0].str, PSTR("enable"))) {
|
||||||
@ -373,7 +377,7 @@ void Log_Write_Startup(byte type)
|
|||||||
struct Location cmd = get_wp_with_index(0);
|
struct Location cmd = get_wp_with_index(0);
|
||||||
Log_Write_Cmd(0, &cmd);
|
Log_Write_Cmd(0, &cmd);
|
||||||
|
|
||||||
for (int i=1; i<g.waypoint_total; i++){
|
for (int i = 1; i <= g.waypoint_total; i++){
|
||||||
cmd = get_wp_with_index(i);
|
cmd = get_wp_with_index(i);
|
||||||
Log_Write_Cmd(i, &cmd);
|
Log_Write_Cmd(i, &cmd);
|
||||||
}
|
}
|
||||||
@ -486,7 +490,7 @@ void Log_Write_Current()
|
|||||||
// Read a Current packet
|
// Read a Current packet
|
||||||
void Log_Read_Current()
|
void Log_Read_Current()
|
||||||
{
|
{
|
||||||
Serial.printf("CURR: %d, %4.4f, %4.4f, %d\n",
|
Serial.printf_P(PSTR("CURR: %d, %4.4f, %4.4f, %d\n"),
|
||||||
DataFlash.ReadInt(),
|
DataFlash.ReadInt(),
|
||||||
((float)DataFlash.ReadInt() / 100.f),
|
((float)DataFlash.ReadInt() / 100.f),
|
||||||
((float)DataFlash.ReadInt() / 100.f),
|
((float)DataFlash.ReadInt() / 100.f),
|
||||||
@ -498,11 +502,11 @@ void Log_Read_Control_Tuning()
|
|||||||
{
|
{
|
||||||
float logvar;
|
float logvar;
|
||||||
|
|
||||||
Serial.print("CTUN:");
|
Serial.printf_P(PSTR("CTUN:"));
|
||||||
for (int y=1;y<10;y++) {
|
for (int y = 1; y < 10; y++) {
|
||||||
logvar = DataFlash.ReadInt();
|
logvar = DataFlash.ReadInt();
|
||||||
if(y < 8) logvar = logvar/100.f;
|
if(y < 8) logvar = logvar/100.f;
|
||||||
if(y == 9) logvar = logvar/10000.f;
|
if(y == 9) logvar = logvar/10000.f;
|
||||||
Serial.print(logvar);
|
Serial.print(logvar);
|
||||||
Serial.print(comma);
|
Serial.print(comma);
|
||||||
}
|
}
|
||||||
@ -512,21 +516,14 @@ void Log_Read_Control_Tuning()
|
|||||||
// Read a nav tuning packet
|
// Read a nav tuning packet
|
||||||
void Log_Read_Nav_Tuning()
|
void Log_Read_Nav_Tuning()
|
||||||
{
|
{
|
||||||
Serial.print("NTUN:");
|
Serial.printf_P(PSTR("NTUN: %4.4f, %d, %4.4f, %4.4f, %4.4f, %4.4f, %4.4f,\n"),
|
||||||
Serial.print((float)((uint16_t)DataFlash.ReadInt())/100.0); // Yaw from IMU
|
(float)((uint16_t)DataFlash.ReadInt())/100.0,
|
||||||
Serial.print(comma);
|
DataFlash.ReadInt(),
|
||||||
Serial.print(DataFlash.ReadInt()); // wp_distance
|
(float)((uint16_t)DataFlash.ReadInt())/100.0,
|
||||||
Serial.print(comma);
|
(float)((uint16_t)DataFlash.ReadInt())/100.0,
|
||||||
Serial.print((float)((uint16_t)DataFlash.ReadInt())/100.0); // target_bearing - Bearing to Target
|
(float)DataFlash.ReadInt()/100.0,
|
||||||
Serial.print(comma);
|
(float)DataFlash.ReadInt()/100.0,
|
||||||
Serial.print((float)((uint16_t)DataFlash.ReadInt())/100.0); // nav_bearing - Bearing to steer
|
(float)DataFlash.ReadInt()/1000.0);
|
||||||
Serial.print(comma);
|
|
||||||
Serial.print((float)DataFlash.ReadInt()/100.0); // Altitude error
|
|
||||||
Serial.print(comma);
|
|
||||||
Serial.print((float)DataFlash.ReadInt()/100.0); // Airspeed
|
|
||||||
Serial.print(comma);
|
|
||||||
Serial.print((float)DataFlash.ReadInt()/1000.0); // nav_gain_scaler
|
|
||||||
Serial.println(comma);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Read a performance packet
|
// Read a performance packet
|
||||||
@ -539,10 +536,12 @@ void Log_Read_Performance()
|
|||||||
pm_time = DataFlash.ReadLong();
|
pm_time = DataFlash.ReadLong();
|
||||||
Serial.print(pm_time);
|
Serial.print(pm_time);
|
||||||
Serial.print(comma);
|
Serial.print(comma);
|
||||||
for (int y=1;y<9;y++) {
|
for (int y = 1; y < 9; y++) {
|
||||||
if(y<3 || y>7) logvar = DataFlash.ReadInt();
|
if(y < 3 || y > 7){
|
||||||
else logvar = DataFlash.ReadByte();
|
logvar = DataFlash.ReadInt();
|
||||||
//if(y > 7) logvar = logvar/1000.f;
|
}else{
|
||||||
|
logvar = DataFlash.ReadByte();
|
||||||
|
}
|
||||||
Serial.print(logvar);
|
Serial.print(logvar);
|
||||||
Serial.print(comma);
|
Serial.print(comma);
|
||||||
}
|
}
|
||||||
@ -556,14 +555,14 @@ void Log_Read_Cmd()
|
|||||||
long logvarl;
|
long logvarl;
|
||||||
|
|
||||||
Serial.print("CMD:");
|
Serial.print("CMD:");
|
||||||
for(int i=1;i<4;i++) {
|
for(int i = 1; i < 4; i++) {
|
||||||
logvarb = DataFlash.ReadByte();
|
logvarb = DataFlash.ReadByte();
|
||||||
Serial.print(logvarb,DEC);
|
Serial.print(logvarb, DEC);
|
||||||
Serial.print(comma);
|
Serial.print(comma);
|
||||||
}
|
}
|
||||||
for(int i=1;i<4;i++) {
|
for(int i = 1; i < 4; i++) {
|
||||||
logvarl = DataFlash.ReadLong();
|
logvarl = DataFlash.ReadLong();
|
||||||
Serial.print(logvarl,DEC);
|
Serial.print(logvarl, DEC);
|
||||||
Serial.print(comma);
|
Serial.print(comma);
|
||||||
}
|
}
|
||||||
Serial.println(" ");
|
Serial.println(" ");
|
||||||
@ -572,34 +571,24 @@ void Log_Read_Cmd()
|
|||||||
void Log_Read_Startup()
|
void Log_Read_Startup()
|
||||||
{
|
{
|
||||||
byte logbyte = DataFlash.ReadByte();
|
byte logbyte = DataFlash.ReadByte();
|
||||||
|
|
||||||
if (logbyte == TYPE_AIRSTART_MSG)
|
if (logbyte == TYPE_AIRSTART_MSG)
|
||||||
Serial.print("AIR START - ");
|
Serial.printf_P(PSTR("AIR START - "));
|
||||||
else if (logbyte == TYPE_GROUNDSTART_MSG)
|
else if (logbyte == TYPE_GROUNDSTART_MSG)
|
||||||
Serial.print("GROUND START - ");
|
Serial.printf_P(PSTR("GROUND START - "));
|
||||||
else
|
else
|
||||||
Serial.print("UNKNOWN STARTUP TYPE -");
|
Serial.printf_P(PSTR("UNKNOWN STARTUP - "));
|
||||||
Serial.print(DataFlash.ReadByte(), DEC);
|
|
||||||
Serial.println(" commands in memory");
|
Serial.printf_P(PSTR(" %d commands in memory\n"),(int)DataFlash.ReadByte());
|
||||||
}
|
}
|
||||||
|
|
||||||
// Read an attitude packet
|
// Read an attitude packet
|
||||||
void Log_Read_Attitude()
|
void Log_Read_Attitude()
|
||||||
{
|
{
|
||||||
int log_roll;
|
Serial.printf_P(PSTR("ATT: %d, %d, %d\n"),
|
||||||
int log_pitch;
|
DataFlash.ReadInt(),
|
||||||
uint16_t log_yaw;
|
DataFlash.ReadInt(),
|
||||||
|
(uint16_t)DataFlash.ReadInt());
|
||||||
log_roll = DataFlash.ReadInt();
|
|
||||||
log_pitch = DataFlash.ReadInt();
|
|
||||||
log_yaw = (uint16_t)DataFlash.ReadInt();
|
|
||||||
|
|
||||||
Serial.print("ATT:");
|
|
||||||
Serial.print(log_roll);
|
|
||||||
Serial.print(comma);
|
|
||||||
Serial.print(log_pitch);
|
|
||||||
Serial.print(comma);
|
|
||||||
Serial.print(log_yaw);
|
|
||||||
Serial.println();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Read a mode packet
|
// Read a mode packet
|
||||||
@ -612,25 +601,16 @@ void Log_Read_Mode()
|
|||||||
// Read a GPS packet
|
// Read a GPS packet
|
||||||
void Log_Read_GPS()
|
void Log_Read_GPS()
|
||||||
{
|
{
|
||||||
|
Serial.printf_P(PSTR("GPS: %ld, %d, %d, %4.7f, %4.7f, %4.4f, %4.4f, %4.4f, %4.4f\n"),
|
||||||
Serial.print("GPS:");
|
DataFlash.ReadLong(),
|
||||||
Serial.print(DataFlash.ReadLong()); // Time
|
(int)DataFlash.ReadByte(),
|
||||||
Serial.print(comma);
|
(int)DataFlash.ReadByte(),
|
||||||
Serial.print((int)DataFlash.ReadByte()); // Fix
|
(float)DataFlash.ReadLong() / t7,
|
||||||
Serial.print(comma);
|
(float)DataFlash.ReadLong() / t7,
|
||||||
Serial.print((int)DataFlash.ReadByte()); // Num of Sats
|
(float)DataFlash.ReadLong() / 100.0,
|
||||||
Serial.print(comma);
|
(float)DataFlash.ReadLong() / 100.0,
|
||||||
Serial.print((float)DataFlash.ReadLong()/t7, 7); // Lattitude
|
(float)DataFlash.ReadLong() / 100.0,
|
||||||
Serial.print(comma);
|
(float)DataFlash.ReadLong() / 100.0);
|
||||||
Serial.print((float)DataFlash.ReadLong()/t7, 7); // Longitude
|
|
||||||
Serial.print(comma);
|
|
||||||
Serial.print((float)DataFlash.ReadLong()/100.0); // Baro/gps altitude mix
|
|
||||||
Serial.print(comma);
|
|
||||||
Serial.print((float)DataFlash.ReadLong()/100.0); // GPS altitude
|
|
||||||
Serial.print(comma);
|
|
||||||
Serial.print((float)DataFlash.ReadLong()/100.0); // Ground Speed
|
|
||||||
Serial.print(comma);
|
|
||||||
Serial.println((float)DataFlash.ReadLong()/100.0); // Ground Course
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -639,8 +619,8 @@ void Log_Read_Raw()
|
|||||||
{
|
{
|
||||||
float logvar;
|
float logvar;
|
||||||
Serial.print("RAW:");
|
Serial.print("RAW:");
|
||||||
for (int y=0;y<6;y++) {
|
for (int y = 0; y < 6; y++) {
|
||||||
logvar = (float)DataFlash.ReadLong()/t7;
|
logvar = (float)DataFlash.ReadLong() / t7;
|
||||||
Serial.print(logvar);
|
Serial.print(logvar);
|
||||||
Serial.print(comma);
|
Serial.print(comma);
|
||||||
}
|
}
|
||||||
@ -651,61 +631,60 @@ void Log_Read_Raw()
|
|||||||
void Log_Read(int start_page, int end_page)
|
void Log_Read(int start_page, int end_page)
|
||||||
{
|
{
|
||||||
byte data;
|
byte data;
|
||||||
byte log_step=0;
|
byte log_step;
|
||||||
int packet_count=0;
|
int packet_count;
|
||||||
int page = start_page;
|
int page = start_page;
|
||||||
|
|
||||||
|
|
||||||
DataFlash.StartRead(start_page);
|
DataFlash.StartRead(start_page);
|
||||||
while (page < end_page && page != -1)
|
while (page < end_page && page != -1){
|
||||||
{
|
|
||||||
data = DataFlash.ReadByte();
|
data = DataFlash.ReadByte();
|
||||||
switch(log_step) //This is a state machine to read the packets
|
switch(log_step) // This is a state machine to read the packets
|
||||||
{
|
{
|
||||||
case 0:
|
case 0:
|
||||||
if(data==HEAD_BYTE1) // Head byte 1
|
if(data == HEAD_BYTE1) // Head byte 1
|
||||||
log_step++;
|
log_step++;
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
if(data==HEAD_BYTE2) // Head byte 2
|
if(data == HEAD_BYTE2) // Head byte 2
|
||||||
log_step++;
|
log_step++;
|
||||||
else
|
else
|
||||||
log_step = 0;
|
log_step = 0;
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
if(data==LOG_ATTITUDE_MSG){
|
if(data == LOG_ATTITUDE_MSG){
|
||||||
Log_Read_Attitude();
|
Log_Read_Attitude();
|
||||||
log_step++;
|
log_step++;
|
||||||
|
|
||||||
}else if(data==LOG_MODE_MSG){
|
}else if(data == LOG_MODE_MSG){
|
||||||
Log_Read_Mode();
|
Log_Read_Mode();
|
||||||
log_step++;
|
log_step++;
|
||||||
|
|
||||||
}else if(data==LOG_CONTROL_TUNING_MSG){
|
}else if(data == LOG_CONTROL_TUNING_MSG){
|
||||||
Log_Read_Control_Tuning();
|
Log_Read_Control_Tuning();
|
||||||
log_step++;
|
log_step++;
|
||||||
|
|
||||||
}else if(data==LOG_NAV_TUNING_MSG){
|
}else if(data == LOG_NAV_TUNING_MSG){
|
||||||
Log_Read_Nav_Tuning();
|
Log_Read_Nav_Tuning();
|
||||||
log_step++;
|
log_step++;
|
||||||
|
|
||||||
}else if(data==LOG_PERFORMANCE_MSG){
|
}else if(data == LOG_PERFORMANCE_MSG){
|
||||||
Log_Read_Performance();
|
Log_Read_Performance();
|
||||||
log_step++;
|
log_step++;
|
||||||
|
|
||||||
}else if(data==LOG_RAW_MSG){
|
}else if(data == LOG_RAW_MSG){
|
||||||
Log_Read_Raw();
|
Log_Read_Raw();
|
||||||
log_step++;
|
log_step++;
|
||||||
|
|
||||||
}else if(data==LOG_CMD_MSG){
|
}else if(data == LOG_CMD_MSG){
|
||||||
Log_Read_Cmd();
|
Log_Read_Cmd();
|
||||||
log_step++;
|
log_step++;
|
||||||
|
|
||||||
}else if(data==LOG_CURRENT_MSG){
|
}else if(data == LOG_CURRENT_MSG){
|
||||||
Log_Read_Current();
|
Log_Read_Current();
|
||||||
log_step++;
|
log_step++;
|
||||||
|
|
||||||
}else if(data==LOG_STARTUP_MSG){
|
}else if(data == LOG_STARTUP_MSG){
|
||||||
Log_Read_Startup();
|
Log_Read_Startup();
|
||||||
log_step++;
|
log_step++;
|
||||||
}else {
|
}else {
|
||||||
@ -713,26 +692,23 @@ void Log_Read(int start_page, int end_page)
|
|||||||
Log_Read_GPS();
|
Log_Read_GPS();
|
||||||
log_step++;
|
log_step++;
|
||||||
}else{
|
}else{
|
||||||
Serial.print("Error Reading Packet: ");
|
Serial.printf_P(PSTR("Error Reading Packet: %d\n"),packet_count);
|
||||||
Serial.print(packet_count);
|
|
||||||
log_step = 0; // Restart, we have a problem...
|
log_step = 0; // Restart, we have a problem...
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 3:
|
case 3:
|
||||||
if(data==END_BYTE){
|
if(data == END_BYTE){
|
||||||
packet_count++;
|
packet_count++;
|
||||||
}else{
|
}else{
|
||||||
Serial.print("Error Reading END_BYTE ");
|
Serial.printf_P(PSTR("Error Reading END_BYTE: %d\n"),data);
|
||||||
Serial.println(data,DEC);
|
|
||||||
}
|
}
|
||||||
log_step=0; // Restart sequence: new packet...
|
log_step = 0; // Restart sequence: new packet...
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
page = DataFlash.GetPage();
|
page = DataFlash.GetPage();
|
||||||
}
|
}
|
||||||
Serial.print("Number of packets read: ");
|
Serial.printf_P(PSTR("Number of packets read: %d\n"), packet_count);
|
||||||
Serial.println(packet_count);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -10,257 +10,257 @@ byte mavdelay = 0;
|
|||||||
|
|
||||||
static uint8_t mavlink_check_target(uint8_t sysid, uint8_t compid)
|
static uint8_t mavlink_check_target(uint8_t sysid, uint8_t compid)
|
||||||
{
|
{
|
||||||
if (sysid != mavlink_system.sysid)
|
if (sysid != mavlink_system.sysid){
|
||||||
{
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
|
||||||
else if (compid != mavlink_system.compid)
|
}else if(compid != mavlink_system.compid){
|
||||||
{
|
|
||||||
gcs.send_text(SEVERITY_LOW,"component id mismatch");
|
gcs.send_text(SEVERITY_LOW,"component id mismatch");
|
||||||
return 0; // XXX currently not receiving correct compid from gcs
|
return 0; // XXX currently not receiving correct compid from gcs
|
||||||
|
|
||||||
|
} else {
|
||||||
|
return 0; // no error
|
||||||
}
|
}
|
||||||
else return 0; // no error
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void mavlink_send_message(mavlink_channel_t chan, uint8_t id, uint32_t param, uint16_t packet_drops)
|
void mavlink_send_message(mavlink_channel_t chan, uint8_t id, uint32_t param, uint16_t packet_drops)
|
||||||
{
|
{
|
||||||
uint64_t timeStamp = micros();
|
uint64_t timeStamp = micros();
|
||||||
switch(id) {
|
switch(id) {
|
||||||
|
|
||||||
case MSG_HEARTBEAT:
|
case MSG_HEARTBEAT:
|
||||||
mavlink_msg_heartbeat_send(
|
mavlink_msg_heartbeat_send(
|
||||||
chan,
|
chan,
|
||||||
system_type,
|
system_type,
|
||||||
MAV_AUTOPILOT_ARDUPILOTMEGA);
|
MAV_AUTOPILOT_ARDUPILOTMEGA);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case MSG_EXTENDED_STATUS:
|
case MSG_EXTENDED_STATUS:
|
||||||
{
|
{
|
||||||
uint8_t mode = MAV_MODE_UNINIT;
|
uint8_t mode = MAV_MODE_UNINIT;
|
||||||
uint8_t nav_mode = MAV_NAV_VECTOR;
|
uint8_t nav_mode = MAV_NAV_VECTOR;
|
||||||
|
|
||||||
switch(control_mode) {
|
switch(control_mode) {
|
||||||
case ACRO:
|
case ACRO:
|
||||||
mode = MAV_MODE_MANUAL;
|
mode = MAV_MODE_MANUAL;
|
||||||
break;
|
break;
|
||||||
case STABILIZE:
|
case STABILIZE:
|
||||||
mode = MAV_MODE_GUIDED;
|
mode = MAV_MODE_GUIDED;
|
||||||
break;
|
break;
|
||||||
case FBW:
|
case FBW:
|
||||||
mode = MAV_MODE_TEST1;
|
mode = MAV_MODE_TEST1;
|
||||||
break;
|
break;
|
||||||
case ALT_HOLD:
|
case ALT_HOLD:
|
||||||
mode = MAV_MODE_TEST2;
|
mode = MAV_MODE_TEST2;
|
||||||
break;
|
break;
|
||||||
case POSITION_HOLD:
|
case LOITER:
|
||||||
mode = MAV_MODE_AUTO;
|
mode = MAV_MODE_AUTO;
|
||||||
nav_mode = MAV_NAV_HOLD;
|
nav_mode = MAV_NAV_HOLD;
|
||||||
break;
|
break;
|
||||||
case AUTO:
|
case AUTO:
|
||||||
mode = MAV_MODE_AUTO;
|
mode = MAV_MODE_AUTO;
|
||||||
nav_mode = MAV_NAV_WAYPOINT;
|
nav_mode = MAV_NAV_WAYPOINT;
|
||||||
break;
|
break;
|
||||||
case RTL:
|
case RTL:
|
||||||
mode = MAV_MODE_AUTO;
|
mode = MAV_MODE_AUTO;
|
||||||
nav_mode = MAV_NAV_RETURNING;
|
nav_mode = MAV_NAV_RETURNING;
|
||||||
break;
|
break;
|
||||||
case TAKEOFF:
|
//case TAKEOFF:
|
||||||
mode = MAV_MODE_AUTO;
|
// mode = MAV_MODE_AUTO;
|
||||||
nav_mode = MAV_NAV_LIFTOFF;
|
// nav_mode = MAV_NAV_LIFTOFF;
|
||||||
break;
|
// break;
|
||||||
case LAND:
|
//case LAND:
|
||||||
mode = MAV_MODE_AUTO;
|
// mode = MAV_MODE_AUTO;
|
||||||
nav_mode = MAV_NAV_LANDING;
|
// nav_mode = MAV_NAV_LANDING;
|
||||||
|
// break;
|
||||||
|
}
|
||||||
|
uint8_t status = MAV_STATE_ACTIVE;
|
||||||
|
uint8_t motor_block = false;
|
||||||
|
|
||||||
|
mavlink_msg_sys_status_send(
|
||||||
|
chan,
|
||||||
|
mode,
|
||||||
|
nav_mode,
|
||||||
|
status,
|
||||||
|
load * 1000,
|
||||||
|
battery_voltage1 * 1000,
|
||||||
|
motor_block,
|
||||||
|
packet_drops);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
uint8_t status = MAV_STATE_ACTIVE;
|
|
||||||
uint8_t motor_block = false;
|
|
||||||
|
|
||||||
mavlink_msg_sys_status_send(
|
case MSG_ATTITUDE:
|
||||||
chan,
|
{
|
||||||
mode,
|
Vector3f omega = dcm.get_gyro();
|
||||||
nav_mode,
|
mavlink_msg_attitude_send(
|
||||||
status,
|
chan,
|
||||||
load * 1000,
|
timeStamp,
|
||||||
battery_voltage1 * 1000,
|
dcm.roll,
|
||||||
motor_block,
|
dcm.pitch,
|
||||||
packet_drops);
|
dcm.yaw,
|
||||||
break;
|
omega.x,
|
||||||
}
|
omega.y,
|
||||||
|
omega.z);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
case MSG_ATTITUDE:
|
case MSG_LOCATION:
|
||||||
{
|
{
|
||||||
Vector3f omega = dcm.get_gyro();
|
Matrix3f rot = dcm.get_dcm_matrix(); // neglecting angle of attack for now
|
||||||
mavlink_msg_attitude_send(
|
mavlink_msg_global_position_int_send(
|
||||||
chan,
|
chan,
|
||||||
timeStamp,
|
current_loc.lat,
|
||||||
dcm.roll,
|
current_loc.lng,
|
||||||
dcm.pitch,
|
current_loc.alt * 10,
|
||||||
dcm.yaw,
|
g_gps->ground_speed / 1.0e2 * rot.a.x,
|
||||||
omega.x,
|
g_gps->ground_speed / 1.0e2 * rot.b.x,
|
||||||
omega.y,
|
g_gps->ground_speed / 1.0e2 * rot.c.x);
|
||||||
omega.z);
|
break;
|
||||||
break;
|
}
|
||||||
|
|
||||||
|
case MSG_LOCAL_LOCATION:
|
||||||
|
{
|
||||||
|
Matrix3f rot = dcm.get_dcm_matrix(); // neglecting angle of attack for now
|
||||||
|
mavlink_msg_local_position_send(
|
||||||
|
chan,
|
||||||
|
timeStamp,
|
||||||
|
ToRad((current_loc.lat - home.lat) / 1.0e7) * radius_of_earth,
|
||||||
|
ToRad((current_loc.lng - home.lng) / 1.0e7) * radius_of_earth * cos(ToRad(home.lat / 1.0e7)),
|
||||||
|
(current_loc.alt - home.alt) / 1.0e2,
|
||||||
|
g_gps->ground_speed / 1.0e2 * rot.a.x,
|
||||||
|
g_gps->ground_speed / 1.0e2 * rot.b.x,
|
||||||
|
g_gps->ground_speed / 1.0e2 * rot.c.x);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
case MSG_GPS_RAW:
|
||||||
|
{
|
||||||
|
mavlink_msg_gps_raw_send(
|
||||||
|
chan,
|
||||||
|
timeStamp,
|
||||||
|
g_gps->status(),
|
||||||
|
g_gps->latitude / 1.0e7,
|
||||||
|
g_gps->longitude / 1.0e7,
|
||||||
|
g_gps->altitude / 100.0,
|
||||||
|
g_gps->hdop,
|
||||||
|
0.0,
|
||||||
|
g_gps->ground_speed / 100.0,
|
||||||
|
g_gps->ground_course / 100.0);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
case MSG_SERVO_OUT:
|
||||||
|
{
|
||||||
|
uint8_t rssi = 1;
|
||||||
|
// normalized values scaled to -10000 to 10000
|
||||||
|
// This is used for HIL. Do not change without discussing with HIL maintainers
|
||||||
|
mavlink_msg_rc_channels_scaled_send(
|
||||||
|
chan,
|
||||||
|
g.rc_1.norm_output(),
|
||||||
|
g.rc_2.norm_output(),
|
||||||
|
g.rc_3.norm_output(),
|
||||||
|
g.rc_4.norm_output(),
|
||||||
|
0,0,0,0,rssi);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
case MSG_RADIO_IN:
|
||||||
|
{
|
||||||
|
uint8_t rssi = 1;
|
||||||
|
mavlink_msg_rc_channels_raw_send(
|
||||||
|
chan,
|
||||||
|
g.rc_1.radio_in,
|
||||||
|
g.rc_2.radio_in,
|
||||||
|
g.rc_3.radio_in,
|
||||||
|
g.rc_4.radio_in,
|
||||||
|
g.rc_5.radio_in,
|
||||||
|
g.rc_6.radio_in,
|
||||||
|
g.rc_7.radio_in,
|
||||||
|
g.rc_8.radio_in,
|
||||||
|
rssi);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
case MSG_RADIO_OUT:
|
||||||
|
{
|
||||||
|
mavlink_msg_servo_output_raw_send(
|
||||||
|
chan,
|
||||||
|
motor_out[0],
|
||||||
|
motor_out[1],
|
||||||
|
motor_out[2],
|
||||||
|
motor_out[3],
|
||||||
|
0, 0, 0, 0);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
case MSG_VFR_HUD:
|
||||||
|
{
|
||||||
|
mavlink_msg_vfr_hud_send(
|
||||||
|
chan,
|
||||||
|
(float)airspeed / 100.0,
|
||||||
|
(float)g_gps->ground_speed / 100.0,
|
||||||
|
dcm.yaw_sensor,
|
||||||
|
current_loc.alt / 100.0,
|
||||||
|
climb_rate,
|
||||||
|
nav_throttle);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
#if HIL_MODE != HIL_MODE_ATTITUDE
|
||||||
|
case MSG_RAW_IMU:
|
||||||
|
{
|
||||||
|
Vector3f accel = imu.get_accel();
|
||||||
|
Vector3f gyro = imu.get_gyro();
|
||||||
|
//Serial.printf_P(PSTR("sending accel: %f %f %f\n"), accel.x, accel.y, accel.z);
|
||||||
|
//Serial.printf_P(PSTR("sending gyro: %f %f %f\n"), gyro.x, gyro.y, gyro.z);
|
||||||
|
mavlink_msg_raw_imu_send(
|
||||||
|
chan,
|
||||||
|
timeStamp,
|
||||||
|
accel.x * 1000.0 / gravity,
|
||||||
|
accel.y * 1000.0 / gravity,
|
||||||
|
accel.z * 1000.0 / gravity,
|
||||||
|
gyro.x * 1000.0,
|
||||||
|
gyro.y * 1000.0,
|
||||||
|
gyro.z * 1000.0,
|
||||||
|
compass.mag_x,
|
||||||
|
compass.mag_y,
|
||||||
|
compass.mag_z);
|
||||||
|
|
||||||
|
mavlink_msg_raw_pressure_send(
|
||||||
|
chan,
|
||||||
|
timeStamp,
|
||||||
|
adc.Ch(AIRSPEED_CH),
|
||||||
|
barometer.RawPress,
|
||||||
|
0,
|
||||||
|
0);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
#endif // HIL_PROTOCOL != HIL_PROTOCOL_ATTITUDE
|
||||||
|
|
||||||
|
case MSG_GPS_STATUS:
|
||||||
|
{
|
||||||
|
mavlink_msg_gps_status_send(
|
||||||
|
chan,
|
||||||
|
g_gps->num_sats,
|
||||||
|
NULL,
|
||||||
|
NULL,
|
||||||
|
NULL,
|
||||||
|
NULL,
|
||||||
|
NULL);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
case MSG_CURRENT_WAYPOINT:
|
||||||
|
{
|
||||||
|
mavlink_msg_waypoint_current_send(
|
||||||
|
chan,
|
||||||
|
g.waypoint_index);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
defualt:
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
case MSG_LOCATION:
|
|
||||||
{
|
|
||||||
Matrix3f rot = dcm.get_dcm_matrix(); // neglecting angle of attack for now
|
|
||||||
mavlink_msg_global_position_int_send(
|
|
||||||
chan,
|
|
||||||
current_loc.lat,
|
|
||||||
current_loc.lng,
|
|
||||||
current_loc.alt * 10,
|
|
||||||
g_gps->ground_speed / 1.0e2 * rot.a.x,
|
|
||||||
g_gps->ground_speed / 1.0e2 * rot.b.x,
|
|
||||||
g_gps->ground_speed / 1.0e2 * rot.c.x);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
case MSG_LOCAL_LOCATION:
|
|
||||||
{
|
|
||||||
Matrix3f rot = dcm.get_dcm_matrix(); // neglecting angle of attack for now
|
|
||||||
mavlink_msg_local_position_send(
|
|
||||||
chan,
|
|
||||||
timeStamp,
|
|
||||||
ToRad((current_loc.lat - home.lat) / 1.0e7) * radius_of_earth,
|
|
||||||
ToRad((current_loc.lng - home.lng) / 1.0e7) * radius_of_earth * cos(ToRad(home.lat / 1.0e7)),
|
|
||||||
(current_loc.alt - home.alt) / 1.0e2,
|
|
||||||
g_gps->ground_speed / 1.0e2 * rot.a.x,
|
|
||||||
g_gps->ground_speed / 1.0e2 * rot.b.x,
|
|
||||||
g_gps->ground_speed / 1.0e2 * rot.c.x);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
case MSG_GPS_RAW:
|
|
||||||
{
|
|
||||||
mavlink_msg_gps_raw_send(
|
|
||||||
chan,
|
|
||||||
timeStamp,
|
|
||||||
g_gps->status(),
|
|
||||||
g_gps->latitude / 1.0e7,
|
|
||||||
g_gps->longitude / 1.0e7,
|
|
||||||
g_gps->altitude / 100.0,
|
|
||||||
g_gps->hdop,
|
|
||||||
0.0,
|
|
||||||
g_gps->ground_speed / 100.0,
|
|
||||||
g_gps->ground_course / 100.0);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
case MSG_SERVO_OUT:
|
|
||||||
{
|
|
||||||
uint8_t rssi = 1;
|
|
||||||
// normalized values scaled to -10000 to 10000
|
|
||||||
// This is used for HIL. Do not change without discussing with HIL maintainers
|
|
||||||
mavlink_msg_rc_channels_scaled_send(
|
|
||||||
chan,
|
|
||||||
g.rc_1.norm_output(),
|
|
||||||
g.rc_2.norm_output(),
|
|
||||||
g.rc_3.norm_output(),
|
|
||||||
g.rc_4.norm_output(),
|
|
||||||
0,0,0,0,rssi);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
case MSG_RADIO_IN:
|
|
||||||
{
|
|
||||||
uint8_t rssi = 1;
|
|
||||||
mavlink_msg_rc_channels_raw_send(
|
|
||||||
chan,
|
|
||||||
g.rc_1.radio_in,
|
|
||||||
g.rc_2.radio_in,
|
|
||||||
g.rc_3.radio_in,
|
|
||||||
g.rc_4.radio_in,
|
|
||||||
g.rc_5.radio_in,
|
|
||||||
g.rc_6.radio_in,
|
|
||||||
g.rc_7.radio_in,
|
|
||||||
g.rc_8.radio_in,
|
|
||||||
rssi);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
case MSG_RADIO_OUT:
|
|
||||||
{
|
|
||||||
mavlink_msg_servo_output_raw_send(
|
|
||||||
chan,
|
|
||||||
motor_out[0],
|
|
||||||
motor_out[1],
|
|
||||||
motor_out[2],
|
|
||||||
motor_out[3],
|
|
||||||
0, 0, 0, 0);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
case MSG_VFR_HUD:
|
|
||||||
{
|
|
||||||
mavlink_msg_vfr_hud_send(
|
|
||||||
chan,
|
|
||||||
(float)airspeed / 100.0,
|
|
||||||
(float)g_gps->ground_speed / 100.0,
|
|
||||||
dcm.yaw_sensor,
|
|
||||||
current_loc.alt / 100.0,
|
|
||||||
climb_rate,
|
|
||||||
nav_throttle);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
#if HIL_MODE != HIL_MODE_ATTITUDE
|
|
||||||
case MSG_RAW_IMU:
|
|
||||||
{
|
|
||||||
Vector3f accel = imu.get_accel();
|
|
||||||
Vector3f gyro = imu.get_gyro();
|
|
||||||
//Serial.printf_P(PSTR("sending accel: %f %f %f\n"), accel.x, accel.y, accel.z);
|
|
||||||
//Serial.printf_P(PSTR("sending gyro: %f %f %f\n"), gyro.x, gyro.y, gyro.z);
|
|
||||||
mavlink_msg_raw_imu_send(
|
|
||||||
chan,
|
|
||||||
timeStamp,
|
|
||||||
accel.x * 1000.0 / gravity,
|
|
||||||
accel.y * 1000.0 / gravity,
|
|
||||||
accel.z * 1000.0 / gravity,
|
|
||||||
gyro.x * 1000.0,
|
|
||||||
gyro.y * 1000.0,
|
|
||||||
gyro.z * 1000.0,
|
|
||||||
compass.mag_x,
|
|
||||||
compass.mag_y,
|
|
||||||
compass.mag_z);
|
|
||||||
|
|
||||||
mavlink_msg_raw_pressure_send(
|
|
||||||
chan,
|
|
||||||
timeStamp,
|
|
||||||
adc.Ch(AIRSPEED_CH),
|
|
||||||
barometer.RawPress,
|
|
||||||
0,
|
|
||||||
0);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
#endif // HIL_PROTOCOL != HIL_PROTOCOL_ATTITUDE
|
|
||||||
|
|
||||||
case MSG_GPS_STATUS:
|
|
||||||
{
|
|
||||||
mavlink_msg_gps_status_send(
|
|
||||||
chan,
|
|
||||||
g_gps->num_sats,
|
|
||||||
NULL,
|
|
||||||
NULL,
|
|
||||||
NULL,
|
|
||||||
NULL,
|
|
||||||
NULL);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
case MSG_CURRENT_WAYPOINT:
|
|
||||||
{
|
|
||||||
mavlink_msg_waypoint_current_send(
|
|
||||||
chan,
|
|
||||||
g.waypoint_index);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
defualt:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void mavlink_send_text(mavlink_channel_t chan, uint8_t severity, const char *str)
|
void mavlink_send_text(mavlink_channel_t chan, uint8_t severity, const char *str)
|
||||||
|
@ -40,9 +40,6 @@ struct Location get_wp_with_index(int i)
|
|||||||
mem = (WP_START_BYTE) + (i * WP_SIZE);
|
mem = (WP_START_BYTE) + (i * WP_SIZE);
|
||||||
temp.id = eeprom_read_byte((uint8_t*)mem);
|
temp.id = eeprom_read_byte((uint8_t*)mem);
|
||||||
|
|
||||||
mem++;
|
|
||||||
temp.options = eeprom_read_byte((uint8_t*)mem);
|
|
||||||
|
|
||||||
mem++;
|
mem++;
|
||||||
temp.p1 = eeprom_read_byte((uint8_t*)mem);
|
temp.p1 = eeprom_read_byte((uint8_t*)mem);
|
||||||
|
|
||||||
@ -57,8 +54,10 @@ struct Location get_wp_with_index(int i)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Add on home altitude if we are a nav command
|
// Add on home altitude if we are a nav command
|
||||||
if(temp.options & WP_OPT_ALT_RELATIVE){
|
if(temp.id < 0x70){
|
||||||
temp.alt += home.alt;
|
//if((flight_options_mask & WP_OPT_ALT_RELATIVE) == 0){
|
||||||
|
temp.alt += home.alt;
|
||||||
|
//}
|
||||||
}
|
}
|
||||||
|
|
||||||
return temp;
|
return temp;
|
||||||
@ -77,7 +76,7 @@ void set_wp_with_index(struct Location temp, int i)
|
|||||||
//}
|
//}
|
||||||
|
|
||||||
// Store the location relatove to home
|
// Store the location relatove to home
|
||||||
if(temp.options & WP_OPT_ALT_RELATIVE){
|
if((flight_options_mask & WP_OPT_ALT_RELATIVE) == 0){
|
||||||
temp.alt -= home.alt;
|
temp.alt -= home.alt;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -86,9 +85,6 @@ void set_wp_with_index(struct Location temp, int i)
|
|||||||
|
|
||||||
eeprom_write_byte((uint8_t *) mem, temp.id);
|
eeprom_write_byte((uint8_t *) mem, temp.id);
|
||||||
|
|
||||||
mem++;
|
|
||||||
eeprom_write_byte((uint8_t *) mem, temp.options);
|
|
||||||
|
|
||||||
mem++;
|
mem++;
|
||||||
eeprom_write_byte((uint8_t *) mem, temp.p1);
|
eeprom_write_byte((uint8_t *) mem, temp.p1);
|
||||||
|
|
||||||
@ -167,12 +163,6 @@ void set_next_WP(struct Location *wp)
|
|||||||
// -----------------------------------------------
|
// -----------------------------------------------
|
||||||
target_altitude = current_loc.alt;
|
target_altitude = current_loc.alt;
|
||||||
|
|
||||||
// XXX YUCK!
|
|
||||||
if(prev_WP.id != MAV_CMD_NAV_TAKEOFF && prev_WP.alt != home.alt && (next_WP.id == MAV_CMD_NAV_WAYPOINT || next_WP.id == MAV_CMD_NAV_LAND))
|
|
||||||
offset_altitude = next_WP.alt - prev_WP.alt;
|
|
||||||
else
|
|
||||||
offset_altitude = 0;
|
|
||||||
|
|
||||||
// zero out our loiter vals to watch for missed waypoints
|
// zero out our loiter vals to watch for missed waypoints
|
||||||
loiter_delta = 0;
|
loiter_delta = 0;
|
||||||
loiter_sum = 0;
|
loiter_sum = 0;
|
||||||
|
@ -81,9 +81,6 @@ handle_no_commands()
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
switch (control_mode){
|
switch (control_mode){
|
||||||
case LAND:
|
|
||||||
// don't get a new command
|
|
||||||
break;
|
|
||||||
|
|
||||||
//case GCS_AUTO:
|
//case GCS_AUTO:
|
||||||
// set_mode(LOITER);
|
// set_mode(LOITER);
|
||||||
|
@ -88,11 +88,9 @@
|
|||||||
#define FBW 3 // AUTO control
|
#define FBW 3 // AUTO control
|
||||||
#define AUTO 4 // AUTO control
|
#define AUTO 4 // AUTO control
|
||||||
#define GCS_AUTO 5 // AUTO control
|
#define GCS_AUTO 5 // AUTO control
|
||||||
#define POSITION_HOLD 6 // Hold a single location
|
#define LOITER 6 // Hold a single location
|
||||||
#define RTL 7 // AUTO control
|
#define RTL 7 // AUTO control
|
||||||
#define TAKEOFF 8 // controlled decent rate
|
#define NUM_MODES 8
|
||||||
#define LAND 9 // controlled decent rate
|
|
||||||
#define NUM_MODES 10
|
|
||||||
|
|
||||||
|
|
||||||
#define WP_OPT_ALT_RELATIVE (1<<0)
|
#define WP_OPT_ALT_RELATIVE (1<<0)
|
||||||
@ -207,18 +205,6 @@
|
|||||||
#define MASK_LOG_CMD (1<<8)
|
#define MASK_LOG_CMD (1<<8)
|
||||||
#define MASK_LOG_CUR (1<<9)
|
#define MASK_LOG_CUR (1<<9)
|
||||||
|
|
||||||
// bits in log_bitmask
|
|
||||||
#define LOGBIT_ATTITUDE_FAST (1<<0)
|
|
||||||
#define LOGBIT_ATTITUDE_MED (1<<1)
|
|
||||||
#define LOGBIT_GPS (1<<2)
|
|
||||||
#define LOGBIT_PM (1<<3)
|
|
||||||
#define LOGBIT_CTUN (1<<4)
|
|
||||||
#define LOGBIT_NTUN (1<<5)
|
|
||||||
#define LOGBIT_MODE (1<<6)
|
|
||||||
#define LOGBIT_RAW (1<<7)
|
|
||||||
#define LOGBIT_CMD (1<<8)
|
|
||||||
#define LOGBIT_CURRENT (1<<9)
|
|
||||||
|
|
||||||
// Waypoint Modes
|
// Waypoint Modes
|
||||||
// ----------------
|
// ----------------
|
||||||
#define ABS_WP 0
|
#define ABS_WP 0
|
||||||
|
@ -100,20 +100,19 @@ void calc_bearing_error()
|
|||||||
|
|
||||||
void calc_altitude_error()
|
void calc_altitude_error()
|
||||||
{
|
{
|
||||||
//if(control_mode == AUTO && offset_altitude != 0) {
|
altitude_error = next_WP.alt - current_loc.alt;
|
||||||
if(next_WP.options & WP_OPT_ALT_CHANGE || offset_altitude == 0) {
|
}
|
||||||
target_altitude = next_WP.alt;
|
|
||||||
|
|
||||||
|
void calc_altitude_smoothing_error()
|
||||||
|
{
|
||||||
|
// limit climb rates - we draw a straight line between first location and edge of waypoint_radius
|
||||||
|
target_altitude = next_WP.alt - ((wp_distance * (next_WP.alt - prev_WP.alt)) / (wp_totalDistance - g.waypoint_radius));
|
||||||
|
|
||||||
|
// stay within a certain range
|
||||||
|
if(prev_WP.alt > next_WP.alt){
|
||||||
|
target_altitude = constrain(target_altitude, next_WP.alt, prev_WP.alt);
|
||||||
}else{
|
}else{
|
||||||
// limit climb rates - we draw a straight line between first location and edge of waypoint_radius
|
target_altitude = constrain(target_altitude, prev_WP.alt, next_WP.alt);
|
||||||
target_altitude = next_WP.alt - ((wp_distance * offset_altitude) / (wp_totalDistance - g.waypoint_radius));
|
|
||||||
|
|
||||||
// stay within a certain range
|
|
||||||
if(prev_WP.alt > next_WP.alt){
|
|
||||||
target_altitude = constrain(target_altitude, next_WP.alt, prev_WP.alt);
|
|
||||||
}else{
|
|
||||||
target_altitude = constrain(target_altitude, prev_WP.alt, next_WP.alt);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
altitude_error = target_altitude - current_loc.alt;
|
altitude_error = target_altitude - current_loc.alt;
|
||||||
|
@ -647,7 +647,8 @@ void default_logs()
|
|||||||
{
|
{
|
||||||
|
|
||||||
// convenience macro for testing LOG_* and setting LOGBIT_*
|
// convenience macro for testing LOG_* and setting LOGBIT_*
|
||||||
#define LOGBIT(_s) (LOG_ ## _s ? LOGBIT_ ## _s : 0)
|
#define LOGBIT(_s) (MASK_LOG_##_s ? MASK_LOG_##_s : 0)
|
||||||
|
|
||||||
g.log_bitmask =
|
g.log_bitmask =
|
||||||
LOGBIT(ATTITUDE_FAST) |
|
LOGBIT(ATTITUDE_FAST) |
|
||||||
LOGBIT(ATTITUDE_MED) |
|
LOGBIT(ATTITUDE_MED) |
|
||||||
@ -658,7 +659,7 @@ void default_logs()
|
|||||||
LOGBIT(MODE) |
|
LOGBIT(MODE) |
|
||||||
LOGBIT(RAW) |
|
LOGBIT(RAW) |
|
||||||
LOGBIT(CMD) |
|
LOGBIT(CMD) |
|
||||||
LOGBIT(CURRENT);
|
LOGBIT(CUR);
|
||||||
#undef LOGBIT
|
#undef LOGBIT
|
||||||
|
|
||||||
g.log_bitmask.save();
|
g.log_bitmask.save();
|
||||||
|
@ -287,7 +287,7 @@ void set_mode(byte mode)
|
|||||||
update_auto();
|
update_auto();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case POSITION_HOLD:
|
case LOITER:
|
||||||
do_hold_position();
|
do_hold_position();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -295,12 +295,6 @@ void set_mode(byte mode)
|
|||||||
do_RTL();
|
do_RTL();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case TAKEOFF:
|
|
||||||
break;
|
|
||||||
|
|
||||||
case LAND:
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user