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;
}
I think your table of desired results is incorrect. Here's my klunky way:
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:
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...
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.