mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-24 17:48:35 -04:00
fixed airspeed sensor for ArduPlane on APM2
we were trying to use a non-existant ADC chip!
This commit is contained in:
parent
7c939e83e0
commit
5d2301ef47
@ -131,7 +131,9 @@ static AP_Int8 *flight_modes = &g.flight_mode1;
|
|||||||
#if HIL_MODE == HIL_MODE_DISABLED
|
#if HIL_MODE == HIL_MODE_DISABLED
|
||||||
|
|
||||||
// real sensors
|
// real sensors
|
||||||
|
#if CONFIG_ADC == ENABLED
|
||||||
static AP_ADC_ADS7844 adc;
|
static AP_ADC_ADS7844 adc;
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef DESKTOP_BUILD
|
#ifdef DESKTOP_BUILD
|
||||||
AP_Baro_BMP085_HIL barometer;
|
AP_Baro_BMP085_HIL barometer;
|
||||||
@ -224,9 +226,9 @@ ModeFilter sonar_mode_filter;
|
|||||||
|
|
||||||
#if CONFIG_PITOT_SOURCE == PITOT_SOURCE_ADC
|
#if CONFIG_PITOT_SOURCE == PITOT_SOURCE_ADC
|
||||||
AP_AnalogSource_ADC pitot_analog_source( &adc,
|
AP_AnalogSource_ADC pitot_analog_source( &adc,
|
||||||
CONFIG_PITOT_SOURCE_ADC_CHANNEL, 0.25);
|
CONFIG_PITOT_SOURCE_ADC_CHANNEL, 1.0);
|
||||||
#elif CONFIG_PITOT_SOURCE == PITOT_SOURCE_ANALOG_PIN
|
#elif CONFIG_PITOT_SOURCE == PITOT_SOURCE_ANALOG_PIN
|
||||||
AP_AnalogSource_Arduino pitot_analog_source(CONFIG_PITOT_SOURCE_ANALOG_PIN);
|
AP_AnalogSource_Arduino pitot_analog_source(CONFIG_PITOT_SOURCE_ANALOG_PIN, 4.0);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if SONAR_TYPE == MAX_SONAR_XL
|
#if SONAR_TYPE == MAX_SONAR_XL
|
||||||
|
@ -65,6 +65,7 @@
|
|||||||
# define CONFIG_RELAY DISABLED
|
# define CONFIG_RELAY DISABLED
|
||||||
# define MAG_ORIENTATION AP_COMPASS_APM2_SHIELD
|
# define MAG_ORIENTATION AP_COMPASS_APM2_SHIELD
|
||||||
# define CONFIG_SONAR_SOURCE SONAR_SOURCE_ANALOG_PIN
|
# define CONFIG_SONAR_SOURCE SONAR_SOURCE_ANALOG_PIN
|
||||||
|
# define CONFIG_PITOT_SOURCE PITOT_SOURCE_ANALOG_PIN
|
||||||
# ifdef APM2_BETA_HARDWARE
|
# ifdef APM2_BETA_HARDWARE
|
||||||
# define CONFIG_BARO AP_BARO_BMP085
|
# define CONFIG_BARO AP_BARO_BMP085
|
||||||
# else // APM2 Production Hardware (default)
|
# else // APM2 Production Hardware (default)
|
||||||
|
@ -77,10 +77,10 @@ static void read_airspeed(void)
|
|||||||
// calibration before we can use it. This isn't as
|
// calibration before we can use it. This isn't as
|
||||||
// accurate as the 50 point average in zero_airspeed(),
|
// accurate as the 50 point average in zero_airspeed(),
|
||||||
// but it is better than using it uncalibrated
|
// but it is better than using it uncalibrated
|
||||||
airspeed_raw = (float)adc.Ch(AIRSPEED_CH);
|
airspeed_raw = pitot_analog_source.read();
|
||||||
g.airspeed_offset.set_and_save(airspeed_raw);
|
g.airspeed_offset.set_and_save(airspeed_raw);
|
||||||
}
|
}
|
||||||
airspeed_raw = (adc.Ch(AIRSPEED_CH) * 0.1) + (airspeed_raw * 0.9);
|
airspeed_raw = (pitot_analog_source.read() * 0.1) + (airspeed_raw * 0.9);
|
||||||
airspeed_pressure = max((airspeed_raw - g.airspeed_offset), 0);
|
airspeed_pressure = max((airspeed_raw - g.airspeed_offset), 0);
|
||||||
airspeed = sqrt(airspeed_pressure * g.airspeed_ratio) * 100;
|
airspeed = sqrt(airspeed_pressure * g.airspeed_ratio) * 100;
|
||||||
#endif
|
#endif
|
||||||
@ -92,10 +92,10 @@ static void zero_airspeed(void)
|
|||||||
{
|
{
|
||||||
float sum = 0;
|
float sum = 0;
|
||||||
int c;
|
int c;
|
||||||
airspeed_raw = adc.Ch(AIRSPEED_CH);
|
airspeed_raw = pitot_analog_source.read();
|
||||||
for(c = 0; c < 250; c++) {
|
for(c = 0; c < 250; c++) {
|
||||||
delay(2);
|
delay(2);
|
||||||
sum += adc.Ch(AIRSPEED_CH);
|
sum += pitot_analog_source.read();
|
||||||
}
|
}
|
||||||
sum /= c;
|
sum /= c;
|
||||||
g.airspeed_offset.set_and_save((int16_t)sum);
|
g.airspeed_offset.set_and_save((int16_t)sum);
|
||||||
|
@ -177,7 +177,9 @@ static void init_ardupilot()
|
|||||||
|
|
||||||
#if HIL_MODE != HIL_MODE_ATTITUDE
|
#if HIL_MODE != HIL_MODE_ATTITUDE
|
||||||
|
|
||||||
|
#if CONFIG_ADC == ENABLED
|
||||||
adc.Init(&timer_scheduler); // APM ADC library initialization
|
adc.Init(&timer_scheduler); // APM ADC library initialization
|
||||||
|
#endif
|
||||||
|
|
||||||
barometer.init(&timer_scheduler);
|
barometer.init(&timer_scheduler);
|
||||||
|
|
||||||
|
@ -626,8 +626,8 @@ test_mag(uint8_t argc, const Menu::arg *argv)
|
|||||||
static int8_t
|
static int8_t
|
||||||
test_airspeed(uint8_t argc, const Menu::arg *argv)
|
test_airspeed(uint8_t argc, const Menu::arg *argv)
|
||||||
{
|
{
|
||||||
float airspeed_ch = adc.Ch(AIRSPEED_CH);
|
float airspeed_ch = pitot_analog_source.read();
|
||||||
// Serial.println(adc.Ch(AIRSPEED_CH));
|
// Serial.println(pitot_analog_source.read());
|
||||||
Serial.printf_P(PSTR("airspeed_ch: %.1f\n"), airspeed_ch);
|
Serial.printf_P(PSTR("airspeed_ch: %.1f\n"), airspeed_ch);
|
||||||
|
|
||||||
if (g.airspeed_enabled == false){
|
if (g.airspeed_enabled == false){
|
||||||
|
Loading…
Reference in New Issue
Block a user