Coordinate transformations#

Motivation#

In all fields of science we frequently encounter data that is represented in coordinates or coordinate systems that are not apt for certain operations or visualizations. In these cases we may thus need to compute new coordinates based on one or multiple existing coordinates. For simple cases this may just be done by hand. Consider:

[1]:
import scipp as sc
import plopp as pp

x = sc.linspace(dim='x', unit='m', start=1.0, stop=55.0, num=100)
da = sc.DataArray(data=x * x, coords={'x': x})
da.plot(figsize=(4, 3))
[1]:
../_images/user-guide_coordinate-transformations_1_0.svg

We may want to use \(x^2\) instead of \(x\) as a coordinate, to highlight the quadratic nature of our data:

[2]:
da2 = da.copy()
da2.coords['x_square'] = x * x
da2
[2]:
Show/Hide data repr Show/Hide attributes
scipp.DataArray (3.60 KB)
    • x: 100
    • x
      (x)
      float64
      m
      1.0, 1.545, ..., 54.455, 55.0
      Values:
      array([ 1. , 1.54545455, 2.09090909, 2.63636364, 3.18181818, 3.72727273, 4.27272727, 4.81818182, 5.36363636, 5.90909091, 6.45454545, 7. , 7.54545455, 8.09090909, 8.63636364, 9.18181818, 9.72727273, 10.27272727, 10.81818182, 11.36363636, 11.90909091, 12.45454545, 13. , 13.54545455, 14.09090909, 14.63636364, 15.18181818, 15.72727273, 16.27272727, 16.81818182, 17.36363636, 17.90909091, 18.45454545, 19. , 19.54545455, 20.09090909, 20.63636364, 21.18181818, 21.72727273, 22.27272727, 22.81818182, 23.36363636, 23.90909091, 24.45454545, 25. , 25.54545455, 26.09090909, 26.63636364, 27.18181818, 27.72727273, 28.27272727, 28.81818182, 29.36363636, 29.90909091, 30.45454545, 31. , 31.54545455, 32.09090909, 32.63636364, 33.18181818, 33.72727273, 34.27272727, 34.81818182, 35.36363636, 35.90909091, 36.45454545, 37. , 37.54545455, 38.09090909, 38.63636364, 39.18181818, 39.72727273, 40.27272727, 40.81818182, 41.36363636, 41.90909091, 42.45454545, 43. , 43.54545455, 44.09090909, 44.63636364, 45.18181818, 45.72727273, 46.27272727, 46.81818182, 47.36363636, 47.90909091, 48.45454545, 49. , 49.54545455, 50.09090909, 50.63636364, 51.18181818, 51.72727273, 52.27272727, 52.81818182, 53.36363636, 53.90909091, 54.45454545, 55. ])
    • x_square
      (x)
      float64
      m^2
      1.0, 2.388, ..., 2965.298, 3025.000
      Values:
      array([1.00000000e+00, 2.38842975e+00, 4.37190083e+00, 6.95041322e+00, 1.01239669e+01, 1.38925620e+01, 1.82561983e+01, 2.32148760e+01, 2.87685950e+01, 3.49173554e+01, 4.16611570e+01, 4.90000000e+01, 5.69338843e+01, 6.54628099e+01, 7.45867769e+01, 8.43057851e+01, 9.46198347e+01, 1.05528926e+02, 1.17033058e+02, 1.29132231e+02, 1.41826446e+02, 1.55115702e+02, 1.69000000e+02, 1.83479339e+02, 1.98553719e+02, 2.14223140e+02, 2.30487603e+02, 2.47347107e+02, 2.64801653e+02, 2.82851240e+02, 3.01495868e+02, 3.20735537e+02, 3.40570248e+02, 3.61000000e+02, 3.82024793e+02, 4.03644628e+02, 4.25859504e+02, 4.48669421e+02, 4.72074380e+02, 4.96074380e+02, 5.20669421e+02, 5.45859504e+02, 5.71644628e+02, 5.98024793e+02, 6.25000000e+02, 6.52570248e+02, 6.80735537e+02, 7.09495868e+02, 7.38851240e+02, 7.68801653e+02, 7.99347107e+02, 8.30487603e+02, 8.62223140e+02, 8.94553719e+02, 9.27479339e+02, 9.61000000e+02, 9.95115702e+02, 1.02982645e+03, 1.06513223e+03, 1.10103306e+03, 1.13752893e+03, 1.17461983e+03, 1.21230579e+03, 1.25058678e+03, 1.28946281e+03, 1.32893388e+03, 1.36900000e+03, 1.40966116e+03, 1.45091736e+03, 1.49276860e+03, 1.53521488e+03, 1.57825620e+03, 1.62189256e+03, 1.66612397e+03, 1.71095041e+03, 1.75637190e+03, 1.80238843e+03, 1.84900000e+03, 1.89620661e+03, 1.94400826e+03, 1.99240496e+03, 2.04139669e+03, 2.09098347e+03, 2.14116529e+03, 2.19194215e+03, 2.24331405e+03, 2.29528099e+03, 2.34784298e+03, 2.40100000e+03, 2.45475207e+03, 2.50909917e+03, 2.56404132e+03, 2.61957851e+03, 2.67571074e+03, 2.73243802e+03, 2.78976033e+03, 2.84767769e+03, 2.90619008e+03, 2.96529752e+03, 3.02500000e+03])
    • (x)
      float64
      m^2
      1.0, 2.388, ..., 2965.298, 3025.000
      Values:
      array([1.00000000e+00, 2.38842975e+00, 4.37190083e+00, 6.95041322e+00, 1.01239669e+01, 1.38925620e+01, 1.82561983e+01, 2.32148760e+01, 2.87685950e+01, 3.49173554e+01, 4.16611570e+01, 4.90000000e+01, 5.69338843e+01, 6.54628099e+01, 7.45867769e+01, 8.43057851e+01, 9.46198347e+01, 1.05528926e+02, 1.17033058e+02, 1.29132231e+02, 1.41826446e+02, 1.55115702e+02, 1.69000000e+02, 1.83479339e+02, 1.98553719e+02, 2.14223140e+02, 2.30487603e+02, 2.47347107e+02, 2.64801653e+02, 2.82851240e+02, 3.01495868e+02, 3.20735537e+02, 3.40570248e+02, 3.61000000e+02, 3.82024793e+02, 4.03644628e+02, 4.25859504e+02, 4.48669421e+02, 4.72074380e+02, 4.96074380e+02, 5.20669421e+02, 5.45859504e+02, 5.71644628e+02, 5.98024793e+02, 6.25000000e+02, 6.52570248e+02, 6.80735537e+02, 7.09495868e+02, 7.38851240e+02, 7.68801653e+02, 7.99347107e+02, 8.30487603e+02, 8.62223140e+02, 8.94553719e+02, 9.27479339e+02, 9.61000000e+02, 9.95115702e+02, 1.02982645e+03, 1.06513223e+03, 1.10103306e+03, 1.13752893e+03, 1.17461983e+03, 1.21230579e+03, 1.25058678e+03, 1.28946281e+03, 1.32893388e+03, 1.36900000e+03, 1.40966116e+03, 1.45091736e+03, 1.49276860e+03, 1.53521488e+03, 1.57825620e+03, 1.62189256e+03, 1.66612397e+03, 1.71095041e+03, 1.75637190e+03, 1.80238843e+03, 1.84900000e+03, 1.89620661e+03, 1.94400826e+03, 1.99240496e+03, 2.04139669e+03, 2.09098347e+03, 2.14116529e+03, 2.19194215e+03, 2.24331405e+03, 2.29528099e+03, 2.34784298e+03, 2.40100000e+03, 2.45475207e+03, 2.50909917e+03, 2.56404132e+03, 2.61957851e+03, 2.67571074e+03, 2.73243802e+03, 2.78976033e+03, 2.84767769e+03, 2.90619008e+03, 2.96529752e+03, 3.02500000e+03])

While adding a new coordinate may often be done with a single line of code, the above example highlights the first shortcoming of this approach: To actually visualize da using this new coordinate we must additionally rename the dimension:

[3]:
da2 = da2.rename_dims({'x': 'x_square'})
da2.plot(figsize=(4, 3))
[3]:
../_images/user-guide_coordinate-transformations_5_0.svg

Further complications are:

  • The original coordinate is preserved and may get in the way in subsequent operations.

  • Event-coordinates of binned data are not handled.

  • Multi-step conversions with multiple inputs and multiple outputs may be required in practice.

To accommodate these recurring yet highly application-specific needs, Scipp provides a generic mechanism for transforming coordinates. This is described and exemplified in the following.

transform_coords#

Overview#

sc.transform_coords (also available as method of data arrays and datasets) is a tool for transforming one or more input coordinates into one or more output coordinates. It automatically handles:

  • Renaming of dimensions, if dimension-coordinates are transformed.

  • Making coordinates unaligned to avoid interference of coordinates consumed by the transformation in follow-up operations.

  • Conversion of event-coordinates of binned data, if present.

Basic example#

We start by revisiting the example given in Motivation. The building blocks transform_coords operates on are functions with named parameters. The parameter names define the names of the input coordinates to consume. Let us define x_square, which will consume x:

