From 26927b87ca626a1857bad1597dc6b60b8085d396 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Bc=2E=20Martin=20Kubov=C4=8D=C3=ADk?= <74611856+markub3327@users.noreply.github.com> Date: Tue, 10 Jan 2023 14:58:47 +0100 Subject: [PATCH 1/2] Update Adafruit_AHRS_Madgwick.cpp --- src/Adafruit_AHRS_Madgwick.cpp | 20 +++++++++++--------- 1 file changed, 11 insertions(+), 9 deletions(-) diff --git a/src/Adafruit_AHRS_Madgwick.cpp b/src/Adafruit_AHRS_Madgwick.cpp index d8234ff..14aef48 100644 --- a/src/Adafruit_AHRS_Madgwick.cpp +++ b/src/Adafruit_AHRS_Madgwick.cpp @@ -280,15 +280,17 @@ void Adafruit_Madgwick::updateIMU(float gx, float gy, float gz, float ax, // Fast inverse square-root // See: http://en.wikipedia.org/wiki/Fast_inverse_square_root -float Adafruit_Madgwick::invSqrt(float x) { - float halfx = 0.5f * x; - float y = x; - long i = *(long *)&y; - i = 0x5f3759df - (i >> 1); - y = *(float *)&i; - y = y * (1.5f - (halfx * y * y)); - y = y * (1.5f - (halfx * y * y)); - return y; +float Adafruit_Madgwick::invSqrt(float x) +{ + float halfx = 0.5f * x; + union { + float f; + uint32_t i; + } conv = { .f = x }; + conv.i = 0x5f3759df - (conv.i >> 1); + conv.f *= 1.5f - (halfx * conv.f * conv.f); + conv.f *= 1.5f - (halfx * conv.f * conv.f); + return y; } //------------------------------------------------------------------------------------------- From 3599cbf2c25e974a1ae0cd9a80d453533aa3be93 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Bc=2E=20Martin=20Kubov=C4=8D=C3=ADk?= <74611856+markub3327@users.noreply.github.com> Date: Tue, 10 Jan 2023 14:59:16 +0100 Subject: [PATCH 2/2] Update Adafruit_AHRS_Mahony.cpp --- src/Adafruit_AHRS_Mahony.cpp | 20 +++++++++++--------- 1 file changed, 11 insertions(+), 9 deletions(-) diff --git a/src/Adafruit_AHRS_Mahony.cpp b/src/Adafruit_AHRS_Mahony.cpp index c01b510..c0e0693 100644 --- a/src/Adafruit_AHRS_Mahony.cpp +++ b/src/Adafruit_AHRS_Mahony.cpp @@ -259,15 +259,17 @@ void Adafruit_Mahony::updateIMU(float gx, float gy, float gz, float ax, // Fast inverse square-root // See: http://en.wikipedia.org/wiki/Fast_inverse_square_root -float Adafruit_Mahony::invSqrt(float x) { - float halfx = 0.5f * x; - float y = x; - long i = *(long *)&y; - i = 0x5f3759df - (i >> 1); - y = *(float *)&i; - y = y * (1.5f - (halfx * y * y)); - y = y * (1.5f - (halfx * y * y)); - return y; +float Adafruit_Mahony::invSqrt(float x) +{ + float halfx = 0.5f * x; + union { + float f; + uint32_t i; + } conv = { .f = x }; + conv.i = 0x5f3759df - (conv.i >> 1); + conv.f *= 1.5f - (halfx * conv.f * conv.f); + conv.f *= 1.5f - (halfx * conv.f * conv.f); + return y; } //-------------------------------------------------------------------------------------------