mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-23 09:08:30 -04:00
11b599bcd0
For the general case, pragma once is better replacement for of include guards. One line instead of three, less scopes to close in the end of the file, no chance to having the outdated names in the define symbol.
120 lines
4.1 KiB
C++
120 lines
4.1 KiB
C++
/// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-
|
|
|
|
#pragma once
|
|
|
|
#include <DataFlash/DataFlash.h>
|
|
#include <GCS_MAVLink/GCS_MAVLink.h>
|
|
|
|
namespace SITL {
|
|
|
|
struct PACKED sitl_fdm {
|
|
// this is the packet sent by the simulator
|
|
// to the APM executable to update the simulator state
|
|
// All values are little-endian
|
|
uint64_t timestamp_us;
|
|
double latitude, longitude; // degrees
|
|
double altitude; // MSL
|
|
double heading; // degrees
|
|
double speedN, speedE, speedD; // m/s
|
|
double xAccel, yAccel, zAccel; // m/s/s in body frame
|
|
double rollRate, pitchRate, yawRate; // degrees/s/s in body frame
|
|
double rollDeg, pitchDeg, yawDeg; // euler angles, degrees
|
|
double airspeed; // m/s
|
|
uint32_t magic; // 0x4c56414f
|
|
};
|
|
|
|
// number of rc output channels
|
|
#define SITL_NUM_CHANNELS 14
|
|
|
|
|
|
class SITL {
|
|
public:
|
|
|
|
SITL() {
|
|
// set a default compass offset
|
|
mag_ofs.set(Vector3f(5, 13, -18));
|
|
AP_Param::setup_object_defaults(this, var_info);
|
|
}
|
|
|
|
enum GPSType {
|
|
GPS_TYPE_NONE = 0,
|
|
GPS_TYPE_UBLOX = 1,
|
|
GPS_TYPE_MTK = 2,
|
|
GPS_TYPE_MTK16 = 3,
|
|
GPS_TYPE_MTK19 = 4,
|
|
GPS_TYPE_NMEA = 5,
|
|
GPS_TYPE_SBP = 6,
|
|
GPS_TYPE_FILE = 7
|
|
};
|
|
|
|
struct sitl_fdm state;
|
|
|
|
static const struct AP_Param::GroupInfo var_info[];
|
|
|
|
// noise levels for simulated sensors
|
|
AP_Float baro_noise; // in metres
|
|
AP_Float baro_drift; // in metres per second
|
|
AP_Float baro_glitch; // glitch in meters
|
|
AP_Float gyro_noise; // in degrees/second
|
|
AP_Float accel_noise; // in m/s/s
|
|
AP_Float accel2_noise; // in m/s/s
|
|
AP_Vector3f accel_bias; // in m/s/s
|
|
AP_Float aspd_noise; // in m/s
|
|
AP_Float aspd_fail; // pitot tube failure
|
|
|
|
AP_Float mag_noise; // in mag units (earth field is 818)
|
|
AP_Float mag_error; // in degrees
|
|
AP_Vector3f mag_mot; // in mag units per amp
|
|
AP_Vector3f mag_ofs; // in mag units
|
|
AP_Float servo_rate; // servo speed in degrees/second
|
|
|
|
AP_Float sonar_glitch;// probablility between 0-1 that any given sonar sample will read as max distance
|
|
AP_Float sonar_noise; // in metres
|
|
AP_Float sonar_scale; // meters per volt
|
|
|
|
AP_Float drift_speed; // degrees/second/minute
|
|
AP_Float drift_time; // period in minutes
|
|
AP_Float engine_mul; // engine multiplier
|
|
AP_Int8 gps_disable; // disable simulated GPS
|
|
AP_Int8 gps2_enable; // enable 2nd simulated GPS
|
|
AP_Int8 gps_delay; // delay in samples
|
|
AP_Int8 gps_type; // see enum GPSType
|
|
AP_Float gps_byteloss;// byte loss as a percent
|
|
AP_Int8 gps_numsats; // number of visible satellites
|
|
AP_Vector3f gps_glitch; // glitch offsets in lat, lon and altitude
|
|
AP_Int8 gps_hertz; // GPS update rate in Hz
|
|
AP_Float batt_voltage; // battery voltage base
|
|
AP_Float accel_fail; // accelerometer failure value
|
|
AP_Int8 rc_fail; // fail RC input
|
|
AP_Int8 baro_disable; // disable simulated barometer
|
|
AP_Int8 float_exception; // enable floating point exception checks
|
|
AP_Int8 flow_enable; // enable simulated optflow
|
|
AP_Int16 flow_rate; // optflow data rate (Hz)
|
|
AP_Int8 flow_delay; // optflow data delay
|
|
AP_Int8 terrain_enable; // enable using terrain for height
|
|
|
|
// wind control
|
|
AP_Float wind_speed;
|
|
AP_Float wind_direction;
|
|
AP_Float wind_turbulance;
|
|
AP_Float gps_drift_alt;
|
|
|
|
AP_Int16 baro_delay; // barometer data delay in ms
|
|
AP_Int16 mag_delay; // magnetometer data delay in ms
|
|
AP_Int16 wind_delay; // windspeed data delay in ms
|
|
|
|
void simstate_send(mavlink_channel_t chan);
|
|
|
|
void Log_Write_SIMSTATE(DataFlash_Class &dataflash);
|
|
|
|
// convert a set of roll rates from earth frame to body frame
|
|
static void convert_body_frame(double rollDeg, double pitchDeg,
|
|
double rollRate, double pitchRate, double yawRate,
|
|
double *p, double *q, double *r);
|
|
|
|
// convert a set of roll rates from body frame to earth frame
|
|
static Vector3f convert_earth_frame(const Matrix3f &dcm, const Vector3f &gyro);
|
|
};
|
|
|
|
} // namespace SITL
|