SITL: permit double-precision maths in SITL even on embedded hardware

This commit is contained in:
Peter Barker 2021-10-16 17:10:20 +11:00 committed by Peter Barker
parent 4c8fc3bcaf
commit b360521d0b
8 changed files with 17 additions and 4 deletions

View File

@ -16,13 +16,14 @@
parent class for aircraft simulators parent class for aircraft simulators
*/ */
#define ALLOW_DOUBLE_MATH_FUNCTIONS
#include "SIM_Aircraft.h" #include "SIM_Aircraft.h"
#include <stdio.h> #include <stdio.h>
#include <sys/time.h> #include <sys/time.h>
#include <unistd.h> #include <unistd.h>
#if defined(__CYGWIN__) || defined(__CYGWIN64__) #if defined(__CYGWIN__) || defined(__CYGWIN64__)
#include <windows.h> #include <windows.h>
#include <time.h> #include <time.h>

View File

@ -16,6 +16,8 @@
Balance Bot simulator class Balance Bot simulator class
*/ */
#define ALLOW_DOUBLE_MATH_FUNCTIONS
#include "SIM_BalanceBot.h" #include "SIM_BalanceBot.h"
#include <stdio.h> #include <stdio.h>

View File

@ -16,6 +16,8 @@
Blimp simulator class Blimp simulator class
*/ */
#define ALLOW_DOUBLE_MATH_FUNCTIONS
#include "SIM_Blimp.h" #include "SIM_Blimp.h"
#include <stdio.h> #include <stdio.h>

View File

@ -12,6 +12,8 @@
#include <time.h> #include <time.h>
#define ALLOW_DOUBLE_MATH_FUNCTIONS
#include <AP_BoardConfig/AP_BoardConfig.h> #include <AP_BoardConfig/AP_BoardConfig.h>
#include <AP_HAL/AP_HAL.h> #include <AP_HAL/AP_HAL.h>
#include <SITL/SITL.h> #include <SITL/SITL.h>

View File

@ -1,3 +1,5 @@
#define ALLOW_DOUBLE_MATH_FUNCTIONS
#include "SIM_MS5611.h" #include "SIM_MS5611.h"
#include <SITL/SITL.h> #include <SITL/SITL.h>

View File

@ -17,6 +17,8 @@
just enough to be able to debug control logic for new frame types just enough to be able to debug control logic for new frame types
*/ */
#define ALLOW_DOUBLE_MATH_FUNCTIONS
#include "SIM_Plane.h" #include "SIM_Plane.h"
#include <stdio.h> #include <stdio.h>

View File

@ -67,12 +67,12 @@ protected:
float thruster_mount_radius = 0.25; // distance in meters from thrusters to center of mass. Used to calculate torque. float thruster_mount_radius = 0.25; // distance in meters from thrusters to center of mass. Used to calculate torque.
float equivalent_sphere_radius = 0.2; float equivalent_sphere_radius = 0.2;
// volume = 4.pi.r³/3 // volume = 4.pi.r³/3
float volume = 4 * M_PI * pow(equivalent_sphere_radius, 3) / 3; float volume = 4 * M_PI * powf(equivalent_sphere_radius, 3) / 3;
float density = 500; float density = 500;
float mass = volume * density; // 16.75 kg float mass = volume * density; // 16.75 kg
// Moment of Inertia (I)(kg.m²) approximated with a sphere with a 25 cm radius (r) and same density as water // Moment of Inertia (I)(kg.m²) approximated with a sphere with a 25 cm radius (r) and same density as water
// I = 2.m.r²/5 // I = 2.m.r²/5
float moment_of_inertia = 2 * (mass * pow(equivalent_sphere_radius, 2) / 5); float moment_of_inertia = 2 * (mass * powf(equivalent_sphere_radius, 2) / 5);
// Frame drag coefficient // Frame drag coefficient
const Vector3f linear_drag_coefficient = Vector3f(1.4, 1.8, 2.0); const Vector3f linear_drag_coefficient = Vector3f(1.4, 1.8, 2.0);
@ -83,7 +83,7 @@ protected:
// $ V = 4 * pi * r^3 / 3 $ // $ V = 4 * pi * r^3 / 3 $
// $ r ^2 = (V * 3 / 4) ^ (2/3) $ // $ r ^2 = (V * 3 / 4) ^ (2/3) $
// A = area (m^3), r = sphere radius (m) // A = area (m^3), r = sphere radius (m)
float equivalent_sphere_area = M_PI_4 * pow(volume * 3.0f / 4.0f, 2.0f / 3.0f); float equivalent_sphere_area = M_PI_4 * powf(volume * 3.0f / 4.0f, 2.0f / 3.0f);
} frame_property; } frame_property;

View File

@ -17,6 +17,8 @@
SITL.cpp - software in the loop state SITL.cpp - software in the loop state
*/ */
#define ALLOW_DOUBLE_MATH_FUNCTIONS
#include "SITL.h" #include "SITL.h"
#if AP_SIM_ENABLED #if AP_SIM_ENABLED