2013-05-29 20:56:00 -03:00
|
|
|
/// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-
|
2012-02-11 07:59:56 -04:00
|
|
|
|
|
|
|
/*
|
|
|
|
new variable scheme
|
|
|
|
Andrew Tridgell February 2012
|
|
|
|
*/
|
|
|
|
|
2012-12-18 20:32:35 -04:00
|
|
|
#include <math.h>
|
|
|
|
#include <stdarg.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
|
2012-02-11 07:59:56 -04:00
|
|
|
#include <AP_Common.h>
|
2012-12-18 20:32:35 -04:00
|
|
|
#include <AP_Progmem.h>
|
|
|
|
#include <AP_HAL.h>
|
|
|
|
#include <AP_Menu.h>
|
|
|
|
#include <AP_Param.h>
|
|
|
|
#include <AP_GPS.h> // ArduPilot GPS library
|
|
|
|
#include <AP_Baro.h> // ArduPilot barometer library
|
|
|
|
#include <AP_Compass.h> // ArduPilot Mega Magnetometer Library
|
|
|
|
#include <AP_Math.h> // ArduPilot Mega Vector/Matrix math Library
|
|
|
|
#include <AP_ADC.h> // ArduPilot Mega Analog to Digital Converter Library
|
|
|
|
#include <AP_ADC_AnalogSource.h>
|
|
|
|
#include <AP_InertialSensor.h> // Inertial Sensor Library
|
|
|
|
#include <AP_AHRS.h> // ArduPilot Mega DCM Library
|
2014-02-18 04:13:43 -04:00
|
|
|
#include <AP_NavEKF.h>
|
2012-02-11 07:59:56 -04:00
|
|
|
#include <PID.h> // PID library
|
|
|
|
#include <RC_Channel.h> // RC Channel Library
|
2012-12-18 20:32:35 -04:00
|
|
|
#include <AP_RangeFinder.h> // Range finder library
|
|
|
|
#include <Filter.h> // Filter library
|
|
|
|
#include <AP_Buffer.h> // APM FIFO Buffer
|
|
|
|
#include <AP_Relay.h> // APM relay
|
|
|
|
#include <AP_Camera.h> // Photo or video camera
|
|
|
|
#include <AP_Airspeed.h>
|
2013-09-12 22:46:42 -03:00
|
|
|
#include <AP_Vehicle.h>
|
2014-03-18 19:21:35 -03:00
|
|
|
#include <AP_Mission.h>
|
2014-07-25 04:17:34 -03:00
|
|
|
#include <AP_Terrain.h>
|
2013-07-18 04:36:47 -03:00
|
|
|
#include <AP_SpdHgtControl.h>
|
2012-12-18 20:32:35 -04:00
|
|
|
#include <memcheck.h>
|
2014-04-21 05:10:59 -03:00
|
|
|
#include <AP_RCMapper.h>
|
2012-12-18 20:32:35 -04:00
|
|
|
|
|
|
|
#include <APM_OBC.h>
|
|
|
|
#include <APM_Control.h>
|
|
|
|
#include <GCS_MAVLink.h> // MAVLink GCS definitions
|
|
|
|
#include <AP_Mount.h> // Camera/Antenna mount
|
|
|
|
#include <AP_Declination.h> // ArduPilot Mega Declination Helper Library
|
2012-02-12 18:55:39 -04:00
|
|
|
#include <DataFlash.h>
|
2012-08-06 22:02:48 -03:00
|
|
|
#include <SITL.h>
|
2013-08-29 00:23:01 -03:00
|
|
|
#include <AP_Notify.h>
|
2012-12-18 20:32:35 -04:00
|
|
|
|
2012-11-07 09:48:02 -04:00
|
|
|
#include "config.h"
|
|
|
|
#include "Parameters.h"
|
2012-03-17 23:33:09 -03:00
|
|
|
|
2012-12-18 20:32:35 -04:00
|
|
|
#include <AP_HAL_AVR.h>
|
|
|
|
#include <AP_HAL_AVR_SITL.h>
|
|
|
|
#include <AP_HAL_Empty.h>
|
|
|
|
|
|
|
|
AP_HAL::BetterStream* cliSerial;
|
|
|
|
|
|
|
|
const AP_HAL::HAL& hal = AP_HAL_BOARD_DRIVER;
|
|
|
|
|
2012-08-06 22:02:48 -03:00
|
|
|
// this sets up the parameter table, and sets the default values. This
|
|
|
|
// must be the first AP_Param variable declared to ensure its
|
|
|
|
// constructor runs before the constructors of the other AP_Param
|
|
|
|
// variables
|
2012-11-07 09:48:02 -04:00
|
|
|
extern const AP_Param::Info var_info[];
|
2012-08-06 22:02:48 -03:00
|
|
|
AP_Param param_loader(var_info, WP_START_BYTE);
|
|
|
|
|
2012-02-11 07:59:56 -04:00
|
|
|
static Parameters g;
|
2012-02-12 18:55:39 -04:00
|
|
|
|
2014-03-31 04:26:09 -03:00
|
|
|
static AP_GPS gps;
|
2012-12-18 20:32:35 -04:00
|
|
|
AP_InertialSensor_MPU6000 ins;
|
2014-01-02 02:16:54 -04:00
|
|
|
AP_Baro_HIL barometer;
|
2014-03-31 04:26:09 -03:00
|
|
|
AP_AHRS_DCM ahrs(ins, barometer, gps);
|
2012-02-12 18:55:39 -04:00
|
|
|
|
2012-12-18 20:32:35 -04:00
|
|
|
static AP_Compass_HIL compass;
|
2012-08-06 22:02:48 -03:00
|
|
|
SITL sitl;
|
|
|
|
|
2012-02-11 07:59:56 -04:00
|
|
|
#define SERIAL0_BAUD 115200
|
|
|
|
|
2012-12-18 20:32:35 -04:00
|
|
|
#define Debug(fmt, args...) cliSerial->printf("%s:%d: " fmt "\n", __FUNCTION__, __LINE__ , ##args)
|
2012-02-12 03:23:39 -04:00
|
|
|
|
|
|
|
|
2012-02-11 07:59:56 -04:00
|
|
|
void setup() {
|
2012-12-18 20:32:35 -04:00
|
|
|
cliSerial = hal.uartA;
|
|
|
|
|
|
|
|
hal.uartA->begin(SERIAL0_BAUD, 128, 128);
|
|
|
|
|
|
|
|
// load the default values of variables listed in var_info[]
|
|
|
|
AP_Param::setup_sketch_defaults();
|
2012-02-11 07:59:56 -04:00
|
|
|
|
|
|
|
load_parameters();
|
|
|
|
|
2012-02-12 03:23:39 -04:00
|
|
|
// show some sizes
|
2012-12-18 20:32:35 -04:00
|
|
|
cliSerial->printf_P(PSTR("sizeof(RC_Channel)=%u\n"), (unsigned)sizeof(RC_Channel));
|
|
|
|
cliSerial->printf_P(PSTR("sizeof(g)=%u\n"), (unsigned)sizeof(g));
|
|
|
|
cliSerial->printf_P(PSTR("sizeof(g.throttle_min)=%u\n"), (unsigned)sizeof(g.throttle_min));
|
|
|
|
cliSerial->printf_P(PSTR("sizeof(g.channel_roll)=%u\n"), (unsigned)sizeof(g.channel_roll));
|
|
|
|
cliSerial->printf_P(PSTR("throttle_max now: %u\n"), (unsigned)g.throttle_max);
|
2012-02-11 07:59:56 -04:00
|
|
|
|
2012-02-12 03:23:39 -04:00
|
|
|
// some ad-hoc testing
|
|
|
|
|
2012-02-11 07:59:56 -04:00
|
|
|
// try set interfaces
|
|
|
|
g.throttle_min.set(g.throttle_min+1);
|
|
|
|
g.throttle_min.save();
|
|
|
|
g.throttle_min.set_and_save(g.throttle_min+1);
|
|
|
|
|
2012-12-18 20:32:35 -04:00
|
|
|
cliSerial->printf_P(PSTR("throttle_min now: %u\n"), (unsigned)g.throttle_min);
|
2012-02-11 07:59:56 -04:00
|
|
|
|
|
|
|
// find a variable by name
|
|
|
|
AP_Param *vp;
|
2012-02-12 03:23:39 -04:00
|
|
|
enum ap_var_type type;
|
|
|
|
vp = AP_Param::find("RLL2SRV_P", &type);
|
2012-02-11 07:59:56 -04:00
|
|
|
((AP_Float *)vp)->set(23);
|
|
|
|
|
2012-12-18 20:32:35 -04:00
|
|
|
cliSerial->printf_P(PSTR("RLL2SRV_P=%f\n"),
|
2012-02-11 07:59:56 -04:00
|
|
|
g.pidServoRoll.kP());
|
|
|
|
|
2013-01-11 06:24:58 -04:00
|
|
|
#if 0
|
2012-02-11 07:59:56 -04:00
|
|
|
char s[AP_MAX_NAME_SIZE+1];
|
|
|
|
|
|
|
|
g.throttle_min.copy_name(s, sizeof(s));
|
|
|
|
s[AP_MAX_NAME_SIZE] = 0;
|
2012-12-18 20:32:35 -04:00
|
|
|
cliSerial->printf_P(PSTR("THROTTLE_MIN.copy_name()->%s\n"), s);
|
2012-02-11 07:59:56 -04:00
|
|
|
|
|
|
|
g.channel_roll.radio_min.copy_name(s, sizeof(s));
|
|
|
|
s[AP_MAX_NAME_SIZE] = 0;
|
2012-12-18 20:32:35 -04:00
|
|
|
cliSerial->printf_P(PSTR("RC1_MIN.copy_name()->%s %p\n"), s, &g.channel_roll.radio_min);
|
2013-01-11 06:24:58 -04:00
|
|
|
#endif
|
2012-02-12 03:23:39 -04:00
|
|
|
|
2012-02-13 17:34:25 -04:00
|
|
|
Vector3f ofs;
|
|
|
|
ofs = compass.get_offsets();
|
2012-12-18 20:32:35 -04:00
|
|
|
cliSerial->printf_P(PSTR("Compass: %f %f %f\n"),
|
2012-02-13 17:34:25 -04:00
|
|
|
ofs.x, ofs.y, ofs.z);
|
|
|
|
ofs.x += 1.1;
|
|
|
|
ofs.y += 1.2;
|
|
|
|
ofs.z += 1.3;
|
2014-07-11 21:22:25 -03:00
|
|
|
compass.set_and_save_offsets(0, ofs);
|
2012-12-18 20:32:35 -04:00
|
|
|
cliSerial->printf_P(PSTR("Compass: %f %f %f\n"),
|
2012-02-24 02:23:47 -04:00
|
|
|
ofs.x, ofs.y, ofs.z);
|
|
|
|
|
|
|
|
test_vector3f();
|
2012-02-13 17:34:25 -04:00
|
|
|
|
2012-02-12 03:23:39 -04:00
|
|
|
// full testing of all variables
|
2012-02-19 01:58:08 -04:00
|
|
|
AP_Param::ParamToken token;
|
2012-02-12 03:23:39 -04:00
|
|
|
for (AP_Param *ap = AP_Param::first(&token, &type);
|
|
|
|
ap;
|
|
|
|
ap=AP_Param::next(&token, &type)) {
|
2012-08-06 22:02:48 -03:00
|
|
|
//test_variable(ap, type);
|
2012-02-12 03:23:39 -04:00
|
|
|
}
|
2012-02-12 19:16:55 -04:00
|
|
|
|
2013-04-19 04:54:49 -03:00
|
|
|
AP_Param::show_all(cliSerial);
|
2012-02-12 19:16:55 -04:00
|
|
|
|
2012-12-18 20:32:35 -04:00
|
|
|
cliSerial->println_P(PSTR("All done."));
|
2012-02-11 07:59:56 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
void loop()
|
|
|
|
{
|
|
|
|
}
|
2012-02-12 03:23:39 -04:00
|
|
|
|
2012-02-24 02:23:47 -04:00
|
|
|
// test vector3f handling
|
|
|
|
void test_vector3f(void)
|
|
|
|
{
|
|
|
|
enum ap_var_type type;
|
|
|
|
|
|
|
|
AP_Float *f;
|
|
|
|
AP_Vector3f *v;
|
|
|
|
Vector3f vec;
|
|
|
|
|
|
|
|
v = (AP_Vector3f *)AP_Param::find("COMPASS_OFS", &type);
|
|
|
|
|
|
|
|
f = (AP_Float *)AP_Param::find("COMPASS_OFS_X", &type);
|
|
|
|
f->set_and_save(10);
|
|
|
|
f = (AP_Float *)AP_Param::find("COMPASS_OFS_Y", &type);
|
|
|
|
f->set_and_save(11);
|
|
|
|
f = (AP_Float *)AP_Param::find("COMPASS_OFS_Z", &type);
|
|
|
|
f->set_and_save(12);
|
|
|
|
|
|
|
|
v->load();
|
|
|
|
|
|
|
|
vec = *v;
|
2012-12-18 20:32:35 -04:00
|
|
|
cliSerial->printf_P(PSTR("vec %f %f %f\n"),
|
2012-02-24 02:23:47 -04:00
|
|
|
vec.x, vec.y, vec.z);
|
|
|
|
|
|
|
|
if (vec.x != 10 ||
|
|
|
|
vec.y != 11 ||
|
|
|
|
vec.z != 12) {
|
2012-12-18 20:32:35 -04:00
|
|
|
cliSerial->printf_P(PSTR("wrong value for compass vector\n"));
|
2012-02-24 02:23:47 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-01-11 06:24:58 -04:00
|
|
|
#if 0
|
2012-02-12 03:23:39 -04:00
|
|
|
// test all interfaces for a variable
|
|
|
|
void test_variable(AP_Param *ap, enum ap_var_type type)
|
|
|
|
{
|
2012-02-24 02:23:47 -04:00
|
|
|
static int8_t value;
|
2012-02-12 03:23:39 -04:00
|
|
|
char s[AP_MAX_NAME_SIZE+1];
|
|
|
|
|
|
|
|
value++;
|
|
|
|
|
2012-02-24 02:23:47 -04:00
|
|
|
ap->copy_name(s, sizeof(s), type==AP_PARAM_FLOAT);
|
2012-12-18 20:32:35 -04:00
|
|
|
cliSerial->printf_P(PSTR("Testing variable '%s' of type %u\n"),
|
2012-02-12 03:23:39 -04:00
|
|
|
s, type);
|
|
|
|
enum ap_var_type type2;
|
|
|
|
if (AP_Param::find(s, &type2) != ap ||
|
|
|
|
type2 != type) {
|
|
|
|
Debug("find failed");
|
|
|
|
}
|
2012-02-12 18:55:39 -04:00
|
|
|
if (strcmp(s, "FORMAT_VERSION") == 0) {
|
|
|
|
// don't wipe the version
|
|
|
|
return;
|
|
|
|
}
|
2012-02-12 03:23:39 -04:00
|
|
|
switch (type) {
|
|
|
|
case AP_PARAM_INT8: {
|
|
|
|
AP_Int8 *v = (AP_Int8 *)ap;
|
2012-02-12 19:26:21 -04:00
|
|
|
if (sizeof(*v) != 1) {
|
|
|
|
Debug("incorrect size %u", (unsigned)sizeof(*v));
|
|
|
|
}
|
2012-02-12 03:23:39 -04:00
|
|
|
v->set(value);
|
|
|
|
if (!v->save()) {
|
|
|
|
Debug("failed set_and_save");
|
|
|
|
}
|
|
|
|
if (!v->load()) {
|
|
|
|
Debug("failed load");
|
|
|
|
}
|
|
|
|
if (v->get() != value) {
|
2012-02-24 02:23:47 -04:00
|
|
|
Debug("wrong value %d %d", (int)v->get(), (int)value);
|
2012-02-12 03:23:39 -04:00
|
|
|
}
|
|
|
|
if (!v->set_and_save(value+1)) {
|
|
|
|
Debug("failed set_and_save");
|
|
|
|
}
|
|
|
|
if (!v->load()) {
|
|
|
|
Debug("failed load");
|
|
|
|
}
|
|
|
|
if (v->vtype != type) {
|
|
|
|
Debug("wrong type");
|
|
|
|
}
|
|
|
|
if (v->get() != value+1) {
|
|
|
|
Debug("wrong value %u %u", (unsigned)v->get(), value+1);
|
|
|
|
}
|
|
|
|
if (*v != value+1) {
|
|
|
|
Debug("wrong direct value %u %u", (unsigned)v->get(), value+1);
|
|
|
|
}
|
|
|
|
*v = value+2;
|
|
|
|
if (v->get() != value+2) {
|
|
|
|
Debug("wrong copy assignment value %u %u", (unsigned)v->get(), value+2);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case AP_PARAM_INT16: {
|
|
|
|
AP_Int16 *v = (AP_Int16 *)ap;
|
2012-02-12 19:26:21 -04:00
|
|
|
if (sizeof(*v) != 2) {
|
|
|
|
Debug("incorrect size %u", (unsigned)sizeof(*v));
|
|
|
|
}
|
2012-02-12 03:23:39 -04:00
|
|
|
v->set(value);
|
|
|
|
if (!v->save()) {
|
|
|
|
Debug("failed set_and_save");
|
|
|
|
}
|
|
|
|
if (!v->load()) {
|
|
|
|
Debug("failed load");
|
|
|
|
}
|
|
|
|
if (v->get() != value) {
|
|
|
|
Debug("wrong value %u %u", (unsigned)v->get(), value);
|
|
|
|
}
|
|
|
|
if (!v->set_and_save(value+1)) {
|
|
|
|
Debug("failed set_and_save");
|
|
|
|
}
|
|
|
|
if (!v->load()) {
|
|
|
|
Debug("failed load");
|
|
|
|
}
|
|
|
|
if (v->vtype != type) {
|
|
|
|
Debug("wrong type");
|
|
|
|
}
|
|
|
|
if (v->get() != value+1) {
|
|
|
|
Debug("wrong value %u %u", (unsigned)v->get(), value+1);
|
|
|
|
}
|
|
|
|
if (*v != value+1) {
|
|
|
|
Debug("wrong direct value %u %u", (unsigned)v->get(), value+1);
|
|
|
|
}
|
|
|
|
*v = value+2;
|
|
|
|
if (v->get() != value+2) {
|
|
|
|
Debug("wrong copy assignment value %u %u", (unsigned)v->get(), value+2);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case AP_PARAM_INT32: {
|
|
|
|
AP_Int32 *v = (AP_Int32 *)ap;
|
2012-02-12 19:26:21 -04:00
|
|
|
if (sizeof(*v) != 4) {
|
|
|
|
Debug("incorrect size %u", (unsigned)sizeof(*v));
|
|
|
|
}
|
2012-02-12 03:23:39 -04:00
|
|
|
v->set(value);
|
|
|
|
if (!v->save()) {
|
|
|
|
Debug("failed set_and_save");
|
|
|
|
}
|
|
|
|
if (!v->load()) {
|
|
|
|
Debug("failed load");
|
|
|
|
}
|
|
|
|
if (v->get() != value) {
|
|
|
|
Debug("wrong value %u %u", (unsigned)v->get(), value);
|
|
|
|
}
|
|
|
|
if (!v->set_and_save(value+1)) {
|
|
|
|
Debug("failed set_and_save");
|
|
|
|
}
|
|
|
|
if (!v->load()) {
|
|
|
|
Debug("failed load");
|
|
|
|
}
|
|
|
|
if (v->vtype != type) {
|
|
|
|
Debug("wrong type");
|
|
|
|
}
|
|
|
|
if (v->get() != value+1) {
|
|
|
|
Debug("wrong value %u %u", (unsigned)v->get(), value+1);
|
|
|
|
}
|
|
|
|
if (*v != value+1) {
|
|
|
|
Debug("wrong direct value %u %u", (unsigned)v->get(), value+1);
|
|
|
|
}
|
|
|
|
*v = value+2;
|
|
|
|
if (v->get() != value+2) {
|
|
|
|
Debug("wrong copy assignment value %u %u", (unsigned)v->get(), value+2);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case AP_PARAM_FLOAT: {
|
|
|
|
AP_Float *v = (AP_Float *)ap;
|
2012-02-12 19:26:21 -04:00
|
|
|
if (sizeof(*v) != 4) {
|
|
|
|
Debug("incorrect size %u", (unsigned)sizeof(*v));
|
|
|
|
}
|
2012-02-12 03:23:39 -04:00
|
|
|
v->set(value);
|
|
|
|
if (!v->save()) {
|
|
|
|
Debug("failed set_and_save");
|
|
|
|
}
|
|
|
|
if (!v->load()) {
|
|
|
|
Debug("failed load");
|
|
|
|
}
|
|
|
|
if (v->get() != value) {
|
|
|
|
Debug("wrong value %u %u", (unsigned)v->get(), value);
|
|
|
|
}
|
|
|
|
if (!v->set_and_save(value+1)) {
|
|
|
|
Debug("failed set_and_save");
|
|
|
|
}
|
|
|
|
if (!v->load()) {
|
|
|
|
Debug("failed load");
|
|
|
|
}
|
|
|
|
if (v->vtype != type) {
|
|
|
|
Debug("wrong type");
|
|
|
|
}
|
|
|
|
if (v->get() != value+1) {
|
|
|
|
Debug("wrong value %u %u", (unsigned)v->get(), value+1);
|
|
|
|
}
|
|
|
|
if (*v != value+1) {
|
|
|
|
Debug("wrong direct value %u %u", (unsigned)v->get(), value+1);
|
|
|
|
}
|
|
|
|
*v = value+2;
|
|
|
|
if (v->get() != value+2) {
|
|
|
|
Debug("wrong copy assignment value %u %u", (unsigned)v->get(), value+2);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
2012-02-12 19:26:21 -04:00
|
|
|
case AP_PARAM_VECTOR3F: {
|
|
|
|
AP_Vector3f *v = (AP_Vector3f *)ap;
|
|
|
|
if (sizeof(*v) != 12) {
|
|
|
|
Debug("incorrect size %u", (unsigned)sizeof(*v));
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case AP_PARAM_VECTOR6F: {
|
|
|
|
AP_Vector6f *v = (AP_Vector6f *)ap;
|
|
|
|
if (sizeof(*v) != 24) {
|
|
|
|
Debug("incorrect size %u", (unsigned)sizeof(*v));
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case AP_PARAM_MATRIX3F: {
|
|
|
|
AP_Matrix3f *v = (AP_Matrix3f *)ap;
|
|
|
|
if (sizeof(*v) != 36) {
|
|
|
|
Debug("incorrect size %u", (unsigned)sizeof(*v));
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
2012-02-12 03:23:39 -04:00
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2013-01-11 06:24:58 -04:00
|
|
|
#endif
|
2012-12-18 20:32:35 -04:00
|
|
|
|
|
|
|
AP_HAL_MAIN();
|