Ardupilot2/libraries/AP_InertialSensor/AP_InertialSensor_SITL.h
Andrew Tridgell 01b0586958 AP_InertialSensor: use motor_mask from SITL for which outputs are motors
generate noise based on motor_mask
2022-10-24 22:23:43 +09:00

53 lines
1.2 KiB
C++

#pragma once
#include "AP_InertialSensor.h"
#if AP_SIM_INS_ENABLED
#include "AP_InertialSensor_Backend.h"
// simulated sensor rates in Hz. This matches a pixhawk1
const uint16_t INS_SITL_SENSOR_A[] = { 1000, 1000 };
const uint16_t INS_SITL_SENSOR_B[] = { 760, 800 };
#include <SITL/SITL.h>
class AP_InertialSensor_SITL : public AP_InertialSensor_Backend
{
public:
AP_InertialSensor_SITL(AP_InertialSensor &imu, const uint16_t sample_rates[]);
/* update accel and gyro state */
bool update() override;
void start() override;
// detect the sensor
static AP_InertialSensor_Backend *detect(AP_InertialSensor &imu, const uint16_t sample_rates[]);
private:
bool init_sensor(void);
void timer_update();
float gyro_drift(void);
void generate_accel();
void generate_gyro();
float get_temperature(void);
SITL::SIM *sitl;
const uint16_t gyro_sample_hz;
const uint16_t accel_sample_hz;
uint8_t gyro_instance;
uint8_t accel_instance;
uint64_t next_gyro_sample;
uint64_t next_accel_sample;
float gyro_time;
float accel_time;
float gyro_motor_phase[32];
float accel_motor_phase[32];
uint32_t temp_start_ms;
static uint8_t bus_id;
};
#endif // AP_SIM_INS_ENABLED