cf.Domain.anchor¶
-
Domain.
anchor
(*args, **kwargs)[source]¶ Roll a cyclic axis so that the given value lies in the first coordinate cell.
A unique axis is selected with the axes and kwargs parameters.
New in version 3.9.0.
- Parameters
- axis:
The cyclic axis to be anchored.
domain axis selection TODO.
- value:
Anchor the dimension coordinate values for the selected cyclic axis to the value. May be any numeric scalar object that can be converted to a
Data
object (which includesnumpy
andData
objects). If value has units then they must be compatible with those of the dimension coordinates, otherwise it is assumed to have the same units as the dimension coordinates. The coordinate values are transformed so that value is “equal to or just before” the new first coordinate value. More specifically:Increasing dimension coordinates with positive period, P, are transformed so that value lies in the half-open range (L-P, F], where F and L are the transformed first and last coordinate values, respectively.
Decreasing dimension coordinates with positive period, P, are transformed so that value lies in the half-open range (L+P, F], where F and L are the transformed first and last coordinate values, respectively.
- Parameter example:
If the original dimension coordinates are
0, 5, ..., 355
(evenly spaced) and the period is360
thenvalue=0
implies transformed coordinates of0, 5, ..., 355
;value=-12
implies transformed coordinates of-10, -5, ..., 345
;value=380
implies transformed coordinates of380, 385, ..., 715
.- Parameter example:
If the original dimension coordinates are
355, 350, ..., 0
(evenly spaced) and the period is360
thenvalue=355
implies transformed coordinates of355, 350, ..., 0
;value=0
implies transformed coordinates of0, -5, ..., -355
;value=392
implies transformed coordinates of390, 385, ..., 30
.
- inplace:
bool
, optional If True then do the operation in-place and return
None
.- dry_run:
bool
, optional Return a dictionary of parameters which describe the anchoring process. The construct is not changed, even if inplace is True.
- i: deprecated at version 3.0.0
Use the inplace parameter instead.
kwargs: deprecated at version 3.0.0
- Returns
Examples
>>> f.iscyclic('X') True >>> f.dimension_coordinate('X').data <CF Data(8): [0, ..., 315] degrees_east> TODO >>> print(f.dimension_coordinate('X').array) [ 0 45 90 135 180 225 270 315] >>> g = f.anchor('X', 230) >>> print(g.dimension_coordinate('X').array) [270 315 0 45 90 135 180 225] >>> g = f.anchor('X', cf.Data(590, 'degreesE')) >>> print(g.dimension_coordinate('X').array) [630 675 360 405 450 495 540 585] >>> g = f.anchor('X', cf.Data(-490, 'degreesE')) >>> print(g.dimension_coordinate('X').array) [-450 -405 -720 -675 -630 -585 -540 -495]
>>> f.iscyclic('X') True >>> f.dimension_coordinate('X').data <CF Data(8): [0.0, ..., 357.1875] degrees_east> >>> f.anchor('X', 10000).dimension_coordinate('X').data <CF Data(8): [10001.25, ..., 10358.4375] degrees_east> >>> d = f.anchor('X', 10000, dry_run=True) >>> d {'axis': 'domainaxis2', 'nperiod': <CF Data(1): [10080.0] 0.0174532925199433 rad>, 'roll': 28} >>> (f.roll(d['axis'], d['roll']).dimension_coordinate( ... d['axis']) + d['nperiod']).data <CF Data(8): [10001.25, ..., 10358.4375] degrees_east>