获取两个标题之间的差异
我有这个方法来计算 2 个 0-360 罗盘方向之间的差异。
尽管这可以计算出我的绝对偏差(例如,始终为正输出)有多远,但我无法弄清楚需要做什么才能将符号引入输出中。
理想情况下,如果从初始航向到最终航向的最短距离是顺时针旋转,如果航向之间的最短距离涉及逆时针旋转,我希望错误具有正号-明智的是,我希望 error
有一个负号。
所需输入/输出的一些示例
initial
-- final
-- error
0 ...... ....... 30 .. 30
30 .................. 0 .................. . -30
360 ................. 1 .. 1
1 ................. ....... 360 ....... -1
代码:
/// <summary>
/// Calculate the error from a given initial heading to a final heading
/// </summary>
/// <param name="inital"></param>
/// <param name="final"></param>
/// <returns></returns>
private double GetHeadingError(double initial, double final)
{
double directionA = final - initial;
double directionB = 360 - (final + initial);
double error = 0;
if (Math.Abs(directionA) < Math.Abs(directionB))
{
error = directionA;
}
else
{
error = directionB;
}
return error;
}
I have this method for figuring out the difference between 2 0-360 compass headings.
Although this works for figuring out how far absolutely (as in, always positive output) off I am, I am having trouble figuring out what needs to be done to introduce the sign into the output.
Ideally, if the shortest distance from the initial heading to the final heading is by going around clockwise, I'd like the error
to have a positive sign, if the shortest distance between the headings involves going around counterclock-wise, I'd like the error
to have a negative sign.
A few examples of desired inputs/outputs
initial
-- final
-- error
0 .................... 30 .......... 30
30 .................... 0 .......... -30
360 .................... 1 .......... 1
1 .................... 360 .......... -1
Code:
/// <summary>
/// Calculate the error from a given initial heading to a final heading
/// </summary>
/// <param name="inital"></param>
/// <param name="final"></param>
/// <returns></returns>
private double GetHeadingError(double initial, double final)
{
double directionA = final - initial;
double directionB = 360 - (final + initial);
double error = 0;
if (Math.Abs(directionA) < Math.Abs(directionB))
{
error = directionA;
}
else
{
error = directionB;
}
return error;
}
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(5)
如果我正确理解了这个问题,我认为下面的代码应该有效:
基本上我将 360 度视为 0,我认为这是可以的。此代码将产生与上表中列出的相同的结果。代码不进行边界检查,它期望值在 0 到 360 之间。
If I understand the question correctly, I think the following code should work:
Basically I'm treating 360 degrees the same as 0, which I believe is ok. This code will produce the same results as listed in the table above. Code does not do bounds checking, it is expecting values between 0 and 360.
我认为您的期望结果表不正确。这是我笨拙的方法:
I think your table of desired results is incorrect. Here's my klunky way:
编辑:添加了差异恰好为 180 度时的检查。以前,根据最终值是大于还是小于初始值,返回 180 或 -180。我对其进行了修改,使其在两种情况下都返回正 180。
所以这是我的尝试......
Edit: added check for when the difference is exactly 180 degrees. previously this was returning either 180 or -180 depending on whether final was greater or lower than initial. I've modified it so that it returns positive 180 in both cases.
So here's my attempt...
这是一个简单的解决方案,尽管在 Dart 中命名有点不同。基于此航空电子设备答案。
编辑:这里有一个更简洁的答案,但我自己还没有尝试过:
Here's a straightforward solution, albeit named a bit differently and in Dart. Based on this avionics answer.
Edit: There's an even more concise answer here, but I haven't tried it myself: