mirror of
https://gitee.com/mirrors_PX4/PX4-Autopilot.git
synced 2026-07-03 20:40:36 +08:00
303 lines
7.3 KiB
C
303 lines
7.3 KiB
C
/****************************************************************************
|
|
*
|
|
* Copyright (c) 2012-2017 PX4 Development Team. All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that the following conditions
|
|
* are met:
|
|
*
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
* notice, this list of conditions and the following disclaimer.
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
* notice, this list of conditions and the following disclaimer in
|
|
* the documentation and/or other materials provided with the
|
|
* distribution.
|
|
* 3. Neither the name PX4 nor the names of its contributors may be
|
|
* used to endorse or promote products derived from this software
|
|
* without specific prior written permission.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
|
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
|
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
|
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
|
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
|
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
|
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
* POSSIBILITY OF SUCH DAMAGE.
|
|
*
|
|
****************************************************************************/
|
|
|
|
/**
|
|
* Primary baro ID
|
|
*
|
|
* @group Sensor Calibration
|
|
*/
|
|
PARAM_DEFINE_INT32(CAL_BARO_PRIME, 0);
|
|
|
|
/**
|
|
* Airspeed sensor pitot model
|
|
*
|
|
* @value 0 HB Pitot
|
|
*
|
|
* @group Sensor Calibration
|
|
*/
|
|
PARAM_DEFINE_INT32(CAL_AIR_PMODEL, 0);
|
|
|
|
/**
|
|
* Airspeed sensor tube length
|
|
* @min 0.01
|
|
* @max 0.5
|
|
* @unit meter
|
|
*
|
|
* @group Sensor Calibration
|
|
*/
|
|
PARAM_DEFINE_FLOAT(CAL_AIR_TUBELEN, 0.2f);
|
|
|
|
/**
|
|
* Differential pressure sensor offset
|
|
*
|
|
* The offset (zero-reading) in Pascal
|
|
*
|
|
* @group Sensor Calibration
|
|
*/
|
|
PARAM_DEFINE_FLOAT(SENS_DPRES_OFF, 0.0f);
|
|
|
|
/**
|
|
* Differential pressure sensor analog scaling
|
|
*
|
|
* Pick the appropriate scaling from the datasheet.
|
|
* this number defines the (linear) conversion from voltage
|
|
* to Pascal (pa). For the MPXV7002DP this is 1000.
|
|
*
|
|
* NOTE: If the sensor always registers zero, try switching
|
|
* the static and dynamic tubes.
|
|
*
|
|
* @group Sensor Calibration
|
|
*/
|
|
PARAM_DEFINE_FLOAT(SENS_DPRES_ANSC, 0);
|
|
|
|
/**
|
|
* QNH for barometer
|
|
*
|
|
* @min 500
|
|
* @max 1500
|
|
* @group Sensors
|
|
* @unit hPa
|
|
*/
|
|
PARAM_DEFINE_FLOAT(SENS_BARO_QNH, 1013.25f);
|
|
|
|
/**
|
|
* Board rotation
|
|
*
|
|
* This parameter defines the rotation of the FMU board relative to the platform.
|
|
*
|
|
* @value 0 No rotation
|
|
* @value 1 Yaw 45°
|
|
* @value 2 Yaw 90°
|
|
* @value 3 Yaw 135°
|
|
* @value 4 Yaw 180°
|
|
* @value 5 Yaw 225°
|
|
* @value 6 Yaw 270°
|
|
* @value 7 Yaw 315°
|
|
* @value 8 Roll 180°
|
|
* @value 9 Roll 180°, Yaw 45°
|
|
* @value 10 Roll 180°, Yaw 90°
|
|
* @value 11 Roll 180°, Yaw 135°
|
|
* @value 12 Pitch 180°
|
|
* @value 13 Roll 180°, Yaw 225°
|
|
* @value 14 Roll 180°, Yaw 270°
|
|
* @value 15 Roll 180°, Yaw 315°
|
|
* @value 16 Roll 90°
|
|
* @value 17 Roll 90°, Yaw 45°
|
|
* @value 18 Roll 90°, Yaw 90°
|
|
* @value 19 Roll 90°, Yaw 135°
|
|
* @value 20 Roll 270°
|
|
* @value 21 Roll 270°, Yaw 45°
|
|
* @value 22 Roll 270°, Yaw 90°
|
|
* @value 23 Roll 270°, Yaw 135°
|
|
* @value 24 Pitch 90°
|
|
* @value 25 Pitch 270°
|
|
*
|
|
* @reboot_required true
|
|
*
|
|
* @group Sensors
|
|
*/
|
|
PARAM_DEFINE_INT32(SENS_BOARD_ROT, 0);
|
|
|
|
/**
|
|
* PX4Flow board rotation
|
|
*
|
|
* This parameter defines the yaw rotation of the PX4FLOW board relative to the vehicle body frame.
|
|
* Zero rotation is defined as X on flow board pointing towards front of vehicle.
|
|
* The recommneded installation default for the PX4FLOW board is with the Y axis forward (270 deg yaw).
|
|
*
|
|
* @value 0 No rotation
|
|
* @value 1 Yaw 45°
|
|
* @value 2 Yaw 90°
|
|
* @value 3 Yaw 135°
|
|
* @value 4 Yaw 180°
|
|
* @value 5 Yaw 225°
|
|
* @value 6 Yaw 270°
|
|
* @value 7 Yaw 315°
|
|
*
|
|
* @reboot_required true
|
|
*
|
|
* @group Sensors
|
|
*/
|
|
PARAM_DEFINE_INT32(SENS_FLOW_ROT, 6);
|
|
|
|
/**
|
|
* Board rotation Y (Pitch) offset
|
|
*
|
|
* This parameter defines a rotational offset in degrees around the Y (Pitch) axis. It allows the user
|
|
* to fine tune the board offset in the event of misalignment.
|
|
*
|
|
* @unit deg
|
|
* @group Sensors
|
|
*/
|
|
PARAM_DEFINE_FLOAT(SENS_BOARD_Y_OFF, 0.0f);
|
|
|
|
/**
|
|
* Board rotation X (Roll) offset
|
|
*
|
|
* This parameter defines a rotational offset in degrees around the X (Roll) axis It allows the user
|
|
* to fine tune the board offset in the event of misalignment.
|
|
*
|
|
* @unit deg
|
|
* @group Sensors
|
|
*/
|
|
PARAM_DEFINE_FLOAT(SENS_BOARD_X_OFF, 0.0f);
|
|
|
|
/**
|
|
* Board rotation Z (YAW) offset
|
|
*
|
|
* This parameter defines a rotational offset in degrees around the Z (Yaw) axis. It allows the user
|
|
* to fine tune the board offset in the event of misalignment.
|
|
*
|
|
* @unit deg
|
|
* @group Sensors
|
|
*/
|
|
PARAM_DEFINE_FLOAT(SENS_BOARD_Z_OFF, 0.0f);
|
|
|
|
/**
|
|
* Threshold (of RMS) to warn about high vibration levels
|
|
*
|
|
* @group Sensors
|
|
* @min 0.01
|
|
* @max 10
|
|
* @decimal 2
|
|
*/
|
|
PARAM_DEFINE_FLOAT(ATT_VIBE_THRESH, 0.2f);
|
|
|
|
/**
|
|
* Lidar-Lite (LL40LS)
|
|
*
|
|
* @reboot_required true
|
|
* @min 0
|
|
* @max 2
|
|
* @group Sensors
|
|
* @value 0 Disabled
|
|
* @value 1 PWM
|
|
* @value 2 I2C
|
|
*/
|
|
PARAM_DEFINE_INT32(SENS_EN_LL40LS, 0);
|
|
|
|
/**
|
|
* Lightware laser rangefinder (serial)
|
|
*
|
|
* @reboot_required true
|
|
* @min 0
|
|
* @max 4
|
|
* @group Sensors
|
|
* @value 0 Disabled
|
|
* @value 1 SF02
|
|
* @value 2 SF10/a
|
|
* @value 3 SF10/b
|
|
* @value 4 SF10/c
|
|
* @value 5 SF11/c
|
|
*/
|
|
PARAM_DEFINE_INT32(SENS_EN_SF0X, 0);
|
|
|
|
/**
|
|
* Maxbotix Soanr (mb12xx)
|
|
*
|
|
* @reboot_required true
|
|
*
|
|
* @boolean
|
|
* @group Sensors
|
|
*/
|
|
PARAM_DEFINE_INT32(SENS_EN_MB12XX, 0);
|
|
|
|
/**
|
|
* TeraRanger Rangefinder (i2c)
|
|
*
|
|
* @reboot_required true
|
|
* @min 0
|
|
* @max 3
|
|
* @group Sensors
|
|
* @value 0 Disabled
|
|
* @value 1 Autodetect
|
|
* @value 2 TROne
|
|
* @value 3 TREvo
|
|
*/
|
|
PARAM_DEFINE_INT32(SENS_EN_TRANGER, 0);
|
|
|
|
/**
|
|
* Lightware SF1xx/SF20/LW20 laser rangefinder (i2c)
|
|
*
|
|
* @reboot_required true
|
|
* @min 0
|
|
* @max 5
|
|
* @group Sensors
|
|
* @value 0 Disabled
|
|
* @value 1 SF10/a
|
|
* @value 2 SF10/b
|
|
* @value 3 SF10/c
|
|
* @value 4 SF11/c
|
|
* @value 5 SF/LW20
|
|
*/
|
|
PARAM_DEFINE_INT32(SENS_EN_SF1XX, 0);
|
|
|
|
/**
|
|
* Thermal control of sensor temperature
|
|
*
|
|
* @value -1 Thermal control unavailable
|
|
* @value 0 Thermal control off
|
|
* @group Sensors
|
|
*/
|
|
PARAM_DEFINE_INT32(SENS_EN_THERMAL, -1);
|
|
|
|
/**
|
|
* Driver level cut frequency for gyro
|
|
*
|
|
* The cut frequency for the 2nd order butterworth filter on the gyro driver. This features
|
|
* is currently supported by the mpu6000 and mpu9250. This only affects the signal sent to the
|
|
* controllers, not the estimators. 0 disables the filter.
|
|
*
|
|
* @min 5
|
|
* @max 1000
|
|
* @unit Hz
|
|
* @reboot_required true
|
|
* @group Sensors
|
|
*/
|
|
PARAM_DEFINE_FLOAT(IMU_GYRO_CUTOFF, 30.0f);
|
|
|
|
/**
|
|
* Driver level cut frequency for accel
|
|
*
|
|
* The cut frequency for the 2nd order butterworth filter on the accel driver. This features
|
|
* is currently supported by the mpu6000 and mpu9250. This only affects the signal sent to the
|
|
* controllers, not the estimators. 0 disables the filter.
|
|
*
|
|
* @min 5
|
|
* @max 1000
|
|
* @unit Hz
|
|
* @reboot_required true
|
|
* @group Sensors
|
|
*/
|
|
PARAM_DEFINE_FLOAT(IMU_ACCEL_CUTOFF, 30.0f);
|