[4]:
def x_square(x):
    return x * x

Next, we create a dict, mapping from an output coord name to a function that can create this coordinate. The sc.show_graph helper is a convenient tool for visualizing the coordinate transformation defined by such as mapping:

[5]:
graph = {'x^2': x_square}
sc.show_graph(graph)
[5]:
../_images/user-guide_coordinate-transformations_9_0.svg

Here, the x coordinate can be consumed by the x_square function, creating the x^2 coordinate. Note that the function name and coordinate are unrelated. Next, we can call transform_coords. Apart from the graph, we also pass a list of desired output coordinates, here simply ['x^2']. transform_coords returns a new (shallow-copied) data array with added coordinates:

[6]:
transformed = da.transform_coords(['x^2'], graph=graph)
transformed
[6]:
Show/Hide data repr Show/Hide attributes
scipp.DataArray (3.60 KB)
    • x^2: 100
    • x
      (x^2)
      float64
      m
      1.0, 1.545, ..., 54.455, 55.0
      Values:
      array([ 1. , 1.54545455, 2.09090909, 2.63636364, 3.18181818, 3.72727273, 4.27272727, 4.81818182, 5.36363636, 5.90909091, 6.45454545, 7. , 7.54545455, 8.09090909, 8.63636364, 9.18181818, 9.72727273, 10.27272727, 10.81818182, 11.36363636, 11.90909091, 12.45454545, 13. , 13.54545455, 14.09090909, 14.63636364, 15.18181818, 15.72727273, 16.27272727, 16.81818182, 17.36363636, 17.90909091, 18.45454545, 19. , 19.54545455, 20.09090909, 20.63636364, 21.18181818, 21.72727273, 22.27272727, 22.81818182, 23.36363636, 23.90909091, 24.45454545, 25. , 25.54545455, 26.09090909, 26.63636364, 27.18181818, 27.72727273, 28.27272727, 28.81818182, 29.36363636, 29.90909091, 30.45454545, 31. , 31.54545455, 32.09090909, 32.63636364, 33.18181818, 33.72727273, 34.27272727, 34.81818182, 35.36363636, 35.90909091, 36.45454545, 37. , 37.54545455, 38.09090909, 38.63636364, 39.18181818, 39.72727273, 40.27272727, 40.81818182, 41.36363636, 41.90909091, 42.45454545, 43. , 43.54545455, 44.09090909, 44.63636364, 45.18181818, 45.72727273, 46.27272727, 46.81818182, 47.36363636, 47.90909091, 48.45454545, 49. , 49.54545455, 50.09090909, 50.63636364, 51.18181818, 51.72727273, 52.27272727, 52.81818182, 53.36363636, 53.90909091, 54.45454545, 55. ])
    • x^2
      (x^2)
      float64
      m^2
      1.0, 2.388, ..., 2965.298, 3025.000
      Values:
      array([1.00000000e+00, 2.38842975e+00, 4.37190083e+00, 6.95041322e+00, 1.01239669e+01, 1.38925620e+01, 1.82561983e+01, 2.32148760e+01, 2.87685950e+01, 3.49173554e+01, 4.16611570e+01, 4.90000000e+01, 5.69338843e+01, 6.54628099e+01, 7.45867769e+01, 8.43057851e+01, 9.46198347e+01, 1.05528926e+02, 1.17033058e+02, 1.29132231e+02, 1.41826446e+02, 1.55115702e+02, 1.69000000e+02, 1.83479339e+02, 1.98553719e+02, 2.14223140e+02, 2.30487603e+02, 2.47347107e+02, 2.64801653e+02, 2.82851240e+02, 3.01495868e+02, 3.20735537e+02, 3.40570248e+02, 3.61000000e+02, 3.82024793e+02, 4.03644628e+02, 4.25859504e+02, 4.48669421e+02, 4.72074380e+02, 4.96074380e+02, 5.20669421e+02, 5.45859504e+02, 5.71644628e+02, 5.98024793e+02, 6.25000000e+02, 6.52570248e+02, 6.80735537e+02, 7.09495868e+02, 7.38851240e+02, 7.68801653e+02, 7.99347107e+02, 8.30487603e+02, 8.62223140e+02, 8.94553719e+02, 9.27479339e+02, 9.61000000e+02, 9.95115702e+02, 1.02982645e+03, 1.06513223e+03, 1.10103306e+03, 1.13752893e+03, 1.17461983e+03, 1.21230579e+03, 1.25058678e+03, 1.28946281e+03, 1.32893388e+03, 1.36900000e+03, 1.40966116e+03, 1.45091736e+03, 1.49276860e+03, 1.53521488e+03, 1.57825620e+03, 1.62189256e+03, 1.66612397e+03, 1.71095041e+03, 1.75637190e+03, 1.80238843e+03, 1.84900000e+03, 1.89620661e+03, 1.94400826e+03, 1.99240496e+03, 2.04139669e+03, 2.09098347e+03, 2.14116529e+03, 2.19194215e+03, 2.24331405e+03, 2.29528099e+03, 2.34784298e+03, 2.40100000e+03, 2.45475207e+03, 2.50909917e+03, 2.56404132e+03, 2.61957851e+03, 2.67571074e+03, 2.73243802e+03, 2.78976033e+03, 2.84767769e+03, 2.90619008e+03, 2.96529752e+03, 3.02500000e+03])
    • (x^2)
      float64
      m^2
      1.0, 2.388, ..., 2965.298, 3025.000
      Values:
      array([1.00000000e+00, 2.38842975e+00, 4.37190083e+00, 6.95041322e+00, 1.01239669e+01, 1.38925620e+01, 1.82561983e+01, 2.32148760e+01, 2.87685950e+01, 3.49173554e+01, 4.16611570e+01, 4.90000000e+01, 5.69338843e+01, 6.54628099e+01, 7.45867769e+01, 8.43057851e+01, 9.46198347e+01, 1.05528926e+02, 1.17033058e+02, 1.29132231e+02, 1.41826446e+02, 1.55115702e+02, 1.69000000e+02, 1.83479339e+02, 1.98553719e+02, 2.14223140e+02, 2.30487603e+02, 2.47347107e+02, 2.64801653e+02, 2.82851240e+02, 3.01495868e+02, 3.20735537e+02, 3.40570248e+02, 3.61000000e+02, 3.82024793e+02, 4.03644628e+02, 4.25859504e+02, 4.48669421e+02, 4.72074380e+02, 4.96074380e+02, 5.20669421e+02, 5.45859504e+02, 5.71644628e+02, 5.98024793e+02, 6.25000000e+02, 6.52570248e+02, 6.80735537e+02, 7.09495868e+02, 7.38851240e+02, 7.68801653e+02, 7.99347107e+02, 8.30487603e+02, 8.62223140e+02, 8.94553719e+02, 9.27479339e+02, 9.61000000e+02, 9.95115702e+02, 1.02982645e+03, 1.06513223e+03, 1.10103306e+03, 1.13752893e+03, 1.17461983e+03, 1.21230579e+03, 1.25058678e+03, 1.28946281e+03, 1.32893388e+03, 1.36900000e+03, 1.40966116e+03, 1.45091736e+03, 1.49276860e+03, 1.53521488e+03, 1.57825620e+03, 1.62189256e+03, 1.66612397e+03, 1.71095041e+03, 1.75637190e+03, 1.80238843e+03, 1.84900000e+03, 1.89620661e+03, 1.94400826e+03, 1.99240496e+03, 2.04139669e+03, 2.09098347e+03, 2.14116529e+03, 2.19194215e+03, 2.24331405e+03, 2.29528099e+03, 2.34784298e+03, 2.40100000e+03, 2.45475207e+03, 2.50909917e+03, 2.56404132e+03, 2.61957851e+03, 2.67571074e+03, 2.73243802e+03, 2.78976033e+03, 2.84767769e+03, 2.90619008e+03, 2.96529752e+03, 3.02500000e+03])

Note how x is now unaligned (not shown in bold), i.e., operations will not use it for alignment anymore. This is important since it will allow for operations combining transformed with other data that may have matching x^2 but not x.

Example: Multi-step transform splitting and combining input coords#

Introduction#

Let us consider a more complex example. Imagine we have sensors around the globe, counting lightning strikes. For each sensor get have data recorded at a certain UTC, and the sensor location. We may be interested in variation of lightning strike frequency with time of day, as well as latitude. To obtain this, we must:

  1. Extract latitude and longitude information from the sensor locations.

  2. Compute the local datetime from the datetime and a “timezone” offset from the longitude.

  3. Extract the time from the local datetime.

For this purpose, we may define functions that look as follows. We suggest ignoring the implementation details of these functions, since they are approximations and irrelevant for this example:

[7]:
def lat_long(location):
    x = location.fields.x
    y = location.fields.y
    z = location.fields.z
    theta = sc.to_unit(sc.atan2(y=sc.sqrt(x * x + y * y), x=z), 'deg', copy=False)
    phi = sc.to_unit(sc.atan2(y=y, x=x), 'deg', copy=False)
    return {'latitude': 90.0 * sc.Unit('deg') - theta, 'longitude': phi}


