Skip to content

Commit

Permalink
SIH-AGP: add sensor failure simulation
Browse files Browse the repository at this point in the history
  • Loading branch information
bresch committed Dec 13, 2024
1 parent f27a8a6 commit 46943d1
Show file tree
Hide file tree
Showing 3 changed files with 48 additions and 6 deletions.
28 changes: 23 additions & 5 deletions src/modules/simulation/sensor_agp_sim/SensorAgpSim.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -107,9 +107,27 @@ void SensorAgpSim::Run()
vehicle_global_position_s gpos{};
_vehicle_global_position_sub.copy(&gpos);

double latitude = gpos.lat + math::degrees((double)generate_wgn() * 0.2 / CONSTANTS_RADIUS_OF_EARTH);
double longitude = gpos.lon + math::degrees((double)generate_wgn() * 0.2 / CONSTANTS_RADIUS_OF_EARTH);
double altitude = (double)(gpos.alt + (generate_wgn() * 0.5f));
const uint64_t now = gpos.timestamp;
const float dt = (now - _time_last_update) * 1e-6f;
_time_last_update = now;

if (!(_param_sim_agp_fail.get() & static_cast<int32_t>(FailureMode::Stuck))) {
_measured_lla = LatLonAlt(gpos.lat, gpos.lon, gpos.alt_ellipsoid);
}

if (_param_sim_agp_fail.get() & static_cast<int32_t>(FailureMode::Drift)) {
_position_bias += Vector3f(1.5f, -5.f, 0.f) * dt;
_measured_lla += _position_bias;

} else {
_position_bias.zero();
}

const double latitude = _measured_lla.latitude_deg() + math::degrees((double)generate_wgn() * 2.0 /
CONSTANTS_RADIUS_OF_EARTH);
const double longitude = _measured_lla.longitude_deg() + math::degrees((double)generate_wgn() * 2.0 /
CONSTANTS_RADIUS_OF_EARTH);
const double altitude = (double)(_measured_lla.altitude() + (generate_wgn() * 0.5f));

vehicle_global_position_s sample{};

Expand All @@ -120,8 +138,8 @@ void SensorAgpSim::Run()
sample.lat_lon_valid = true;
sample.alt_ellipsoid = altitude;
sample.alt_valid = true;
sample.eph = 0.9f;
sample.epv = 1.78f;
sample.eph = 20.f;
sample.epv = 5.f;

sample.timestamp = hrt_absolute_time();
_aux_global_position_pub.publish(sample);
Expand Down
13 changes: 12 additions & 1 deletion src/modules/simulation/sensor_agp_sim/SensorAgpSim.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@

#pragma once

#include <lib/lat_lon_alt/lat_lon_alt.hpp>
#include <lib/perf/perf_counter.h>
#include <px4_platform_common/defines.h>
#include <px4_platform_common/module.h>
Expand Down Expand Up @@ -64,11 +65,21 @@ class SensorAgpSim : public ModuleBase<SensorAgpSim>, public ModuleParams, publi
bool init();

private:
enum class FailureMode : int32_t {
Stuck = (1 << 0),
Drift = (1 << 1)
};

void Run() override;

// generate white Gaussian noise sample with std=1
static float generate_wgn();

LatLonAlt _measured_lla{};
matrix::Vector3f _position_bias{};

uint64_t _time_last_update{};

uORB::SubscriptionInterval _parameter_update_sub{ORB_ID(parameter_update), 1_s};
uORB::Subscription _vehicle_global_position_sub{ORB_ID(vehicle_global_position_groundtruth)};

Expand All @@ -77,6 +88,6 @@ class SensorAgpSim : public ModuleBase<SensorAgpSim>, public ModuleParams, publi
perf_counter_t _loop_perf{perf_alloc(PC_ELAPSED, MODULE_NAME": cycle")};

DEFINE_PARAMETERS(
(ParamInt<px4::params::SIM_GPS_USED>) _sim_gps_used
(ParamInt<px4::params::SIM_AGP_FAIL>) _param_sim_agp_fail
)
};
13 changes: 13 additions & 0 deletions src/modules/simulation/sensor_agp_sim/parameters.c
Original file line number Diff line number Diff line change
Expand Up @@ -41,3 +41,16 @@
* @value 1 Enabled
*/
PARAM_DEFINE_INT32(SENS_EN_AGPSIM, 0);

/**
* AGP failure mode
* Stuck: freeze the measurement to the current location
* Drift: add a linearly growing bias to the sensor data
*
* @group Simulator
* @min 0
* @max 3
* @bit 0 Stuck
* @bit 1 Drift
*/
PARAM_DEFINE_INT32(SIM_AGP_FAIL, 0);

0 comments on commit 46943d1

Please sign in to comment.