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
Dataobject (which includesnumpyandDataobjects). 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 is360thenvalue=0implies transformed coordinates of0, 5, ..., 355;value=-12implies transformed coordinates of-10, -5, ..., 345;value=380implies transformed coordinates of380, 385, ..., 715.- Parameter example:
If the original dimension coordinates are
355, 350, ..., 0(evenly spaced) and the period is360thenvalue=355implies transformed coordinates of355, 350, ..., 0;value=0implies transformed coordinates of0, -5, ..., -355;value=392implies 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>