2012-08-21 02:58:09 -03:00
/*
APM_AHRS . cpp
This library is free software ; you can redistribute it and / or
modify it under the terms of the GNU Lesser General Public License
as published by the Free Software Foundation ; either version 2.1
of the License , or ( at your option ) any later version .
*/
# include <AP_AHRS.h>
2012-11-14 12:10:15 -04:00
# include <AP_HAL.h>
extern const AP_HAL : : HAL & hal ;
2012-08-21 02:58:09 -03:00
// table of user settable parameters
const AP_Param : : GroupInfo AP_AHRS : : var_info [ ] PROGMEM = {
// index 0 and 1 are for old parameters that are no longer used
// @Param: GPS_GAIN
// @DisplayName: AHRS GPS gain
2012-11-27 00:56:53 -04:00
// @Description: This controls how how much to use the GPS to correct the attitude. This should never be set to zero for a plane as it would result in the plane losing control in turns. For a plane please use the default value of 1.0.
2012-08-21 02:58:09 -03:00
// @Range: 0.0 1.0
// @Increment: .01
AP_GROUPINFO ( " GPS_GAIN " , 2 , AP_AHRS , gps_gain , 1.0 ) ,
// @Param: GPS_USE
2012-11-27 00:41:52 -04:00
// @DisplayName: AHRS use GPS for navigation
// @Description: This controls whether to use dead-reckoning or GPS based navigation. If set to 0 then the GPS won't be used for navigation, and only dead reckoning will be used. A value of zero should never be used for normal flight.
2012-08-21 02:58:09 -03:00
// @User: Advanced
AP_GROUPINFO ( " GPS_USE " , 3 , AP_AHRS , _gps_use , 1 ) ,
// @Param: YAW_P
// @DisplayName: Yaw P
2012-11-19 07:49:36 -04:00
// @Description: This controls the weight the compass or GPS has on the heading. A higher value means the heading will track the yaw source (GPS or compass) more rapidly.
// @Range: 0.1 0.4
2012-08-21 02:58:09 -03:00
// @Increment: .01
AP_GROUPINFO ( " YAW_P " , 4 , AP_AHRS , _kp_yaw , 0.4 ) ,
// @Param: RP_P
// @DisplayName: AHRS RP_P
// @Description: This controls how fast the accelerometers correct the attitude
2012-11-19 07:49:36 -04:00
// @Range: 0.1 0.4
2012-08-21 02:58:09 -03:00
// @Increment: .01
AP_GROUPINFO ( " RP_P " , 5 , AP_AHRS , _kp , 0.4 ) ,
2012-09-07 22:27:12 -03:00
// @Param: WIND_MAX
// @DisplayName: Maximum wind
// @Description: This sets the maximum allowable difference between ground speed and airspeed. This allows the plane to cope with a failing airspeed sensor. A value of zero means to use the airspeed as is.
// @Range: 0 127
// QUnits: m/s
// @Increment: 1
AP_GROUPINFO ( " WIND_MAX " , 6 , AP_AHRS , _wind_max , 0.0 ) ,
2012-09-12 01:42:04 -03:00
// @Param: BARO_USE
// @DisplayName: AHRS Use Barometer
2012-11-27 00:56:53 -04:00
// @Description: This controls the use of the barometer for vertical acceleration compensation in AHRS. It is currently recommended that you set this value to zero unless you are a developer experimenting with the AHRS system.
2012-09-12 01:42:04 -03:00
// @Values: 0:Disabled,1:Enabled
// @User: Advanced
2012-09-20 02:15:03 -03:00
AP_GROUPINFO ( " BARO_USE " , 7 , AP_AHRS , _baro_use , 0 ) ,
2012-09-12 01:42:04 -03:00
2012-11-05 00:29:00 -04:00
// @Param: TRIM
// @DisplayName: AHRS Trim
// @Description: Compensates for the difference between the control board and the frame
2012-12-10 09:28:39 -04:00
// @Units: Radians
2012-11-05 00:29:00 -04:00
// @User: Advanced
AP_GROUPINFO ( " TRIM " , 8 , AP_AHRS , _trim , 0 ) ,
2012-08-21 02:58:09 -03:00
AP_GROUPEND
} ;
2012-08-24 08:22:58 -03:00
// get pitch rate in earth frame, in radians/s
float AP_AHRS : : get_pitch_rate_earth ( void )
{
Vector3f omega = get_gyro ( ) ;
return cos ( roll ) * omega . y - sin ( roll ) * omega . z ;
}
// get roll rate in earth frame, in radians/s
float AP_AHRS : : get_roll_rate_earth ( void ) {
Vector3f omega = get_gyro ( ) ;
return omega . x + tan ( pitch ) * ( omega . y * sin ( roll ) + omega . z * cos ( roll ) ) ;
}
// return airspeed estimate if available
bool AP_AHRS : : airspeed_estimate ( float * airspeed_ret )
{
if ( _airspeed & & _airspeed - > use ( ) ) {
* airspeed_ret = _airspeed - > get_airspeed ( ) ;
2012-09-07 22:27:12 -03:00
if ( _wind_max > 0 & & _gps & & _gps - > status ( ) = = GPS : : GPS_OK ) {
// constrain the airspeed by the ground speed
// and AHRS_WIND_MAX
* airspeed_ret = constrain ( * airspeed_ret ,
_gps - > ground_speed * 0.01 - _wind_max ,
_gps - > ground_speed * 0.01 + _wind_max ) ;
}
2012-08-24 08:22:58 -03:00
return true ;
}
return false ;
}
2012-11-05 00:29:00 -04:00
// add_trim - adjust the roll and pitch trim up to a total of 10 degrees
2012-12-19 11:06:20 -04:00
void AP_AHRS : : add_trim ( float roll_in_radians , float pitch_in_radians , bool save_to_eeprom )
2012-11-05 00:29:00 -04:00
{
Vector3f trim = _trim . get ( ) ;
// add new trim
trim . x = constrain ( trim . x + roll_in_radians , ToRad ( - 10.0 ) , ToRad ( 10.0 ) ) ;
trim . y = constrain ( trim . y + pitch_in_radians , ToRad ( - 10.0 ) , ToRad ( 10.0 ) ) ;
2012-12-19 11:06:20 -04:00
// set new trim values
_trim . set ( trim ) ;
// save to eeprom
if ( save_to_eeprom ) {
_trim . save ( ) ;
}
2012-11-19 07:49:36 -04:00
}