Fixed some stuff in runway number to spoken string function, and added Alexander's function to get the minimum angular difference between two headings from approach to ATCutils
This commit is contained in:
parent
8ce9c2c529
commit
49434e3085
2 changed files with 30 additions and 2 deletions
|
@ -80,7 +80,7 @@ string ConvertRwyNumToSpokenString(int n) {
|
||||||
return(str);
|
return(str);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Assumes we get a two-digit string optionally appended with R or L
|
// Assumes we get a two-digit string optionally appended with L, R or C
|
||||||
// eg 01 07L 29R 36
|
// eg 01 07L 29R 36
|
||||||
// Anything else is not guaranteed to be handled correctly!
|
// Anything else is not guaranteed to be handled correctly!
|
||||||
string ConvertRwyNumToSpokenString(string s) {
|
string ConvertRwyNumToSpokenString(string s) {
|
||||||
|
@ -88,7 +88,16 @@ string ConvertRwyNumToSpokenString(string s) {
|
||||||
return(ConvertRwyNumToSpokenString(atoi(s.c_str())));
|
return(ConvertRwyNumToSpokenString(atoi(s.c_str())));
|
||||||
} else {
|
} else {
|
||||||
string r = ConvertRwyNumToSpokenString(atoi(s.substr(0,2).c_str()));
|
string r = ConvertRwyNumToSpokenString(atoi(s.substr(0,2).c_str()));
|
||||||
return(r += (s.substr(2,1) == "L" ? " left" : " right")); // Warning - not much error checking there!
|
if(s.substr(2,1) == "L") {
|
||||||
|
r += " left";
|
||||||
|
} else if(s.substr(2,1) == "R") {
|
||||||
|
r += " right";
|
||||||
|
} else if(s.substr(2,1) == "C") {
|
||||||
|
r += " center";
|
||||||
|
} else {
|
||||||
|
SG_LOG(SG_ATC, SG_WARN, "WARNING: Unknown suffix " << s.substr(2,1) << " from runway ID " << s << " in ConvertRwyNumToSpokenString(...)");
|
||||||
|
}
|
||||||
|
return(r);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -128,6 +137,8 @@ string GetPhoneticIdent(int i) {
|
||||||
return("Error");
|
return("Error");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//================================================================================================================
|
||||||
|
|
||||||
// Given two positions (lat & lon in degrees), get the HORIZONTAL separation (in meters)
|
// Given two positions (lat & lon in degrees), get the HORIZONTAL separation (in meters)
|
||||||
double dclGetHorizontalSeparation(Point3D pos1, Point3D pos2) {
|
double dclGetHorizontalSeparation(Point3D pos1, Point3D pos2) {
|
||||||
double x; //East-West separation
|
double x; //East-West separation
|
||||||
|
@ -238,6 +249,19 @@ void dclBoundHeading(double &hdg) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// smallest difference between two angles in degrees
|
||||||
|
// difference is negative if a1 > a2 and positive if a2 > a1
|
||||||
|
double GetAngleDiff_deg( const double &a1, const double &a2) {
|
||||||
|
|
||||||
|
double a3 = a2 - a1;
|
||||||
|
while (a3 < 180.0) a3 += 360.0;
|
||||||
|
while (a3 > 180.0) a3 -= 360.0;
|
||||||
|
|
||||||
|
return a3;
|
||||||
|
}
|
||||||
|
|
||||||
|
//================================================================================================================
|
||||||
|
|
||||||
// Airport stuff. The next two functions are straight copies of their fg.... equivalents
|
// Airport stuff. The next two functions are straight copies of their fg.... equivalents
|
||||||
// in fg_init.cxx, and are just here temporarily until some rationalisation occurs.
|
// in fg_init.cxx, and are just here temporarily until some rationalisation occurs.
|
||||||
// find basic airport location info from airport database
|
// find basic airport location info from airport database
|
||||||
|
|
|
@ -77,6 +77,10 @@ double GetHeadingFromTo(Point3D A, Point3D B);
|
||||||
// Given a heading (in degrees), bound it from 0 -> 360
|
// Given a heading (in degrees), bound it from 0 -> 360
|
||||||
void dclBoundHeading(double &hdg);
|
void dclBoundHeading(double &hdg);
|
||||||
|
|
||||||
|
// smallest difference between two angles in degrees
|
||||||
|
// difference is negative if a1 > a2 and positive if a2 > a1
|
||||||
|
double GetAngleDiff_deg( const double &a1, const double &a2);
|
||||||
|
|
||||||
|
|
||||||
/*******************************
|
/*******************************
|
||||||
*
|
*
|
||||||
|
|
Loading…
Add table
Reference in a new issue