def local_datetime(datetime, longitude):
    long = sc.to_unit(longitude, unit='deg', copy=False)
    angular_velocity = (360.0 * sc.Unit('deg')) / (24.0 * sc.Unit('hour'))
    offset = (long / angular_velocity).astype('int64') + 12 * sc.Unit('hour')
    return sc.to_unit(offset, datetime.unit) + datetime


def time(local_datetime):
    seconds_per_day = sc.scalar(24 * 60 * 60, unit='s')
    start_day = sc.scalar(start.value.astype('datetime64[D]'))
    start_day_in_seconds = sc.scalar(start_day.values.astype('datetime64[s]'))
    offset = local_datetime - start_day_in_seconds
    time = (offset % seconds_per_day).astype('float64')
    return time

Defining a transformation graph#

Based on these functions we may then create a mapping between coordinate names and functions. The visualization of the graph gives a handy summary of the desired conversion outlined above:

[8]:
graph = {
    (
        'longitude',
        'latitude',
    ): lat_long,
    'local_time': time,
    'local_datetime': local_datetime,
}
sc.show_graph(graph, size='6')
[8]:
../_images/user-guide_coordinate-transformations_15_0.svg

Sample data#

Next, let us look at the data we are working with. Here we simply create some fake data, the details of the following code cell are irrelevant and should also be ignored:

[9]:
import numpy as np

hour_steps = sc.arange(
    dim='datetime',
    dtype='int64',
    unit='s',
    start=0,
    stop=3 * 24 * 60 * 60,
    step=60 * 60,
)
start = sc.scalar(np.datetime64('2021-06-01T17:00:00'))
datetime = start + hour_steps
nsite = 1000
ntime = len(datetime)
# Note that these points are NOT uniformly distributed on a sphere, this is NOT a good way to generate such points
location = sc.vectors(dims=['location'], values=np.random.rand(nsite, 3)) - sc.vector(
    value=[0.5, 0.5, 0.5]
)
location *= 6371 * sc.Unit('km') / sc.norm(location)
da = sc.DataArray(
    data=sc.array(dims=['location', 'datetime'], values=np.random.rand(nsite, ntime)),
    coords={'location': location, 'datetime': datetime},
)
north = location.fields.z > 0.0 * sc.Unit('km')
north.unit = sc.units.one
da += 2.0 * (north).astype('float64')  # more lightning strikes in northern hemisphere
phi0 = sc.atan2(y=location.fields.y, x=location.fields.x) - sc.to_unit(
    90.0 * sc.Unit('deg'), 'rad'
)
sin = sc.sin(
    phi0 + sc.linspace(dim='datetime', unit='rad', start=0, stop=6 * np.pi, num=ntime)
)
da += 2 * (sin + 1)  # more lightning strikes later in the day
da.unit = 'counts'

Our input data looks as follows, a 2-D data array with dimensions datetime and location, and corresponding coordinates:

[10]:
da
[10]:
Show/Hide data repr Show/Hide attributes
scipp.DataArray (587.81 KB)
    • location: 1000
    • datetime: 72
    • datetime
      (datetime)
      datetime64
      s
      2021-06-01T17:00:00, 2021-06-01T18:00:00, ..., 2021-06-04T15:00:00, 2021-06-04T16:00:00
      Values:
      array(['2021-06-01T17:00:00', '2021-06-01T18:00:00', '2021-06-01T19:00:00', '2021-06-01T20:00:00', '2021-06-01T21:00:00', '2021-06-01T22:00:00', '2021-06-01T23:00:00', '2021-06-02T00:00:00', '2021-06-02T01:00:00', '2021-06-02T02:00:00', '2021-06-02T03:00:00', '2021-06-02T04:00:00', '2021-06-02T05:00:00', '2021-06-02T06:00:00', '2021-06-02T07:00:00', '2021-06-02T08:00:00', '2021-06-02T09:00:00', '2021-06-02T10:00:00', '2021-06-02T11:00:00', '2021-06-02T12:00:00', '2021-06-02T13:00:00', '2021-06-02T14:00:00', '2021-06-02T15:00:00', '2021-06-02T16:00:00', '2021-06-02T17:00:00', '2021-06-02T18:00:00', '2021-06-02T19:00:00', '2021-06-02T20:00:00', '2021-06-02T21:00:00', '2021-06-02T22:00:00', '2021-06-02T23:00:00', '2021-06-03T00:00:00', '2021-06-03T01:00:00', '2021-06-03T02:00:00', '2021-06-03T03:00:00', '2021-06-03T04:00:00', '2021-06-03T05:00:00', '2021-06-03T06:00:00', '2021-06-03T07:00:00', '2021-06-03T08:00:00', '2021-06-03T09:00:00', '2021-06-03T10:00:00', '2021-06-03T11:00:00', '2021-06-03T12:00:00', '2021-06-03T13:00:00', '2021-06-03T14:00:00', '2021-06-03T15:00:00', '2021-06-03T16:00:00', '2021-06-03T17:00:00', '2021-06-03T18:00:00', '2021-06-03T19:00:00', '2021-06-03T20:00:00', '2021-06-03T21:00:00', '2021-06-03T22:00:00', '2021-06-03T23:00:00', '2021-06-04T00:00:00', '2021-06-04T01:00:00', '2021-06-04T02:00:00', '2021-06-04T03:00:00', '2021-06-04T04:00:00', '2021-06-04T05:00:00', '2021-06-04T06:00:00', '2021-06-04T07:00:00', '2021-06-04T08:00:00', '2021-06-04T09:00:00', '2021-06-04T10:00:00', '2021-06-04T11:00:00', '2021-06-04T12:00:00', '2021-06-04T13:00:00', '2021-06-04T14:00:00', '2021-06-04T15:00:00', '2021-06-04T16:00:00'], dtype='datetime64[s]')
    • location
      (location)
      vector3
      km
      [-5856.37156922 -2114.21930018 -1350.04807099], [-235.72188253 5725.8499107 2783.65209649], ..., [-4341.11395331 -4274.55318055 -1863.48215742], [ -894.98450231 -1402.53011076 -6149.92301001]
      Values:
      array([[-5856.37156922, -2114.21930018, -1350.04807099], [ -235.72188253, 5725.8499107 , 2783.65209649], [-3387.09408017, 5371.93335908, 509.47686662], ..., [-4523.82399256, -2764.67680521, 3532.87696461], [-4341.11395331, -4274.55318055, -1863.48215742], [ -894.98450231, -1402.53011076, -6149.92301001]])
    • (location, datetime)
      float64
      counts
      4.101, 4.288, ..., 4.267, 3.178
      Values:
      array([[4.10057244, 4.28817869, 3.98988822, ..., 4.63683272, 4.48209122, 4.85176277], [4.68011366, 4.8665567 , 5.11758422, ..., 3.12319908, 3.74648651, 4.66549553], [5.62566505, 6.07238702, 5.79976953, ..., 4.35416939, 5.15601354, 5.55128796], ..., [6.43612422, 5.77539914, 5.66281152, ..., 6.15638901, 6.02070382, 6.46670194], [4.02808088, 3.26180026, 2.69455495, ..., 4.29036918, 4.15678654, 4.26156147], [4.01675088, 3.5045501 , 2.25948342, ..., 4.38028896, 4.26652895, 3.1782028 ]])

A 3-D scatter plot may be used to visualize this. When dragging the datetime slider we can observe how the lightning counts shifts around the globe with the time of the day (the fake data covers a period of 3 days). Note that the slider is only functional when running the notebook and is not functional in the online documentation page:

[11]:
def scatter_plot(da):
    from plopp import widgets as pw

    da = da.copy(deep=False)
    da.coords['x'] = da.coords['location'].fields.x
    da.coords['y'] = da.coords['location'].fields.y
    da.coords['z'] = da.coords['location'].fields.z
    inp = pp.Node(da)
    slider = pw.SliceWidget(da, dims=['datetime'])
    slider_node = pp.widget_node(slider)
    slice_node = pw.slice_dims(inp, slider_node)
    fig = pp.figure3d(slice_node, x='x', y='y', z='z', pixel_size=500)
    return pw.Box([fig, slider])


scatter_plot(da)
/tmp/ipykernel_6241/2551519854.py:12: VisibleDeprecationWarning: figure3d is deprecated. Use ``scatter3dfigure`` instead.
  fig = pp.figure3d(slice_node, x='x', y='y', z='z', pixel_size=500)
[11]:

Performing a transformation#

With this setup, the actual coordinate transformation is now very simple:

[12]:
transformed = da.transform_coords(['latitude', 'local_time'], graph=graph)

The result is:

