forked from UXARRAY/uxarray
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathtest_azimuthal.py
More file actions
68 lines (47 loc) · 2.12 KB
/
test_azimuthal.py
File metadata and controls
68 lines (47 loc) · 2.12 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
import pytest
import uxarray as ux
import numpy as np
def test_gaussian(gridpath, datasetpath):
uxds = ux.open_dataset(
gridpath("mpas", "dyamond-30km", "gradient_grid_subset.nc"),
datasetpath("mpas", "dyamond-30km", "gradient_data_subset.nc")
)
res = uxds['gaussian'].azimuthal_mean(center_coord=(45, 0), outer_radius=2, radius_step=0.5)
# Expects decreasing values from center
valid_vals = res[1:]
np.testing.assert_array_less(
valid_vals.diff("radius").values, 1e-12
)
def test_inverse_gaussian(gridpath, datasetpath):
uxds = ux.open_dataset(
gridpath("mpas", "dyamond-30km", "gradient_grid_subset.nc"),
datasetpath("mpas", "dyamond-30km", "gradient_data_subset.nc")
)
res = uxds['inverse_gaussian'].azimuthal_mean(center_coord=(45, 0), outer_radius=2, radius_step=0.5)
# Expects increasing values from center
atol = 1e-12
diffs = res[1:].diff("radius").values
diffs = diffs[np.isfinite(diffs)]
np.testing.assert_array_less(-atol, diffs)
def test_non_zero_hit_counts(gridpath, datasetpath):
uxds = ux.open_dataset(
gridpath("mpas", "dyamond-30km", "gradient_grid_subset.nc"),
datasetpath("mpas", "dyamond-30km", "gradient_data_subset.nc")
)
res, hit_counts = uxds['inverse_gaussian'].azimuthal_mean(center_coord=(45, 0), outer_radius=2, radius_step=0.5, return_hit_counts=True)
# At least one hit after the first circle
assert np.all(hit_counts[1:] > 1)
assert 'radius' in hit_counts.dims
assert hit_counts.sizes['radius'] == res.sizes['radius']
def test_zero_hit_counts(gridpath, datasetpath):
uxds = ux.open_dataset(
gridpath("mpas", "dyamond-30km", "gradient_grid_subset.nc"),
datasetpath("mpas", "dyamond-30km", "gradient_data_subset.nc")
)
# Outside of grid domain
res, hit_counts = uxds['inverse_gaussian'].azimuthal_mean(center_coord=(-45, 0), outer_radius=2, radius_step=0.5, return_hit_counts=True)
assert 'radius' in hit_counts.dims
assert hit_counts.sizes['radius'] == res.sizes['radius']
# No hits
assert np.all(hit_counts == 0)
print(res)