Bug located in quad position loop, improved hil.

This commit is contained in:
James Goppert 2011-11-19 21:39:14 -05:00
parent 237ca6a4e5
commit 937a268513
9 changed files with 107 additions and 104 deletions

View File

@ -90,6 +90,7 @@ private:
autoAttitudeLoop(dt); autoAttitudeLoop(dt);
} }
void autoPositionLoop(float dt) { void autoPositionLoop(float dt) {
// XXX need to add waypoint coordinates
float cmdNorthTilt = pidPN.update(_nav->getPN(),_nav->getVN(),dt); float cmdNorthTilt = pidPN.update(_nav->getPN(),_nav->getVN(),dt);
float cmdEastTilt = pidPE.update(_nav->getPE(),_nav->getVE(),dt); float cmdEastTilt = pidPE.update(_nav->getPE(),_nav->getVE(),dt);
float cmdDown = pidPD.update(_nav->getPD(),_nav->getVD(),dt); float cmdDown = pidPD.update(_nav->getPD(),_nav->getVD(),dt);
@ -101,11 +102,6 @@ private:
_cmdPitch = cmdEastTilt * trigCos - cmdNorthTilt * trigSin; _cmdPitch = cmdEastTilt * trigCos - cmdNorthTilt * trigSin;
_cmdRoll = -cmdEastTilt * trigSin + cmdNorthTilt * trigCos; _cmdRoll = -cmdEastTilt * trigSin + cmdNorthTilt * trigCos;
// note that the north tilt is negative of the pitch // note that the north tilt is negative of the pitch
Serial.print(" trigSin: ");
Serial.print(trigSin);
Serial.print(" trigCos: ");
Serial.print(trigCos);
} }
_cmdYawRate = 0; _cmdYawRate = 0;
@ -118,33 +114,8 @@ private:
if (fabs(_cmdPitch) > 0.5) _thrustMix *= 1.13949393; if (fabs(_cmdPitch) > 0.5) _thrustMix *= 1.13949393;
else _thrustMix /= cos(_cmdPitch); else _thrustMix /= cos(_cmdPitch);
//debug statements // debug for position loop
Serial.print(" getPN: "); _hal->debug->printf_P(PSTR("cmd: north tilt(%f), east tilt(%f), down(%f), pitch(%f), roll(%f)\n"),cmdNorthTilt,cmdEastTilt,cmdDown,_cmdPitch,_cmdRoll);
Serial.print(_nav->getPN());
Serial.print(" getPE: ");
Serial.print(_nav->getPE());
Serial.print(" getPD: ");
Serial.print(_nav->getPD());
Serial.print(" getVN: ");
Serial.print(_nav->getVN());
Serial.print(" getVE: ");
Serial.print(_nav->getVE());
Serial.print(" getVD: ");
Serial.println(_nav->getVD());
//Serial.print("Roll: ");
//Serial.print(_cmdRoll);
//Serial.print(" Pitch");
//Serial.print(_cmdPitch);
//Serial.print(" YawRate");
//Serial.print(_cmdYawRate);
//Serial.print(" ThrustMix");
//Serial.print(_thrustMix);
//Serial.print(" North Tilt");
//Serial.print(cmdNorthTilt);
//Serial.print(" East Tilt");
//Serial.print(cmdEastTilt);
//Serial.print(" Down");
//Serial.println(cmdDown);
} }
void autoAttitudeLoop(float dt) { void autoAttitudeLoop(float dt) {
_rollMix = pidRoll.update(_cmdRoll - _nav->getRoll(), _rollMix = pidRoll.update(_cmdRoll - _nav->getRoll(),
@ -152,26 +123,6 @@ private:
_pitchMix = pidPitch.update(_cmdPitch - _nav->getPitch(), _pitchMix = pidPitch.update(_cmdPitch - _nav->getPitch(),
_nav->getPitchRate(), dt); _nav->getPitchRate(), dt);
_yawMix = pidYawRate.update(_cmdYawRate - _nav->getYawRate(), dt); _yawMix = pidYawRate.update(_cmdYawRate - _nav->getYawRate(), dt);
//debug statements
//Serial.print("Roll Cmd: ");
//Serial.print(_cmdRoll*1000);
//Serial.print(" Nav_GetRoll: ");
//Serial.print(_nav->getRoll()*1000);
//Serial.print(" Roll Error: ");
//Serial.print((_cmdRoll - _nav->getRoll())*1000);
//Serial.print(" Pitch Cmd: ");
//Serial.print(_cmdPitch*1000);
//Serial.print(" Nav_GetPitch: ");
//Serial.print(_nav->getPitch()*1000);
//Serial.print(" Pitch Error: ");
//Serial.println((_cmdPitch - _nav->getPitch())*1000);
//Serial.print(" YawRate Cmd: ");
//Serial.print(_cmdYawRate);
//Serial.print(" Nav_GetYawRate: ");
//Serial.print( _nav->getYawRate());
//Serial.print(" YawRate Error: ");
//Serial.println(_cmdYawRate - _nav->getYawRate());
} }
void setMotorsActive() { void setMotorsActive() {

View File

@ -12,7 +12,7 @@
static const apo::vehicle_t vehicle = apo::VEHICLE_QUAD; static const apo::vehicle_t vehicle = apo::VEHICLE_QUAD;
static const apo::halMode_t halMode = apo::MODE_HIL_CNTL; static const apo::halMode_t halMode = apo::MODE_HIL_CNTL;
static const apo::board_t board = apo::BOARD_ARDUPILOTMEGA_1280; static const apo::board_t board = apo::BOARD_ARDUPILOTMEGA_1280;
static const uint8_t heartBeatTimeout = 3; static const uint8_t heartBeatTimeout = 0;
// algorithm selection // algorithm selection
#define CONTROLLER_CLASS ControllerQuad #define CONTROLLER_CLASS ControllerQuad
@ -30,7 +30,7 @@ static const uint8_t heartBeatTimeout = 3;
static const uint32_t debugBaud = 57600; static const uint32_t debugBaud = 57600;
static const uint32_t telemBaud = 57600; static const uint32_t telemBaud = 57600;
static const uint32_t gpsBaud = 38400; static const uint32_t gpsBaud = 38400;
static const uint32_t hilBaud = 57600; static const uint32_t hilBaud = 115200;
// optional sensors // optional sensors
static const bool gpsEnabled = false; static const bool gpsEnabled = false;
@ -66,10 +66,10 @@ static const float PID_POS_I = 0;
static const float PID_POS_D = 0; static const float PID_POS_D = 0;
static const float PID_POS_LIM = 0; // about 5 deg static const float PID_POS_LIM = 0; // about 5 deg
static const float PID_POS_AWU = 0; // about 5 deg static const float PID_POS_AWU = 0; // about 5 deg
static const float PID_POS_Z_P = 0; static const float PID_POS_Z_P = 0.1;
static const float PID_POS_Z_I = 0; static const float PID_POS_Z_I = 0;
static const float PID_POS_Z_D = 0; static const float PID_POS_Z_D = 0.2;
static const float PID_POS_Z_LIM = 0; static const float PID_POS_Z_LIM = 0.1;
static const float PID_POS_Z_AWU = 0; static const float PID_POS_Z_AWU = 0;
static const float PID_POS_DFCUT = 10; // cut derivative feedback at 10 hz static const float PID_POS_DFCUT = 10; // cut derivative feedback at 10 hz

View File

@ -609,6 +609,3 @@ mark_as_advanced(ARDUINO_CORES_PATH
ARDUINO_OBJCOPY_EEP_FLAGS ARDUINO_OBJCOPY_EEP_FLAGS
ARDUINO_OBJCOPY_HEX_FLAGS) ARDUINO_OBJCOPY_HEX_FLAGS)
load_board_settings() load_board_settings()
endif()

View File

@ -131,21 +131,23 @@ void MavlinkComm::sendMessage(uint8_t id, uint32_t param) {
*/ */
case MAVLINK_MSG_ID_SCALED_IMU: { case MAVLINK_MSG_ID_SCALED_IMU: {
/* int16_t xmag, ymag, zmag;
* accel/gyro debug xmag = ymag = zmag = 0;
*/ if (_hal->compass) {
/* // XXX THIS IS NOT SCALED
Vector3f accel = _hal->imu->get_accel(); xmag = _hal->compass->mag_x;
Vector3f gyro = _hal->imu->get_gyro(); ymag = _hal->compass->mag_y;
Serial.printf_P(PSTR("accel: %f %f %f gyro: %f %f %f\n"), zmag = _hal->compass->mag_z;
accel.x,accel.y,accel.z,gyro.x,gyro.y,gyro.z); }
*/ mavlink_msg_scaled_imu_send(_channel, timeStamp,
Vector3f accel = _hal->imu->get_accel(); _navigator->getXAccel()*1e3,
Vector3f gyro = _hal->imu->get_gyro(); _navigator->getYAccel()*1e3,
mavlink_msg_raw_imu_send(_channel, timeStamp, 1000 * accel.x, _navigator->getZAccel()*1e3,
1000 * accel.y, 1000 * accel.z, 1000 * gyro.x, _navigator->getRollRate()*1e3,
1000 * gyro.y, 1000 * gyro.z, _hal->compass->mag_x, _navigator->getPitchRate()*1e3,
_hal->compass->mag_y, _hal->compass->mag_z); // XXX THIS IS NOT SCALED FOR MAG _navigator->getYawRate()*1e3,
xmag, ymag, zmag);
break;
} }
case MAVLINK_MSG_ID_RC_CHANNELS_SCALED: { case MAVLINK_MSG_ID_RC_CHANNELS_SCALED: {
@ -352,6 +354,9 @@ void MavlinkComm::_handleMessage(mavlink_message_t * msg) {
_navigator->setLat_degInt(packet.lat); _navigator->setLat_degInt(packet.lat);
_navigator->setLon_degInt(packet.lon); _navigator->setLon_degInt(packet.lon);
_navigator->setAlt(packet.alt / 1e3); _navigator->setAlt(packet.alt / 1e3);
_navigator->setXAccel(packet.xacc/ 1e3);
_navigator->setYAccel(packet.xacc/ 1e3);
_navigator->setZAccel(packet.xacc/ 1e3);
break; break;
} }
@ -391,31 +396,68 @@ void MavlinkComm::_handleMessage(mavlink_message_t * msg) {
AP_Var::save_all(); AP_Var::save_all();
break; break;
case MAV_ACTION_CALIBRATE_RC: case MAV_ACTION_MOTORS_START:
_hal->setState(MAV_STATE_ACTIVE);
break;
case MAV_ACTION_CALIBRATE_GYRO: case MAV_ACTION_CALIBRATE_GYRO:
case MAV_ACTION_CALIBRATE_MAG: case MAV_ACTION_CALIBRATE_MAG:
case MAV_ACTION_CALIBRATE_ACC: case MAV_ACTION_CALIBRATE_ACC:
case MAV_ACTION_CALIBRATE_PRESSURE: case MAV_ACTION_CALIBRATE_PRESSURE:
_hal->setState(MAV_STATE_STANDBY);
_navigator->calibrate();
break;
case MAV_ACTION_EMCY_KILL:
case MAV_ACTION_CONFIRM_KILL:
case MAV_ACTION_MOTORS_STOP:
case MAV_ACTION_SHUTDOWN:
_hal->setState(MAV_STATE_STANDBY);
_controller->setMode(MAV_MODE_LOCKED);
break;
case MAV_ACTION_LAUNCH:
case MAV_ACTION_TAKEOFF:
_controller->setMode(MAV_MODE_AUTO);
_guide->setMode(MAV_NAV_LIFTOFF);
break;
case MAV_ACTION_LAND:
_guide->setCurrentIndex(0);
_guide->setMode(MAV_NAV_LANDING);
break;
case MAV_ACTION_EMCY_LAND:
_guide->setMode(MAV_NAV_LANDING);
break;
case MAV_ACTION_LOITER:
case MAV_ACTION_HALT:
_guide->setMode(MAV_NAV_LOITER);
break;
case MAV_ACTION_SET_AUTO:
_controller->setMode(MAV_MODE_AUTO);
break;
case MAV_ACTION_SET_MANUAL:
_controller->setMode(MAV_MODE_MANUAL);
break;
case MAV_ACTION_RETURN:
_guide->setMode(MAV_NAV_RETURNING);
break;
case MAV_ACTION_NAVIGATE:
case MAV_ACTION_CONTINUE:
_guide->setMode(MAV_NAV_WAYPOINT);
break;
case MAV_ACTION_CALIBRATE_RC:
case MAV_ACTION_REBOOT: case MAV_ACTION_REBOOT:
case MAV_ACTION_REC_START: case MAV_ACTION_REC_START:
case MAV_ACTION_REC_PAUSE: case MAV_ACTION_REC_PAUSE:
case MAV_ACTION_REC_STOP: case MAV_ACTION_REC_STOP:
case MAV_ACTION_TAKEOFF:
case MAV_ACTION_LAND:
case MAV_ACTION_NAVIGATE:
case MAV_ACTION_LOITER:
case MAV_ACTION_MOTORS_START:
case MAV_ACTION_CONFIRM_KILL:
case MAV_ACTION_EMCY_KILL:
case MAV_ACTION_MOTORS_STOP:
case MAV_ACTION_SHUTDOWN:
case MAV_ACTION_CONTINUE:
case MAV_ACTION_SET_MANUAL:
case MAV_ACTION_SET_AUTO:
case MAV_ACTION_LAUNCH:
case MAV_ACTION_RETURN:
case MAV_ACTION_EMCY_LAND:
case MAV_ACTION_HALT:
sendText(SEVERITY_LOW, PSTR("action not implemented")); sendText(SEVERITY_LOW, PSTR("action not implemented"));
break; break;
default: default:

View File

@ -49,18 +49,22 @@ void AP_Controller::update(const float dt) {
// //
// check for heartbeat from gcs, if not found go to failsafe // check for heartbeat from gcs, if not found go to failsafe
if (_hal->heartBeatLost()) { if (_hal->heartBeatLost()) {
_mode = MAV_MODE_FAILSAFE; setMode(MAV_MODE_FAILSAFE);
_hal->gcs->sendText(SEVERITY_HIGH, PSTR("configure gcs to send heartbeat")); _hal->gcs->sendText(SEVERITY_HIGH, PSTR("configure gcs to send heartbeat"));
// if battery less than 5%, go to failsafe // if battery less than 5%, go to failsafe
} else if (_hal->batteryMonitor && _hal->batteryMonitor->getPercentage() < 5) { } else if (_hal->batteryMonitor && _hal->batteryMonitor->getPercentage() < 5) {
_mode = MAV_MODE_FAILSAFE; setMode(MAV_MODE_FAILSAFE);
_hal->gcs->sendText(SEVERITY_HIGH, PSTR("recharge battery")); _hal->gcs->sendText(SEVERITY_HIGH, PSTR("recharge battery"));
// manual/auto switch // manual/auto switch
} else { } else {
// if all emergencies cleared, fall back to standby // if all emergencies cleared, fall back to standby
if (_hal->getState()==MAV_STATE_EMERGENCY) _hal->setState(MAV_STATE_STANDBY); if (_hal->getState()==MAV_STATE_EMERGENCY) _hal->setState(MAV_STATE_STANDBY);
if (_hal->rc[_chMode]->getRadioPosition() > 0) _mode = MAV_MODE_MANUAL;
else _mode = MAV_MODE_AUTO; // if in auto mode and manual switch set, change to manual
if (getMode()==MAV_MODE_AUTO && (_hal->rc[_chMode]->getRadioPosition() > 0)) setMode(MAV_MODE_MANUAL);
// if in manual mode and auto switch set, switch to auto
if (getMode()==MAV_MODE_MANUAL && (_hal->rc[_chMode]->getRadioPosition() < 0)) setMode(MAV_MODE_AUTO);
} }
// handle flight modes // handle flight modes

View File

@ -64,6 +64,10 @@ public:
AP_Uint8 getMode() { AP_Uint8 getMode() {
return _mode; return _mode;
} }
void setMode(MAV_MODE mode) {
_mode = mode;
}
protected: protected:
AP_Navigator * _nav; AP_Navigator * _nav;
AP_Guide * _guide; AP_Guide * _guide;

View File

@ -146,7 +146,7 @@ void MavlinkGuide::handleCommand() {
// check if we are at waypoint or if command // check if we are at waypoint or if command
// radius is zero within tolerance // radius is zero within tolerance
if (distanceToNext < _command.getRadius() | distanceToNext < 1e-5) { if ( (distanceToNext < _command.getRadius()) | (distanceToNext < 1e-5) ) {
_hal->gcs->sendText(SEVERITY_LOW,PSTR("waypoint reached (distance)")); _hal->gcs->sendText(SEVERITY_LOW,PSTR("waypoint reached (distance)"));
_hal->debug->printf_P(PSTR("waypoint reached (distance)")); _hal->debug->printf_P(PSTR("waypoint reached (distance)"));
nextCommand(); nextCommand();
@ -217,9 +217,9 @@ void MavlinkGuide::handleCommand() {
_pDCmd = _command.getPD(_navigator->getAlt_intM()); _pDCmd = _command.getPD(_navigator->getAlt_intM());
// debug // debug
_hal->debug->printf_P( //_hal->debug->printf_P(
PSTR("guide loop, number: %d, current index: %d, previous index: %d\n"), //PSTR("guide loop, number: %d, current index: %d, previous index: %d\n"),
getNumberOfCommands(), getCurrentIndex(), getPreviousIndex()); //getNumberOfCommands(), getCurrentIndex(), getPreviousIndex());
} }
} // namespace apo } // namespace apo

View File

@ -48,6 +48,11 @@ public:
MAV_NAV getMode() const { MAV_NAV getMode() const {
return _mode; return _mode;
} }
void setMode(MAV_NAV mode) {
_mode = mode;
}
uint8_t getCurrentIndex() { uint8_t getCurrentIndex() {
return _cmdIndex; return _cmdIndex;
} }

View File

@ -187,15 +187,15 @@ public:
_vD = vD; _vD = vD;
} }
void setXAcc(float xAccel) { void setXAccel(float xAccel) {
_xAccel = xAccel; _xAccel = xAccel;
} }
void setYAcc(float yAccel) { void setYAccel(float yAccel) {
_yAccel = yAccel; _yAccel = yAccel;
} }
void setZAcc(float zAccel) { void setZAccel(float zAccel) {
_zAccel = zAccel; _zAccel = zAccel;
} }