Computing US airport connections and route interpolations
To run this example you'll need:
- Optional: An active CARTO organization to visualize the results in a map
In this example we will showcase how easily we can compute all the paths that interconnect the main four US airports using the Analytics Toolbox.
WITH data AS(
SELECT 'SEA' AS abbrev, TO_GEOGRAPHY('POINT(-122.302289722924 47.4435819127259)') AS geog UNION
SELECT 'MIA', TO_GEOGRAPHY('POINT(-80.2789718277441 25.7949407212406)') UNION
SELECT 'LAX', TO_GEOGRAPHY('POINT(-118.402468548522 33.9441742543586)') UNION
SELECT 'JFK', TO_GEOGRAPHY('POINT(-73.7863268609295 40.6459595584081)')
)
SELECT CARTO_ANALYTICS_TOOLBOX_CORE.CARTO.ST_GREATCIRCLE(t1.geog, t2.geog, 25) AS geom
FROM data AS t1
CROSS JOIN data AS t2
WHERE t1.abbrev != t2.abbrev
This query first creates all the possible combinations between airports and then generates the paths between them using the
ST_GREATCIRCLE
function. The resulting paths contain 25 points, but you can set the number of points in order to make the lines smoother if needed (you could also not include this parameter).The result is displayed in this visualization. Notice that we are not using straight lines to interconnect the different airports, but great circles instead.

Now let’s put to the test how to perform line interpolations using the
ST_LINE_INTERPOLATE_POINT
function. In this example we will compute the airplane position after taking off from the different airports and travelling a certain distance.WITH data AS(
SELECT 'SEA' AS abbrev, TO_GEOGRAPHY('POINT(-122.302289722924 47.4435819127259)') AS geog UNION
SELECT 'MIA', TO_GEOGRAPHY('POINT(-80.2789718277441 25.7949407212406)') UNION
SELECT 'LAX', TO_GEOGRAPHY('POINT(-118.402468548522 33.9441742543586)') UNION
SELECT 'JFK', TO_GEOGRAPHY('POINT(-73.7863268609295 40.6459595584081)')
)
SELECT CONCAT(t1.abbrev, ' - ', t2.abbrev) AS route,
CARTO_ANALYTICS_TOOLBOX_CORE.CARTO.ST_LINE_INTERPOLATE_POINT(CARTO_ANALYTICS_TOOLBOX_CORE.CARTO.ST_GREATCIRCLE(t1.geog, t2.geog, 25), 500) AS geom
FROM data AS t1
CROSS JOIN data AS t2
WHERE t1.abbrev != t2.abbrev
This query uses the
ST_LINE_INTERPOLATE_POINT
function over each great circle in order to calculate the location of the plane after travelling 500 kilometers. In the following visualization you can see the resulting locations as well as their origin and destination airports.