[13]:
transformed
[13]:
Show/Hide data repr Show/Hide attributes
scipp.DataArray (1.69 MB)
    • location: 1000
    • local_time: 72
    • datetime
      (local_time)
      datetime64
      s
      2021-06-01T17:00:00, 2021-06-01T18:00:00, ..., 2021-06-04T15:00:00, 2021-06-04T16:00:00
      Values:
      array(['2021-06-01T17:00:00', '2021-06-01T18:00:00', '2021-06-01T19:00:00', '2021-06-01T20:00:00', '2021-06-01T21:00:00', '2021-06-01T22:00:00', '2021-06-01T23:00:00', '2021-06-02T00:00:00', '2021-06-02T01:00:00', '2021-06-02T02:00:00', '2021-06-02T03:00:00', '2021-06-02T04:00:00', '2021-06-02T05:00:00', '2021-06-02T06:00:00', '2021-06-02T07:00:00', '2021-06-02T08:00:00', '2021-06-02T09:00:00', '2021-06-02T10:00:00', '2021-06-02T11:00:00', '2021-06-02T12:00:00', '2021-06-02T13:00:00', '2021-06-02T14:00:00', '2021-06-02T15:00:00', '2021-06-02T16:00:00', '2021-06-02T17:00:00', '2021-06-02T18:00:00', '2021-06-02T19:00:00', '2021-06-02T20:00:00', '2021-06-02T21:00:00', '2021-06-02T22:00:00', '2021-06-02T23:00:00', '2021-06-03T00:00:00', '2021-06-03T01:00:00', '2021-06-03T02:00:00', '2021-06-03T03:00:00', '2021-06-03T04:00:00', '2021-06-03T05:00:00', '2021-06-03T06:00:00', '2021-06-03T07:00:00', '2021-06-03T08:00:00', '2021-06-03T09:00:00', '2021-06-03T10:00:00', '2021-06-03T11:00:00', '2021-06-03T12:00:00', '2021-06-03T13:00:00', '2021-06-03T14:00:00', '2021-06-03T15:00:00', '2021-06-03T16:00:00', '2021-06-03T17:00:00', '2021-06-03T18:00:00', '2021-06-03T19:00:00', '2021-06-03T20:00:00', '2021-06-03T21:00:00', '2021-06-03T22:00:00', '2021-06-03T23:00:00', '2021-06-04T00:00:00', '2021-06-04T01:00:00', '2021-06-04T02:00:00', '2021-06-04T03:00:00', '2021-06-04T04:00:00', '2021-06-04T05:00:00', '2021-06-04T06:00:00', '2021-06-04T07:00:00', '2021-06-04T08:00:00', '2021-06-04T09:00:00', '2021-06-04T10:00:00', '2021-06-04T11:00:00', '2021-06-04T12:00:00', '2021-06-04T13:00:00', '2021-06-04T14:00:00', '2021-06-04T15:00:00', '2021-06-04T16:00:00'], dtype='datetime64[s]')
    • latitude
      (location)
      float64
      deg
      -12.234, 25.908, ..., -17.007, -74.862
      Values:
      array([-12.23402562, 25.90787722, 4.58673304, 34.94341995, -13.60666119, 57.94853877, -34.81802883, -8.94797716, 71.96289091, 69.74475642, 37.81936076, 22.37870602, 41.91336622, 53.47877401, -12.75617261, -49.17828086, 23.03296202, 48.98641065, 36.17024784, -17.74505011, -57.64360924, -60.71580918, 44.67386313, 43.78808619, 27.2671779 , -42.45419501, 35.22518517, -3.25829353, -24.16596925, -68.85593575, -7.29795552, 58.92782974, -20.56475007, 40.74433439, -60.52557866, -57.13492311, 21.04143234, -7.28803425, 45.40840213, 41.18671933, 16.78748578, -38.3182232 , -78.01776793, -50.40621041, -81.42971885, 63.31112145, -24.50267468, 6.34915724, 32.25425579, 54.58702138, -44.01300398, -3.03888236, 36.49691878, -48.90874763, 86.67544138, 57.25585933, 38.83354465, -57.95584404, 50.07634836, -26.14172206, -22.71813314, 2.87497481, 30.96673581, -39.82132949, -60.21368974, -25.72780531, -3.65387234, 22.34884186, 63.55099 , 43.91436684, -0.19177965, 15.74715566, 5.42777698, 26.97075635, 26.50580735, 28.44553778, 55.8419474 , -14.51377183, 24.12177504, -26.39147864, -34.19693824, -9.43262908, -50.32187442, -28.41696887, -41.90840859, 19.86078905, 20.70102559, -58.75098072, -23.14995348, 34.57139066, 27.24784067, -34.92645877, -31.5912296 , 7.89222398, 16.66075878, 20.16614341, -45.26329535, -24.30834176, 28.29124336, -30.16922917, -56.32961919, 18.10409711, -66.62058719, 43.41068294, -53.93688429, -34.86933434, 44.2835862 , 35.44837389, 22.74133959, -71.00691111, -82.13431656, 45.71657925, 53.71285 , 43.7129448 , 44.66062283, -69.88445214, -51.04072673, -4.49165811, -61.9012513 , 54.78931334, 33.33194792, 9.42175438, 82.79370925, -0.82281927, 27.46564158, -15.98820611, 30.72399804, -3.65634109, -60.22739587, -44.33767953, -53.56362769, -41.86575311, -40.45431893, 2.26881332, 26.37805317, -34.46532025, 31.21918521, -50.9038442 , 32.38521643, -50.5295927 , -56.50422023, -38.53985364, 10.86974539, -47.19912108, 77.83038124, -8.13674251, 46.37767642, -58.45394353, -49.62831954, -12.27107031, -37.71959663, 17.83387461, 41.37424163, -10.69857445, -3.82319331, -34.6516288 , -22.61664053, 27.74973492, 30.46820784, -30.46110685, -5.6596238 , 57.61587769, 39.53572808, 5.53695456, -40.53531825, -42.50867181, -50.86541687, 30.04225358, 34.07912224, 23.76032273, -11.67961767, -42.39136709, -28.20080943, 59.64631125, -26.51188102, 60.99156797, 18.21051496, -36.20696019, 52.01898483, -63.65154219, -75.84307685, 51.88381571, -31.08353712, 9.64226959, -26.90190616, -63.73127164, -41.40212875, 19.04014589, -51.14361206, 29.50328437, -33.62075392, 43.14980649, -14.68502103, -48.70067524, 17.6944177 , 20.34315657, -48.92470329, 26.06564745, -27.52156421, 28.32195412, -0.71926403, 0.85815624, -44.91368686, 43.6532199 , 0.3439102 , -11.41735316, 45.56641571, 39.56712602, 69.17374044, -67.80235691, 31.94250797, -50.47182889, -28.70472119, 8.90350075, -42.05520141, 29.82248137, -34.82593675, 41.85078699, -46.87351421, -37.79008131, -38.21528888, -30.38637719, -34.44162528, 1.87676082, -30.11518777, 49.58080695, -0.5494079 , -39.67636679, 29.96283385, 0.57824142, 71.95542028, -41.53347665, -25.37716427, 28.77376442, 40.70192117, -27.42369363, -32.24384467, 27.42425689, 60.28143734, 19.04198255, 18.94536385, 28.75337846, -43.51583151, -66.57702267, -10.78590673, -58.74163383, -18.9332165 , -21.26647914, 3.39004513, 26.1156146 , -30.27510939, 56.69371924, -3.17765613, 6.36760847, 29.09684046, -0.94836962, 18.86270213, -49.4880439 , -48.91606731, -21.2762273 , -22.84440797, -39.53074591, 19.81901874, -32.51618661, -42.79896899, 70.94337356, 54.42745884, 55.19301947, 11.46981273, -19.81238903, -29.74019585, -10.65523716, -40.90168922, -35.72147769, -43.92190332, 36.56067243, -46.49683374, -17.88993912, 70.16248818, 35.38657215, -42.13715853, 59.04296776, 4.94565454, 38.68243991, -5.52346858, 18.11176399, -26.16867379, -37.66959572, -32.48123114, 18.90328467, 27.17403286, -17.66171494, -60.17365729, 1.22031565, 26.99943705, -18.84331904, 27.20638463, -24.27726089, 28.69662682, 80.14985322, 66.65138285, -38.52910777, -3.86053765, -2.68577058, -48.58236351, 24.56628725, 5.44421322, 48.53253031, 53.99583326, -14.04964842, -4.05201635, -39.74204898, -34.08570155, -26.81173358, -9.21012065, -33.00734305, -42.60798903, -17.57703778, -24.97245378, 32.11721744, 37.54430396, -19.96636028, -16.6635851 , -14.01408957, 26.50862157, 25.26480845, -55.41772455, 81.08868528, -1.74811026, 54.51988379, 40.44389134, 39.57171719, -30.50997938, 48.0241773 , 33.02858622, -67.1319153 , -24.02045263, 45.64564361, -36.7775704 , 18.73943225, 34.56323358, 35.56329285, -58.84400246, 8.15822476, -43.39050962, -29.09947429, 16.79787004, -39.882942 , 12.15681986, -49.88899883, 9.2478817 , 36.33497466, 35.92071606, 19.27647499, 39.8537929 , 29.96965923, -14.01922934, -39.79119808, -61.36661161, 28.43157168, -24.28247534, 18.33025182, -24.86265345, 29.55759423, 48.20482139, -15.18545156, -33.8558205 , -23.89743472, 34.93890908, -2.08084559, 52.21292882, 38.8998259 , 53.83521412, -58.36161709, -3.61363523, 12.91037101, -18.37457262, 39.58064997, 42.51759496, -0.46575455, 9.81833483, -50.34264576, -51.9468225 , -17.0925022 , -10.71850627, -86.00453837, 32.27746235, 71.5989199 , -12.99799976, 33.1321675 , -4.96039157, 46.45693933, -33.56731255, -53.42863471, -21.34182367, -36.30895095, -16.494619 , 9.00614263, 27.03788177, 42.56519074, -20.96929116, -45.536327 , -3.68458303, -27.40073915, 42.31931614, 28.7637614 , 16.52265447, -39.27589746, -16.57649455, -23.97420436, 1.07243119, -54.31871206, 76.84698527, 20.67226647, 1.63829174, 53.3438464 , 0.49981201, 51.50306059, 19.61929184, -19.11013135, 37.51367703, 20.07888619, -20.33744794, -23.87012727, 34.3431513 , 40.83172357, -45.81114636, -41.07334811, 2.18845488, -11.29888878, 25.88774161, -25.49261176, -55.29482719, -79.87999734, -37.33767279, -45.22635166, 15.87486387, -40.68229883, 28.42249982, 33.71341231, 25.61512404, 47.92405745, 42.02417171, -39.41535781, -10.37408929, 20.66564585, -30.72800644, 20.52081512, -55.50342262, 39.67152118, -39.40781359, 39.67108429, 15.81551347, -60.29380839, 13.27567647, -35.50631382, -2.7749891 , -39.98323336, 38.0047545 , -29.41184233, -51.32335787, -83.42791108, 0.42269518, 1.20020923, 10.38096352, 12.49420456, -45.22986434, 22.31199863, 12.94324256, -60.52757598, -42.53443798, -46.58335999, 49.21544482, 6.64830914, -44.82151569, 27.69082424, 29.3675082 , 0.93969449, -30.57247051, 17.91197037, 11.69753556, 48.44117306, 5.07643369, -26.70203194, 23.4609933 , 19.07868086, 3.38068106, -50.60154717, -26.5225953 , 37.60347446, 24.07745654, 88.05445441, -56.11022539, 58.98164337, -30.14353217, -49.75094041, -28.82556556, -9.2780066 , -24.19066287, 22.6951917 , 22.99195581, 45.34927873, -60.82584531, 25.74622794, -27.14540379, -70.53256202, 10.4918989 , -71.16902383, -32.91952726, -41.78955958, -48.5913545 , 35.51905766, -4.96985709, -10.30079443, 40.26104464, 26.05805088, 33.15189482, -61.4720092 , 25.56179325, 13.65754139, 23.78985077, -38.41505294, 46.65340095, 39.17141662, 42.05507773, -22.05501778, 43.25503178, 18.1418375 , 50.44000046, -58.30346921, 32.98978228, 56.19726757, 49.74952399, -30.203982 , -63.35955184, 51.99268768, 18.51697074, 43.75187695, 71.43184307, -10.83429714, 22.72476904, -0.64280284, -20.99790529, -33.82599705, -2.41805234, 17.29776293, -16.41847794, -5.71853137, 51.7769755 , 28.58726059, 6.92784213, -36.82983809, -40.89534839, -38.31880231, 22.56476477, 38.61635876, -48.51992013, -37.76961185, -38.28099109, 31.98612345, -7.68995905, -24.08956482, 37.02929127, 32.72027186, 5.57841207, 1.47423429, 16.98578749, -46.16757595, -39.26002322, 15.92752632, 36.86588172, 31.2266625 , 2.43308846, 47.86142341, 43.88391796, -46.98511934, -49.53911897, -4.47324614, -29.11064402, -26.03985168, -51.9385576 , -27.29046617, -27.45878977, -29.09837679, -39.06757529, -13.1718843 , 38.1911141 , -27.10153792, 43.48640456, 33.27982178, -17.88911202, 61.39406419, 15.74599621, 29.07698041, -16.22931643, 2.92156916, 48.62098445, 34.63608673, 29.84193459, 14.04445039, -26.25156992, -59.84730131, -3.59090918, -59.90460505, -35.77894808, 51.58444208, 37.07357526, 38.46896255, -25.85219779, -24.87734381, -70.37457057, 50.43249284, -27.23589956, 15.16438209, -7.57848307, 51.8551084 , -48.6886877 , 32.01299883, 40.72140371, 80.972393 , -35.07518127, -17.78119553, 39.34605908, -4.76046794, -38.93769592, -23.77003751, 65.38424912, 23.8850437 , -29.74456316, -1.23909667, 57.82701014, 28.17347008, -40.41301902, 28.80041307, -30.24114637, 60.24444437, 2.10366333, -43.12501778, 10.55428238, 38.23987622, -47.16015296, -48.16237844, -57.32631026, 6.33691798, -25.7442763 , 17.04714138, -23.03271097, -8.96047163, -1.87023045, 54.72462854, 3.19335707, -31.64131195, -27.22705391, 22.29742582, 23.61138804, 49.10704885, -24.8754923 , -36.91704928, 12.38877679, 4.08055207, 45.79881797, -37.50100971, 38.62282538, -26.26153064, -49.01655232, 37.78646334, -23.04285147, -29.95861974, -11.6449964 , -40.24481445, 11.62414053, -30.47421415, 27.94622493, -22.23686384, 62.40672959, 16.33260105, 23.76110381, -26.31395976, -66.64809646, -36.62243951, -27.82309004, -14.00368203, -40.61448811, 12.9230184 , 45.6800243 , 65.47625835, 1.16122425, 11.01037317, -43.30341946, -41.9040137 , -14.43580737, 38.82127835, 20.28477807, 35.12639021, 14.40931759, -37.8169393 , -72.34083739, -32.35697973, -36.6538088 , 53.470404 , 21.68445788, 32.49769718, 77.19392928, -32.30976044, -41.92150524, 6.99107347, -51.12425026, 46.78507549, 8.89766523, -60.52803578, -24.04918549, -16.6373317 , 40.2908141 , -26.5307209 , -53.24518946, 43.61553075, 61.48597764, -63.06402925, -4.3270533 , -31.37238341, -31.45601006, 63.52337673, -53.18869129, 71.42562162, -39.1897204 , -32.68257294, 9.86043684, 25.20712718, 3.39672058, -31.1322992 , 3.0897952 , -3.40614618, -5.99703785, 20.35908754, -9.59191016, -2.27703076, -44.46059838, -18.69292011, -31.94060933, -12.36842488, 30.26137453, 21.72625705, -13.54364075, -3.58473544, -21.85948476, -28.27609439, -57.99047579, 20.09640548, 39.67579946, -27.98405187, 55.13828201, 56.28627314, -61.81762049, -40.8813583 , -11.39876947, 43.23313958, -16.3271899 , 18.6434009 , -0.51128019, -46.83382184, -51.8484479 , 14.93449496, -34.01904038, -11.55056046, 46.17882517, 36.49476355, 40.53749066, -1.15169877, 51.46272085, -50.67701516, 27.8372753 , 41.73817159, 6.01057514, 38.13164039, 26.52247499, 63.58400579, 21.74234336, 47.44170072, -29.80429421, -34.67262087, -14.89895486, -67.93546373, -39.22890563, 0.31217101, -40.23964078, -34.11933313, 59.0628537 , -34.91245329, 30.78299281, -31.52986706, -53.83304875, -1.41224738, -25.46321815, 36.33996186, 39.50651902, 28.55828781, 74.90629125, 53.26878327, 2.42631487, 36.28587573, -12.27025163, -9.76157972, -22.38703751, -24.68103046, -27.34116525, -6.02386503, -41.64977773, -38.13604909, 72.41685288, 39.89999992, -13.18027522, -17.60067265, 11.52747384, -6.28892785, 69.86771569, 39.22791764, -28.78637358, 35.57277902, -21.17089764, 47.81399566, -26.69062865, 35.04748679, -9.20538685, 45.59468153, 34.65425882, 30.78715688, 36.0689493 , -11.56148636, -55.87757862, -37.06829207, -9.56148386, 28.82849808, 18.37673634, -1.27595708, -32.26663942, 38.36779111, 32.30128823, -55.57508227, 31.99745088, -23.19356364, -72.46637417, -51.14482711, -10.86912796, 48.13647609, -60.72539282, 2.45533863, -29.17388294, 45.61779517, -14.37359857, 31.75227215, -39.89013703, 3.55927774, 19.83776093, 30.07030434, 7.41018154, -43.18689933, 10.26342951, -7.61327532, -73.12720089, 31.45536305, 37.17635916, 7.07173092, 50.0652342 , -9.93554615, 64.2857025 , 11.53468411, 35.86971591, 17.47591914, 31.72947729, 16.78970992, -42.27561956, 1.80614771, 51.46772266, -46.19689004, -47.55967813, -14.69645242, -54.97476776, -18.29753091, 65.96610732, -37.83579722, -31.56169807, -47.33563413, -40.29899864, -35.41632133, -32.93191145, 45.20109774, -41.45749784, -27.04078829, -43.33095869, 53.61680779, -64.94229977, -34.76624417, 42.28768798, 23.45290467, 16.3465867 , 0.67724883, 27.51083366, 49.87159429, -24.16522193, -9.75554571, -12.80678804, -70.30060575, -29.46223309, -24.47170227, -36.89246423, 27.23931742, -66.65181789, 1.5301565 , -62.83888574, 8.61668011, -20.04844262, -37.04299456, -35.11832964, 43.44939971, 39.15572873, -51.61876087, -44.3915413 , -35.07232821, -28.91726018, 48.42421477, 49.19638958, -34.73398583, -39.00545778, -22.82982052, 72.24406963, 20.02654167, 51.56275454, 29.25185917, -49.11039359, -24.60777447, -66.5570202 , -32.59325784, -49.10695691, -85.13577479, -12.00584302, -53.83843426, 1.42877329, 48.85453576, 17.12500776, -22.38771299, -48.3879276 , 29.54357985, 25.46964225, 78.26997257, 23.99662283, 54.40452953, -33.49594841, 7.85656488, -49.4232303 , 26.16615001, 31.57456331, -21.21313936, 37.81852004, 26.20267414, 24.85227668, 69.85245645, 15.67036335, -36.72167982, 64.04657714, 2.52656631, 37.58401853, 78.56713122, 56.87072853, -39.81569079, 73.59603032, -30.23238357, -71.95125671, 67.0427816 , -52.62471633, -12.18920661, 48.46442331, -46.94717704, -43.00328476, 28.98837851, 28.55740332, -5.41047202, 26.21204539, -66.1678217 , -47.21996179, -7.85490856, -62.92948437, -49.82105363, 44.67508858, -62.63087467, 53.73630623, 16.37086971, -18.64117268, 2.86947484, -41.20599733, -36.9362511 , 35.15567906, 16.10271191, 39.6692552 , -35.63029114, 13.05270523, 59.71764667, 46.08068092, 33.67798463, -17.00735443, -74.8619645 ])
    • local_datetime
      (location, local_time)
      datetime64
      s
      2021-06-01T19:00:00, 2021-06-01T20:00:00, ..., 2021-06-04T19:00:00, 2021-06-04T20:00:00
      Values:
      array([['2021-06-01T19:00:00', '2021-06-01T20:00:00', '2021-06-01T21:00:00', ..., '2021-06-04T16:00:00', '2021-06-04T17:00:00', '2021-06-04T18:00:00'], ['2021-06-02T11:00:00', '2021-06-02T12:00:00', '2021-06-02T13:00:00', ..., '2021-06-05T08:00:00', '2021-06-05T09:00:00', '2021-06-05T10:00:00'], ['2021-06-02T13:00:00', '2021-06-02T14:00:00', '2021-06-02T15:00:00', ..., '2021-06-05T10:00:00', '2021-06-05T11:00:00', '2021-06-05T12:00:00'], ..., ['2021-06-01T20:00:00', '2021-06-01T21:00:00', '2021-06-01T22:00:00', ..., '2021-06-04T17:00:00', '2021-06-04T18:00:00', '2021-06-04T19:00:00'], ['2021-06-01T20:00:00', '2021-06-01T21:00:00', '2021-06-01T22:00:00', ..., '2021-06-04T17:00:00', '2021-06-04T18:00:00', '2021-06-04T19:00:00'], ['2021-06-01T21:00:00', '2021-06-01T22:00:00', '2021-06-01T23:00:00', ..., '2021-06-04T18:00:00', '2021-06-04T19:00:00', '2021-06-04T20:00:00']], dtype='datetime64[s]')
    • local_time
      (location, local_time)
      float64
      s
      6.840e+04, 7.200e+04, ..., 6.840e+04, 7.200e+04
      Values:
      array([[68400., 72000., 75600., ..., 57600., 61200., 64800.], [39600., 43200., 46800., ..., 28800., 32400., 36000.], [46800., 50400., 54000., ..., 36000., 39600., 43200.], ..., [72000., 75600., 79200., ..., 61200., 64800., 68400.], [72000., 75600., 79200., ..., 61200., 64800., 68400.], [75600., 79200., 82800., ..., 64800., 68400., 72000.]])
    • location
      (location)
      vector3
      km
      [-5856.37156922 -2114.21930018 -1350.04807099], [-235.72188253 5725.8499107 2783.65209649], ..., [-4341.11395331 -4274.55318055 -1863.48215742], [ -894.98450231 -1402.53011076 -6149.92301001]
      Values:
      array([[-5856.37156922, -2114.21930018, -1350.04807099], [ -235.72188253, 5725.8499107 , 2783.65209649], [-3387.09408017, 5371.93335908, 509.47686662], ..., [-4523.82399256, -2764.67680521, 3532.87696461], [-4341.11395331, -4274.55318055, -1863.48215742], [ -894.98450231, -1402.53011076, -6149.92301001]])
    • longitude
      (location)
      float64
      deg
      -160.150, 92.357, ..., -135.443, -122.543
      Values:
      array([-160.14981899, 92.3574224 , 122.23211889, -81.80153449, 171.91124451, 72.7161464 , -37.20704648, -54.29222144, -110.84341256, 104.94506402, -125.81801485, 75.76267353, 119.09098459, -116.4475465 , 108.20966195, -23.80127532, 118.55551013, -115.5571894 , -46.29603414, -45.28004709, -138.98911882, 164.34355572, 117.09701761, -81.82431374, -140.66625214, -126.29979589, 61.77681929, 21.94718963, 96.66104609, 171.63235559, 141.80508336, 76.62002553, 46.51289536, -144.1923869 , -160.87229661, 165.52189538, 173.39419193, 153.36178802, 57.07253274, -24.40426006, -163.08264553, -121.51930747, 92.7449727 , 21.68310753, 31.88763619, 162.73946292, -43.5063014 , 69.61987359, -110.41099927, -61.10610138, 54.78291902, 56.29114057, -11.16246919, 90.2058266 , 94.03017639, -88.61653251, 143.6125842 , 112.27738718, -18.36994483, -111.43913799, 149.8603351 , 79.33277077, 117.35070142, -87.0129743 , -147.2368151 , -159.26980006, 52.91050037, 140.60299219, 115.27699291, -65.34882711, -133.30901669, 106.25930911, 45.89829497, -23.46588274, -153.39426896, -44.8938384 , 94.79032527, 132.02539534, -40.73104569, -131.45363335, 70.21716044, 120.79797676, -78.39246194, 161.45186092, -100.01472723, -116.48486467, 145.56470445, -97.24868172, -44.97514188, -0.62864535, 119.12040455, 134.31103921, -155.30794812, -159.70698406, 132.7494109 , 16.32950434, -80.68745579, -56.5877701 , -61.79563518, -54.70999788, -117.54399294, -163.71910302, 133.53576842, 24.32359754, 158.210476 , 41.29741521, 41.60045433, -96.02670368, 26.24886484, 134.55653988, 1.23462127, -38.52022507, 85.39427044, 29.10517375, 167.10872789, -21.43474996, -4.90517002, 45.65255371, 133.1767823 , -179.22983704, 71.32587881, -52.29690507, -36.02135668, 154.42612531, 168.57266425, -144.16236014, 139.42401612, 65.45657641, 92.39801538, 88.13211369, 115.29737953, 140.84620145, 25.38997497, -74.88978474, 133.57038576, -41.0445172 , 121.03501465, -95.58238102, -164.59628301, -131.47908438, 161.76749356, -30.97635666, -13.24799491, -66.52547017, 139.43938328, 16.57471487, 113.17870104, 53.11673607, -157.91917652, 142.11175489, 133.06866962, 35.95716282, 178.85127593, 101.04405832, -148.54642198, -147.03691147, 109.76507796, 36.17972844, 0.84147665, -130.19042425, 57.2869001 , -88.72568903, -129.51996034, -117.30249422, -13.51613828, 47.65499268, -118.29287124, -143.88264697, -146.96554144, -40.5141822 , -46.2856886 , -155.08820614, 53.31804791, 38.31611069, 49.57368486, 71.05472341, -74.13296213, -168.69447474, -136.06689845, -168.2494605 , -109.95234936, 78.98112659, -130.5760193 , -22.20330301, -96.78397448, 56.15430575, 177.57665053, -23.60416554, -59.81627826, -52.10541275, 27.32442612, -154.03769892, 38.27870378, -74.07590893, 147.14639526, 35.10372628, 108.04514832, -126.76869086, 1.50504092, 27.70671018, 127.25888916, 120.53161431, 79.97393636, 114.69797303, 79.38824047, 40.68376478, -149.24223694, 153.77676755, -44.62134964, -130.68156409, 34.86780807, 69.93361141, -8.47150555, -171.89062436, 16.32829691, 46.67667205, 127.72780936, 37.71508389, -94.15778334, -164.92006148, 52.36052989, -131.28328386, 148.15221179, 85.37111793, -128.91916102, 159.65684554, -25.50019937, 125.78115494, 109.17423543, 32.46686578, -93.95248898, 51.42689045, -139.02999703, 107.62302168, 134.24227367, -141.39300654, -42.49433412, -4.65395854, -175.69107239, 32.45921823, 109.5473756 , -13.02644825, 109.35416803, 167.65838826, 90.12773107, 98.91710065, -13.66717855, 132.41313404, 20.77702521, 161.13016557, -59.4456137 , -81.789991 , -15.65674221, -162.66972511, -174.40811465, -37.31437807, -70.0710541 , 141.01297265, -90.00101183, 144.63625233, 22.71710073, 22.52383536, 144.3008391 , -41.34346131, -87.68380523, 99.31973176, -126.84522008, -37.8654398 , -53.90332013, 47.18854446, 60.73403175, -12.32865177, -41.95290135, 99.34421523, -131.45179509, 36.62109773, -90.64600956, 79.79887848, 18.30998175, 46.60942875, -65.19024773, -11.41481829, 58.17619517, 62.37168434, -62.11946007, 11.33572822, -40.41828459, -40.79555951, 88.47950518, -40.71383683, 18.02424378, -28.57522857, 170.39637808, 88.2451182 , 131.86945403, -23.62121974, 37.28486077, -43.46100607, -55.5628352 , -55.52757112, 118.92824632, 156.42649219, 176.90643248, 41.85741337, -13.0196188 , -150.62216943, -56.90351376, -106.40300691, 67.57987752, 132.67511532, -39.83454189, -61.88636455, -123.62859942, -121.98306077, 24.44985984, -132.46141147, -60.95483449, 117.92664511, -84.87484803, 141.94956986, 102.32713065, 178.74332323, -134.64250974, 103.79551978, 65.58647219, 49.75278614, -101.2875424 , -50.9529964 , -27.41359596, -102.78989287, 98.66165768, -122.28292636, -147.72094376, 171.1350737 , -62.6422477 , -80.23702484, 43.55185014, 129.93224599, 24.97663217, -159.87540782, 89.66310074, -138.54578372, 177.77117655, -93.21015996, 168.12313022, -152.39153587, 94.5471878 , 26.42772308, 136.39547856, -85.30044244, -53.3645874 , -61.01464059, 97.18087125, -128.86912939, -153.68297939, -61.205603 , -38.06690821, 97.47921972, 34.26572927, -49.64815313, 38.89258635, -82.85823342, 27.62965255, 5.41319062, 65.93354433, 70.90856173, -57.41591079, 163.22334884, 160.54215712, -131.1549457 , -153.28228337, 103.38574614, 43.71507624, -14.82417579, -100.26222352, -110.84393724, -40.5723686 , 55.22671686, -126.62665659, 137.36097867, -0.38261549, 8.1887923 , 40.11688607, 176.79582585, -33.39303408, 109.18112698, 35.6527063 , -93.32281433, -179.07266385, 66.20665995, 52.47184631, 42.84756159, 47.89541948, 118.54841806, -28.84884108, 32.99732439, 34.4609996 , 5.56499521, 63.10517387, -56.41671755, 96.03150814, 40.35484207, 107.54288238, -165.36460362, -0.3869731 , -56.23921632, 101.78267895, 43.82218629, -14.16469319, -80.24393154, -132.21914798, -22.15301741, 31.7857365 , 47.98894459, -176.39856187, 178.07969248, 121.98159631, -154.84313948, -141.14466976, -82.19765005, -129.76120507, -41.67071346, -44.12254012, -151.19095078, -123.70608537, -69.35505315, 127.15081189, 179.87425797, -128.1269229 , -142.63567625, -25.89632148, -147.38546247, -59.6700398 , 48.34729963, 19.05124305, 7.27278445, -127.42289012, 4.70976367, -125.74067482, 10.43891676, 112.97328602, -37.89880196, 79.84056417, 41.86544411, -11.85736059, -160.94964266, -138.51911716, -156.2063303 , 1.33082787, 130.83245132, 25.46927666, -58.70714316, 37.37076282, 8.865168 , 60.95152532, -57.679833 , 158.16768052, -94.84401455, 179.72944514, -55.9639537 , -60.33968594, -45.59480955, 4.73368042, -134.41824832, -98.68418076, -34.76135003, -77.59033878, 9.87739521, 145.51220898, 69.42495501, -65.60578486, -123.63211851, 93.92156066, -130.93403284, -1.78676646, -102.26702068, -65.6730491 , -62.2237179 , 118.19687464, 90.80069702, -130.10134273, 52.63451909, 45.52401276, -45.1181217 , 55.78272434, 81.41147812, -37.43240121, -72.26864449, 69.81489971, -119.38868101, 44.54299999, 28.03241387, 101.37095657, 128.48356324, -50.86414622, -94.78837891, 151.21705611, 170.36046669, 48.62397701, 52.69086435, -23.88409003, -158.99742231, 89.38262298, -170.75600072, 115.29139022, 18.71086866, 121.64319968, -147.37769571, 140.20178342, 127.02209404, -169.61483036, 126.84500781, 152.84539326, 171.7657333 , -142.19800758, -99.46058131, 63.27146402, -69.74127116, 139.79043051, -161.58353151, -22.66588062, 150.65780419, 0.53715902, -124.03638331, 102.15685253, -124.73504602, 179.62963471, -5.85680124, 19.57953677, -80.4557301 , -133.34616293, 24.27858373, 122.03440879, -105.26724127, 150.21438936, 118.70967949, 123.7549614 , -61.36183493, -8.53388314, 130.52530951, 149.7532946 , -34.44584213, -37.25801535, -77.57834336, -121.68595918, -161.62119564, 51.18252411, -94.5807872 , -34.85134261, -103.33544223, -13.40291382, 2.74808054, 87.75057589, -34.28994197, -99.7794325 , 166.58453532, -30.44847809, 104.54672978, -61.14633389, -120.7695234 , -123.61827363, 51.77200374, -84.51825132, -112.83517372, 130.48528572, -147.26902362, -128.27942179, 121.48082043, -75.87849487, 126.61344416, -175.79693195, -122.07263193, 169.93136917, -17.11160309, 107.38376669, 25.26307221, -38.91720417, 55.66680531, -86.65510109, -110.25194639, -43.15764049, -156.82680591, -23.75479927, -1.54427265, 97.51361548, 40.9750013 , -128.10893144, -65.27225253, -111.7604118 , 12.02657098, -19.51258267, -3.48291669, -2.56686303, 28.2972346 , -36.53918697, 29.26030721, -44.26701983, -45.04776128, 41.73058756, -111.54964044, -57.80910092, -49.44423706, -177.05243035, 100.29875419, -3.95154741, -35.98629062, 50.32306174, 77.06252362, -137.24869493, 74.86939851, 5.00922326, 162.11819747, 77.73517257, 42.31832579, -55.178784 , -159.1954837 , 52.70569083, 131.74699695, -73.77084419, 98.99103199, -71.34275777, -46.6461038 , -127.32172967, -173.48107008, 156.35746669, 69.62398468, 72.15669639, 166.57916573, -36.74424947, -73.20127942, 145.382708 , -49.80587137, -22.3614247 , 57.09335365, 129.86562866, 14.29239552, -132.04127749, 60.02618837, 51.20627778, 159.19682703, -0.37983517, -99.70280958, 55.75712245, 153.24954456, -6.73311603, 143.75110367, -18.99220147, -94.08462247, -43.35614835, -171.51622471, -165.96240472, 109.44623389, 122.89778453, 113.1276007 , 103.87438381, -112.43095247, -71.41700762, 129.41218117, -132.38086272, 41.80850001, -144.91962779, -144.43447641, 163.04541851, 129.44739871, 117.4588028 , 148.49126447, 79.0655588 , 130.88832212, -146.41063837, -160.34327029, -39.24411976, 64.97242991, -102.75051488, -151.19806841, 119.87367116, -122.5801941 , -38.50960029, -132.41112751, 9.07442859, 51.74202886, -31.79827022, -104.47544244, 25.6607356 , 21.67448102, 162.37264588, -10.0432212 , 30.73318797, -124.8634992 , 61.87500829, -49.15048192, 13.68772732, 37.86665825, 1.95852203, -41.80686654, -100.05474177, -9.13443356, 127.80867796, 103.10694089, -118.36257339, 84.64181614, -50.97132997, 92.3576386 , -177.2254763 , -175.16846029, -133.78175778, -48.04469325, 160.51917777, 27.29770237, 49.91763526, 68.79094149, 87.99424754, -91.09433008, 51.75541254, -40.3584817 , 5.18979691, -137.42551786, 98.70643007, 47.37897673, -147.6723143 , -133.68533205, 38.61502681, -7.91599432, 119.41709821, 5.73066163, 17.03209697, 5.39826946, -115.68608294, -27.58387831, 161.58920739, 51.68250558, 64.86084435, -30.65473385, -142.75834683, 175.0488853 , -134.33183088, 79.66145268, 56.00943177, -131.69780241, 158.51374554, 144.54104382, 35.1236251 , 150.23105592, 139.03674096, -179.37587059, 135.32485405, 174.43162693, -51.11202261, -157.34968831, 102.12762365, 66.40743817, -71.47544787, 162.924395 , 82.40688091, -112.56499257, -153.82361978, -19.81964114, 165.88366531, 144.59548256, -135.73237483, 42.76051971, -72.86489143, -27.67215677, -112.66744157, -48.48757218, 149.39965827, -116.67627537, 4.59997213, -102.80878127, 37.48122681, 174.15782514, 27.54035784, 105.7712752 , -147.94519414, -171.08729355, 120.50365659, -68.40103753, -149.78295529, -165.21094746, 4.06232404, 151.48007979, -56.14526185, 102.58135246, -117.58300987, 111.37159955, 82.11250465, 116.85401788, 149.41523615, 87.59890317, 140.84096524, -81.89226576, 170.12521852, 109.55281777, -51.68319522, -20.61937767, -93.71628312, -3.10080896, 37.22409002, 145.76138306, 44.45185631, -137.69166516, 36.60299241, -50.46869731, -39.00977706, -36.25211087, -140.8171797 , 145.64506852, 49.17105365, -158.17443318, 68.49392957, -174.97311633, -175.42166269, -167.94252585, 128.60306622, -8.13784885, -31.57607142, -122.54599072, 135.74211466, 14.8821488 , -53.63704549, -131.99102372, 140.62356528, -156.20808745, 161.11334419, 80.81034254, 139.4267055 , -131.3284085 , -23.38954937, -134.69426523, 73.3685942 , 70.71670104, -127.67321102, -50.5304573 , 35.84132352, -5.05926818, -137.31307165, 30.80547186, 46.39290881, 90.25841056, 66.06811683, -124.09374007, 89.0672589 , 32.14525067, 99.26306653, -159.29472702, 173.66235099, -146.99159471, -124.73414424, 168.84659098, 85.42305122, 171.82499791, 11.52247486, 120.14864871, 164.76653292, -140.2181039 , 109.3808975 , -31.41835892, 30.53160854, 168.36032466, -59.61016005, -25.94613684, -26.34660144, 57.02550382, 32.64677197, -159.63806233, 138.4131793 , 26.90503938, -63.77162527, 43.52398462, -159.20784931, -138.22707211, -47.84428187, 46.91345722, 119.77901314, 57.28761773, 64.9243887 , -133.68987219, 30.9506445 , -118.13007039, -2.83722537, -41.07753024, 36.93185921, 53.17375714, 121.95664343, 104.86793238, 33.30426786, -168.21214274, 68.60034727, 52.05003211, -161.09622829, 85.84891174, 150.54579568, -23.84800971, 67.58475103, 47.51237334, 47.08234647, -135.48836681, -122.97140493, -116.26296584, -27.91112655, -47.483859 , 65.973649 , 53.06454573, 15.23483015, -35.3022441 , -30.07281807, 90.64442807, 58.20677241, 148.49136273, -151.24917441, -80.77096937, -89.51168673, 46.61639339, 82.85110463, 104.09972828, 82.80700622, 143.66179724, -88.53170625, 30.01469128, 40.9180374 , 5.21367883, 169.86491675, 139.46498488, -131.78649645, 46.50691725, -84.19400331, 84.43279938, 174.52148001, 25.78998369, 140.82287865, 3.65693056, -178.35993573, 79.42882445, 42.51593193, -129.50757155, 155.52432535, -140.4082003 , 133.0417688 , 160.66300669, 124.49090227, -118.84255799, 124.9566966 , -164.79355655, -58.65148349, -142.01349794, 129.14321215, -97.98255332, 35.85727497, -106.94975379, -53.60245827, -131.9398018 , -8.98173069, 19.89978662, -87.84675704, -133.94511036, 146.46431615, -45.06911498, -65.48414173, -130.54333856, 25.17129238, 114.68460854, -91.52031897, 36.58032201, 96.83762208, -121.06207175, -166.57235862, -104.5857302 , -130.96010036, 59.6032244 , -59.58301289, -2.21826734, -133.13019244, 152.65164829, 108.77301125, 159.62725835, 43.96815519, -33.84644488, -4.90900687, 49.8034874 , 167.8310832 , -60.49303593, -0.90948713, -65.91311729, 141.4852596 , 25.35543444, -81.79021895, 60.31544635, 30.80674762, 52.36997073, 3.36794382, 145.28652696, -11.65844158, 34.57752124, 105.4436081 , -40.76754573, 167.65474754, 109.07383287, 38.28933208, -148.56934904, -135.44263264, -122.5428195 ])
    • (location, local_time)
      float64
      counts
      4.101, 4.288, ..., 4.267, 3.178
      Values:
      array([[4.10057244, 4.28817869, 3.98988822, ..., 4.63683272, 4.48209122, 4.85176277], [4.68011366, 4.8665567 , 5.11758422, ..., 3.12319908, 3.74648651, 4.66549553], [5.62566505, 6.07238702, 5.79976953, ..., 4.35416939, 5.15601354, 5.55128796], ..., [6.43612422, 5.77539914, 5.66281152, ..., 6.15638901, 6.02070382, 6.46670194], [4.02808088, 3.26180026, 2.69455495, ..., 4.29036918, 4.15678654, 4.26156147], [4.01675088, 3.5045501 , 2.25948342, ..., 4.38028896, 4.26652895, 3.1782028 ]])

