Route chord

Download this notebook from GitHub (right-click to download).


Most examples work across multiple plotting backends. This example is also available for:

In [1]:
import holoviews as hv

from holoviews import dim
from bokeh.sampledata.airport_routes import routes, airports

hv.extension('matplotlib')
hv.output(fig='svg', size=300)

Declare data

In [2]:
# Count the routes between Airports
route_counts = routes.groupby(['SourceID', 'DestinationID']).Stops.count().reset_index()
nodes = hv.Dataset(airports, 'AirportID', 'City')
chord = hv.Chord((route_counts, nodes), ['SourceID', 'DestinationID'], ['Stops'])

# Select the 20 busiest airports
busiest = list(routes.groupby('SourceID').count().sort_values('Stops').iloc[-20:].index.values)
busiest_airports = chord.select(AirportID=busiest, selection_mode='nodes')

Plot

In [3]:
busiest_airports.opts(
    cmap='Category20', labels='City',
    edge_color=dim('SourceID').astype(str),
    node_color=dim('AirportID').astype(str))
Out[3]:

Download this notebook from GitHub (right-click to download).