2009-10-11 12:37:13 +01:00
|
|
|
// airways.hxx - storage of airways network, and routing between nodes
|
|
|
|
// Written by James Turner, started 2009.
|
|
|
|
//
|
|
|
|
// Copyright (C) 2009 Curtis L. Olson
|
|
|
|
//
|
|
|
|
// This program is free software; you can redistribute it and/or
|
|
|
|
// modify it under the terms of the GNU General Public License as
|
|
|
|
// published by the Free Software Foundation; either version 2 of the
|
|
|
|
// License, or (at your option) any later version.
|
|
|
|
//
|
|
|
|
// This program is distributed in the hope that it will be useful, but
|
|
|
|
// WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
// General Public License for more details.
|
|
|
|
//
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
|
|
// along with this program; if not, write to the Free Software
|
|
|
|
// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
|
|
|
|
#ifndef FG_AIRWAYS_HXX
|
|
|
|
#define FG_AIRWAYS_HXX
|
|
|
|
|
|
|
|
#include <map>
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
#include <Navaids/route.hxx>
|
2012-08-28 00:26:36 +01:00
|
|
|
#include <Navaids/positioned.hxx>
|
2009-10-11 12:37:13 +01:00
|
|
|
|
2012-08-28 00:26:36 +01:00
|
|
|
class SGPath;
|
2009-10-11 12:37:13 +01:00
|
|
|
typedef SGSharedPtr<FGPositioned> FGPositionedRef;
|
|
|
|
|
|
|
|
namespace flightgear {
|
|
|
|
|
|
|
|
// forward declare some helpers
|
|
|
|
struct SearchContext;
|
|
|
|
class AdjacentWaypoint;
|
|
|
|
class InAirwayFilter;
|
|
|
|
|
2012-11-12 22:30:28 +01:00
|
|
|
class Airway
|
2009-10-11 12:37:13 +01:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
virtual std::string ident() const
|
|
|
|
{ return _ident; }
|
|
|
|
|
2012-08-28 00:26:36 +01:00
|
|
|
static void load(const SGPath& path);
|
2009-10-11 12:37:13 +01:00
|
|
|
|
2013-11-16 09:41:33 +00:00
|
|
|
double topAltitudeFt() const
|
|
|
|
{ return _topAltitudeFt; }
|
|
|
|
|
|
|
|
double bottomAltitudeFt() const
|
|
|
|
{ return _bottomAltitudeFt; }
|
2014-11-13 21:03:24 +00:00
|
|
|
|
|
|
|
static Airway* findByIdent(const std::string& aIdent);
|
|
|
|
|
|
|
|
WayptRef findEnroute(const std::string& aIdent) const;
|
|
|
|
|
|
|
|
bool canVia(const WayptRef& from, const WayptRef& to) const;
|
|
|
|
|
|
|
|
WayptVec via(const WayptRef& from, const WayptRef& to) const;
|
|
|
|
|
|
|
|
bool containsNavaid(const FGPositionedRef& navaid) const;
|
|
|
|
|
2009-10-11 12:37:13 +01:00
|
|
|
/**
|
|
|
|
* Track a network of airways
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
class Network
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
friend class Airway;
|
|
|
|
friend class InAirwayFilter;
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Principal routing algorithm. Attempts to find the best route beween
|
|
|
|
* two points. If either point is part of the airway network (e.g, a SID
|
|
|
|
* or STAR transition), it will <em>not</em> be duplicated in the result
|
|
|
|
* path.
|
|
|
|
*
|
|
|
|
* Returns true if a route could be found, or false otherwise.
|
|
|
|
*/
|
|
|
|
bool route(WayptRef aFrom, WayptRef aTo, WayptVec& aPath);
|
2014-11-13 21:03:24 +00:00
|
|
|
|
|
|
|
|
2009-10-11 12:37:13 +01:00
|
|
|
private:
|
2012-08-28 00:26:36 +01:00
|
|
|
void addEdge(int aWay, const SGGeod& aStartPos,
|
2009-10-11 12:37:13 +01:00
|
|
|
const std::string& aStartIdent,
|
|
|
|
const SGGeod& aEndPos, const std::string& aEndIdent);
|
|
|
|
|
2012-08-28 00:26:36 +01:00
|
|
|
int findAirway(const std::string& aName, double aTop, double aBase);
|
2009-10-11 12:37:13 +01:00
|
|
|
|
2012-12-30 16:12:11 +00:00
|
|
|
bool cleanGeneratedPath(WayptRef aFrom, WayptRef aTo, WayptVec& aPath,
|
|
|
|
bool exactTo, bool exactFrom);
|
|
|
|
|
2009-10-11 12:37:13 +01:00
|
|
|
bool search2(FGPositionedRef aStart, FGPositionedRef aDest, WayptVec& aRoute);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test if a positioned item is part of this airway network or not.
|
|
|
|
*/
|
2012-08-28 00:26:36 +01:00
|
|
|
bool inNetwork(PositionedID pos) const;
|
2009-10-11 12:37:13 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Find the closest node on the network, to the specified waypoint
|
|
|
|
*
|
|
|
|
* May return NULL,false if no match could be found; the search is
|
|
|
|
* internally limited to avoid very poor performance; for example,
|
|
|
|
* in the middle of an ocean.
|
|
|
|
*
|
|
|
|
* The second return value indicates if the returned value is
|
|
|
|
* equal (true) or distinct (false) to the input waypoint.
|
|
|
|
* Equality here means being physically within a close tolerance,
|
|
|
|
* on the order of a hundred metres.
|
|
|
|
*/
|
|
|
|
std::pair<FGPositionedRef, bool> findClosestNode(WayptRef aRef);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Overloaded version working with a raw SGGeod
|
|
|
|
*/
|
2012-08-28 00:26:36 +01:00
|
|
|
|
2009-10-11 12:37:13 +01:00
|
|
|
std::pair<FGPositionedRef, bool> findClosestNode(const SGGeod& aGeod);
|
2012-08-28 00:26:36 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* cache which positioned items are in this network
|
|
|
|
*/
|
|
|
|
typedef std::map<PositionedID, bool> NetworkMembershipDict;
|
|
|
|
mutable NetworkMembershipDict _inNetworkCache;
|
|
|
|
|
|
|
|
int _networkID;
|
2009-10-11 12:37:13 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
static Network* highLevel();
|
|
|
|
static Network* lowLevel();
|
|
|
|
|
|
|
|
private:
|
|
|
|
Airway(const std::string& aIdent, double aTop, double aBottom);
|
|
|
|
|
2014-11-13 21:03:24 +00:00
|
|
|
WayptVec::const_iterator find(WayptRef wpt) const;
|
|
|
|
|
2009-10-11 12:37:13 +01:00
|
|
|
friend class Network;
|
|
|
|
|
|
|
|
std::string _ident;
|
|
|
|
double _topAltitudeFt;
|
|
|
|
double _bottomAltitudeFt;
|
|
|
|
|
|
|
|
WayptVec _elements;
|
|
|
|
};
|
|
|
|
|
|
|
|
} // of namespace flightgear
|
|
|
|
|
|
|
|
|
|
|
|
#endif //of FG_AIRWAYS_HXX
|