In the above:

  • latitude and local_time coordinates have been computed as requested.

  • The intermediate results local_datetime and longitude were preserved as unaligned coordinates (use keep_intermediate=False to drop them).

  • The location and datetime coordinates (which have been consumed by the transformation) have been converted to unaligned coordinates (use keep_inputs=False to drop them).

  • The datetime dimension has been consumed by the local_time coordinate and thus renamed to local_time (use rename_dims=False to disable). For more details see section Renaming of Dimensions.

Post-processing#

In some cases the above result may be all we need. Frequently however, we may need to resample or bin our data after this coordinate transformation.

In the above case, local_time is now a 2-D coordinate, and the coordinate is not ordered since the “date” component of the datetime has been removed. We may thus want to bin this data into latitude/local_time bins. Here we first use flatten with a dummy dimension to make the data suitable for sc.bin:

[14]:
time_edges = sc.linspace(dim='local_time', unit='s', start=0, stop=24 * 60 * 60, num=6)
latitude = sc.linspace(dim='latitude', unit='deg', start=-90, stop=90, num=13)
binned = sc.bin(transformed.flatten(to='dummy'), latitude=latitude, local_time=time_edges)

The result looks as follows. If this was real data (the sample data is fake!) we might observe that there are more lightning strikes on the northern hemisphere as well as later in the day. This might be attributed to more thunderstorms after hot summer days. Note that this example does not represent reality and is merely meant to illustrate several concepts of transform_coords:

