Contrail Forecast (/v1)

This notebook shows basic usage of the Contrail Forecast (/v1) API for retrieving GeoJSON polygon regions and netCDF gridded contrail forecast data.

This API implements a working specification for contrail forecast data designed for air traffic planners and managers implementing navigational contrail avoidance systems.

[1]:
import os
from pprint import pprint
[2]:
# Load API key
# (contact api@contrails.org if you need an API key)
URL = "https://api.contrails.org"
API_KEY = os.environ["CONTRAILS_API_KEY"]
HEADERS = {"x-api-key": API_KEY}

Polygon contrail forecast regions

GET /v1/regions/

Fetch and visualize contrail forecast regions as GeoJSON polygons at a given flight level.

The threshold value must be one of [1, 2, 3, 4]. A threshold of 1 returns contrail regions predicted to create low warming contrails. A thresold of 4 returns contrail regions predicted to create the most warming contrails.

Let’s fetch polygon regions for Oct 15, 2024 12:00 UTC at flight level 330, with threshold value of 3

[3]:
import requests  # pip install requests

# for plotting GeoJSON polygons
import shapely.geometry as sgeom  # pip install shapely
import matplotlib.pyplot as plt  # pip install matplotlib
[4]:
datetime = "2024-10-15T12"  # format ISO8601
aircraft_class = "default"
flight_level = 330
threshold = 3

uri_template = "{URL}/v1/regions?aircraft_class={ac}&time={ts}&flight_level={fl}&threshold={thres}"
uri = uri_template.format(
    URL=URL,
    ac=aircraft_class,
    ts=datetime,
    fl=flight_level,
    thres=threshold,
)
resp = requests.get(uri, headers=HEADERS)
print(f"HTTP Response Code: {resp.status_code} {resp.reason}\n")
HTTP Response Code: 200 OK

[5]:
# Extract a feature
regions_geojson = resp.json()
feature = regions_geojson["features"][0]

# Visualize with shapely
polygons = sgeom.shape(feature["geometry"])
for poly in polygons.geoms:
    plt.fill(*poly.exterior.xy, color="red")

plt.xlabel("longitude")
plt.ylabel("latitude");
../_images/notebooks_forecast_api_6_0.png

NetCDF contrail forecast data

GET /v1/grids/

Fetch and visualize contrail forecast data on a regular grid at a given flight level.

The variable contrails in the netCDF object represents a contrail severity index, ranging from 0 (no contrail warming) to 4 (highly warming).

Let’s fetch netCDF gridded data for Oct 15, 2024 12:00 UTC at flight level 330

[6]:
import xarray as xr  # pip install xarray
[7]:
# fetch netCDF content from API
datetime = "2024-10-15T12"  # format ISO8601
aircraft_class = "default"
flight_level = 330

uri_template = "{URL}/v1/grids?aircraft_class={ac}&time={ts}&flight_level={fl}"
uri = uri_template.format(
    URL=URL,
    ac=aircraft_class,
    ts=datetime,
    fl=flight_level,
)

resp = requests.get(uri, headers=HEADERS)
print(f"HTTP Response Code: {resp.status_code} {resp.reason}\n")

# Save request to disk, then open with xarray
with open("forecast.nc", "wb") as f:
    f.write(resp.content)

ds = xr.open_dataset("forecast.nc", engine="netcdf4")  # pip install netCDF4
HTTP Response Code: 200 OK

[8]:
# Plot lat x lon slice for this time x flight level
ds["contrails"].squeeze().plot(x="longitude", y="latitude", cmap="Reds");
../_images/notebooks_forecast_api_10_0.png