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]:
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]:
- x: 100
- x(x)float64m1.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)float64m^21.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)float64m^21.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]:
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]:
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]:
- x^2: 100
- x(x^2)float64m1.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)float64m^21.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)float64m^21.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:
Extract latitude and longitude information from the sensor locations.
Compute the local datetime from the datetime and a “timezone” offset from the longitude.
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]:
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]:
- location: 1000
- datetime: 72
- datetime(datetime)datetime64s2021-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)vector3km[-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)float64counts4.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]:
- location: 1000
- local_time: 72
- datetime(local_time)datetime64s2021-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)float64deg-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)datetime64s2021-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)float64s6.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)vector3km[-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)float64deg-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)float64counts4.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
andlocal_time
coordinates have been computed as requested.The intermediate results
local_datetime
andlongitude
were preserved as unaligned coordinates (usekeep_intermediate=False
to drop them).The
location
anddatetime
coordinates (which have been consumed by the transformation) have been converted to unaligned coordinates (usekeep_inputs=False
to drop them).The
datetime
dimension has been consumed by thelocal_time
coordinate and thus renamed tolocal_time
(userename_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]:
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
If a node has exactly one colored parent, use that parent’s color (graph 1).
If a node has several colored parents, leave the node black (graph 2). The same happens if no parent is colored.
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.
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.
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 withc
. But example 2, this is not possible because there are two final nodes that depend ona
.
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 toc
because of rule 1.d
is renamed tof
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 toh
becausec
andh
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 toc
andd
tof
. Buth
depends onf
directly andc
through the cycle and can therefore not be associated with a single dimension.
More details on how the algorithm works and the rationale behind it can be found in Architecture Decision Record 0011.