[15]:
binned.hist(latitude=36, local_time=24).plot()
[15]:
../_images/user-guide_coordinate-transformations_29_0.svg

Renaming of Dimensions#

This section is somewhat advanced and not required to understand the basic usage of transform_coords.

As shown above, transform_coords can rename dimensions of the data array if it processes dimension-coordinates. The rules controlling it are described in this section. They are generic and tend to favor not renaming a dimension if it is not entirely clear what the new name should be.

A dimension is only renamed if its dimension-coordinate can be uniquely associated with one output coordinate of transform_coords. In the example above, there are two dimension-coordinates in the input, datetime and location. The latter is used to compute two new coordinates, namely longitude and latitude. It is thus not possible to find a unique new name for the location dimension. datetime on the other hand is used to construct only a single coordinate, local_datetime, which is finally transformed into local_time. The datetime dimension is therefore renamed to local_time.

Identifying outputs with dimension-coordinates can be expressed as a graph-coloring problem. We assign a unique color to each dimension-coordinate (coordinate name matching a dimension of the coordinate); other coordinates are left uncolored (black). We then propagate colors through the directed graph using the following rules

  1. If a node has exactly one colored parent, use that parent’s color (graph 1).

  2. If a node has several colored parents, leave the node black (graph 2). The same happens if no parent is colored.

  3. If a node has more than one child, it is not counted for rules 1 and 2; its color is not applied to its children (graph 3). Other colored nodes are free to apply their color to shared children (graph 4). It makes no difference if the children are computed by the same function or from multiple functions.

base rules

All graphs used by transform_coords are directed acyclic graphs, but they can still have undirected cycles. In those cases, it can be possible to identify an output with a dimension-coordinate even when it has multiple children as part of a cycle.

  1. If a cycle has one and only one colored node as input (w.r.t. directions of the edges) and exactly one output, that output takes the color of the input. In example 1 below, a can be uniquely associated with c. But example 2, this is not possible because there are two final nodes that depend on a.

cycle rules

The following graphs illustrate how the rules interact in larger examples. In particular, it shows that dimensions are renamed to the ‘farthest away’ coordinate even if that is not a final result of the transformation.

  • In graph 1, a is renamed to c because of rule 1. d is renamed to f because of the second part of rule 3. g cannot be renamed because rule 2 applies to its only child, h.

  • In graph 2, a is renamed to h because c and h can be associated with each other through the cycle according to rule 4.

  • This is no longer the case when d is also a dimension-coordinate (graph 3). Like in example 1, a is renamed to c and d to f. But h depends on f directly and c through the cycle and can therefore not be associated with a single dimension.

larger examples

More details on how the algorithm works and the rationale behind it can be found in Architecture Decision Record 0011.