How to access beacons and airways information?

Air navigation and communication with air traffic control (ATC) is mostly based on the use of navigational beacons and airways. In recent years, airways tend to be replaced by Free Route Areas (FRA), but airways are still bound to exist in some parts of the world, Oceanic areas, mountainous areas, and free route navigation remains based on navigational beacons.

Navigational beacons (called navaids in the library) are of different types: historically the first ones were attached to VOR equipment, but we can mostly consider they are a name attached to geographic coordinates.

Basic data of questionable accuracy is provided with the library:

from traffic.data import airways, navaids

However, if other sources of data are configured (e.g. EUROCONTROL data files), the library will look into all sources (with the basic data source set as lowest priority)

class traffic.data.basic.navaid.Navaids(data=None)

VOR, DME and NDB are short-range radio navigation systems for aircraft. They help aircraft with a receiving unit to determine their position and stay on course.

The first airways were designed after the locations of these beacons. Recent progress in GNSS systems helped define more positions by their latitudes and longitudes, referred to as FIX.

A (deprecated) database of world navigational beacons is available as:

>>> from traffic.data import navaids

Any navigational beacon can be accessed by the bracket notation:

>>> navaids['NARAK']
Navaid('NARAK', type='FIX', latitude=44.29527778, longitude=1.74888889)
get(name)

Search for a navaid from all alternative data sources.

Return type:

Navaid

>>> from traffic.data import navaids
>>> navaids.get("ZUE")
Navaid('ZUE', type='NDB', latitude=30.9, longitude=20.068, altitude=0.0, description='ZUEITINA NDB', frequency='369.0kHz')
>>> navaids.extent("Switzerland").get("ZUE")  
Navaid('ZUE', type='VOR', latitude=47.592, longitude=8.817, altitude=1730.0, description='ZURICH EAST VOR-DME', frequency='110.05MHz')
search(name)

Selects the subset of airways matching name in the name or description field. :rtype: Navaids

Warning

The same name may match several navigational beacons in the world. Use the extent() method to limit the search to an area of interest.

>>> navaids.search("ZUE")  
  name   type   latitude   longitude   altitude   frequency   description
 ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
  ZUE    NDB    30.9       20.07       0          369         ZUEITINA NDB
  ZUE    VOR    47.59      8.818       1730       110         ZURICH EAST VOR-DME
  ZUE    DME    47.59      8.818       1730       110         ZURICH EAST VOR-DME
>>> navaids.extent("Switzerland").search("ZUE")  
  name   type   latitude   longitude   altitude   frequency   description
 ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
  ZUE    VOR    47.59      8.818       1730       110         ZURICH EAST VOR-DME
  ZUE    DME    47.59      8.818       1730       110         ZURICH EAST VOR-DME
class traffic.data.basic.airways.Airways(data=None)

An ATS route is a specified route designed for channelling the flow of traffic as necessary for the provision of air traffic services.

The term “ATS route” is used to mean variously, airway, advisory route, controlled or uncontrolled route, arrival or departure route, etc.

An ATS route is defined by route specifications which include an ATS route designator, the track to or from significant points (waypoints), distance between significant points, reporting requirements and, as determined by the appropriate ATS authority, the lowest safe altitude. (ICAO Annex 11 - Air Traffic Services)

A (deprecated) database of world ATS routes is available as:

>>> from traffic.data import airways

Any ATS route can be accessed by the bracket notation:

>>> airways['Z50']
Route('Z50', navaids=['EGOBA', 'SOT', 'BULTI', 'AYE', 'AVMON', ...])
>>> airways.extent((-0.33, 4.85, 42.34, 45.05))["UN869"]
Route('UN869', navaids=['XOMBO', 'TIVLI', 'AGN', 'NARAK', 'NASEP', ...])

Note

The following snippet plots the (in)famous Silk Road Airway (L888) over the Himalaya mountains, which requires special qualifications.

import matplotlib.pyplot as plt

from traffic.data import airways
from cartes.crs import Orthographic

with plt.style.context("traffic"):

    fig, ax = plt.subplots(
        figsize=(7, 7),
        subplot_kw=dict(projection=Orthographic(95, 30)),
    )

    ax.stock_img()
    ax.coastlines()

    airways["L888"].plot(
        ax, linewidth=2, linestyle="solid", color="crimson"
        )

    for navaid in airways["L888"].navaids:
        navaid.plot(
            ax, s=20, marker=".", color="crimson",
            text_kw=dict(fontsize=8)
        )
../_images/navigation_0_1.png
get(name)

Search for a route from all alternative data sources.

Return type:

Route

search(name)

Selects the subset of airways matching name in the route name or in the passed navigational beacon.

Return type:

Airways

>>> airways.extent('Switzerland').search("Z50")  
  route   id   navaid   latitude   longitude
 ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
  Z50     7    GERSA    47.04      8.532
  Z50     8    KELIP    46.96      8.762
  Z50     9    SOPER    46.89      8.944
  Z50     10   PELAD    46.6       9.726
  Z50     11   RESIA    46.48      10.04
>>> airways.search("NARAK")  
  route   id   navaid   latitude   longitude
 ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
  N869    88   NARAK    44.3       1.749
  UN859   15   NARAK    44.3       1.749
  UN869   23   NARAK    44.3       1.749
  UT122   15   NARAK    44.3       1.749
  UY155   2    NARAK    44.3       1.749
  UZ365   3    NARAK    44.3       1.749

Tip

The same L888 route can also be plotted inside a Leaflet widget.

from ipyleaflet import Map, basemaps

m = Map(center=(32.3, 99), zoom=4, basemap=basemaps.Stadia.StamenTerrain)
m.add(airways["L888"])

m