From 7115d781e80fda9388bf25ca7b25b79bdf8e9a6d Mon Sep 17 00:00:00 2001 From: Bertrand Coconnier Date: Tue, 28 Dec 2021 22:08:44 +0100 Subject: [PATCH] Bug fix for issue #553 Improper use of the local frame rotation rate leads to the divergence vehicle rotation rates. --- src/initialization/FGInitialCondition.cpp | 29 ++++++++--------------- 1 file changed, 10 insertions(+), 19 deletions(-) diff --git a/src/initialization/FGInitialCondition.cpp b/src/initialization/FGInitialCondition.cpp index ef95011931..14d056657f 100644 --- a/src/initialization/FGInitialCondition.cpp +++ b/src/initialization/FGInitialCondition.cpp @@ -1187,15 +1187,7 @@ bool FGInitialCondition::Load_v1(Element* document) if (document->FindElement("trim")) SetTrimRequest(document->FindElementValue("trim")); - // Refer to Stevens and Lewis, 1.5-14a, pg. 49. - // This is the rotation rate of the "Local" frame, expressed in the local frame. - const FGMatrix33& Tl2b = orientation.GetT(); - double radInv = 1.0 / position.GetRadius(); - FGColumnVector3 vOmegaLocal = {radInv*vUVW_NED(eEast), - -radInv*vUVW_NED(eNorth), - -radInv*vUVW_NED(eEast)*tan(position.GetLatitude())}; - - vPQR_body = Tl2b * vOmegaLocal; + vPQR_body.InitMatrix(); return result; } @@ -1408,19 +1400,12 @@ bool FGInitialCondition::Load_v2(Element* document) // - Body Element* attrate_el = document->FindElement("attitude_rate"); - const FGMatrix33& Tl2b = orientation.GetT(); - - // Refer to Stevens and Lewis, 1.5-14a, pg. 49. - // This is the rotation rate of the "Local" frame, expressed in the local frame. - double radInv = 1.0 / position.GetRadius(); - FGColumnVector3 vOmegaLocal = { radInv*vUVW_NED(eEast), - -radInv*vUVW_NED(eNorth), - -radInv*vUVW_NED(eEast)*tan(position.GetLatitude())}; if (attrate_el) { string frame = attrate_el->GetAttributeValue("frame"); frame = to_lower(frame); + const FGMatrix33& Tl2b = orientation.GetT(); FGColumnVector3 vAttRate = attrate_el->FindElementTripletConvertTo("RAD/SEC"); if (frame == "eci") { @@ -1429,6 +1414,12 @@ bool FGInitialCondition::Load_v2(Element* document) } else if (frame == "ecef") { vPQR_body = Tl2b * position.GetTec2l() * vAttRate; } else if (frame == "local") { + // Refer to Stevens and Lewis, 1.5-14a, pg. 49. + // This is the rotation rate of the "Local" frame, expressed in the local frame. + double radInv = 1.0 / position.GetRadius(); + FGColumnVector3 vOmegaLocal = {radInv*vUVW_NED(eEast), + -radInv*vUVW_NED(eNorth), + -radInv*vUVW_NED(eEast)*tan(position.GetLatitude())}; vPQR_body = Tl2b * (vAttRate + vOmegaLocal); } else if (frame == "body") { vPQR_body = vAttRate; @@ -1439,11 +1430,11 @@ bool FGInitialCondition::Load_v2(Element* document) result = false; } else if (frame.empty()) { - vPQR_body = Tl2b * vOmegaLocal; + vPQR_body.InitMatrix(); } } else { // Body frame attitude rate assumed 0 relative to local. - vPQR_body = Tl2b * vOmegaLocal; + vPQR_body.InitMatrix(); } return result;