-
Notifications
You must be signed in to change notification settings - Fork 13
/
Copy pathextract_grid.py
74 lines (64 loc) · 2.61 KB
/
extract_grid.py
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
69
70
71
72
73
74
# remove part of the grid
ds = netCDF4.Dataset(path.with_name('pillar_net.nc'))
variables = {}
node_vars = ['NetNode_x', 'NetNode_y', 'NetNode_z', 'NetNode_lat', 'NetNode_lon']
link_vars = ['NetLink', 'NetLinkType']
bndlink_vars = ['BndLink']
elem_vars = ['NetElemNode']
for var in node_vars:
# copy data
variables[var] = ds.variables[var][:]
node_selection = np.logical_and(variables['NetNode_y'] >= 1000, variables['NetNode_y'] <= 2000)
for var in node_vars:
variables[var] = variables[var][node_selection]
for var in link_vars:
variables[var] = ds.variables[var][:]
# lookup nodes that are still available
node_idx_1 = np.where(node_selection)[0] + 1
# look which links are still available
from_filter = np.in1d(variables['NetLink'][:, 0], node_idx_1)
to_filter = np.in1d(variables['NetLink'][:, 1], node_idx_1)
# assume three grids are not connected
assert (from_filter == to_filter).all()
# otherwise we would have to transform into boundary links on removal of link
link_selection = np.logical_and(from_filter, to_filter)
for var in link_vars:
variables[var] = variables[var][link_selection]
for var in bndlink_vars:
variables[var] = ds.variables[var][:]
variables['BndLink']
bndlink_selection = np.in1d(variables['BndLink'], node_idx_1)
for var in bndlink_vars:
variables[var] = variables[var][bndlink_selection]
for var in elem_vars:
variables[var] = ds.variables[var][:]
variables['NetElemNode']
net_elem_node = np.ma.masked_equal(variables['NetElemNode'], -2147483647)
elem_selection = np.apply_along_axis(np.ma.in1d, 0, net_elem_node, node_idx_1)
elem_selection = np.ma.masked_array(elem_selection, mask=net_elem_node.mask)
# assume all cells are all in, or all out
assert (elem_selection.all(axis=1) == elem_selection.any(axis=1)).all()
elem_selection = elem_selection.all(axis=1)
for var in elem_vars:
variables[var] = variables[var][elem_selection]
dims = {
'nNetNode': node_selection.sum(),
'nNetLink': link_selection.sum(),
'nNetLinkPts': 2,
'nBndLink': bndlink_selection.sum(),
'nNetElem': elem_selection.sum(),
'nNetElemMaxNode': 4
}
ds_new = netCDF4.Dataset(path.with_name('pillar_new.nc'), mode='w')
# copy attributes
for attr in ds.ncattrs():
ds_new.setncattr(attr, ds.getncattr(attr))
for dim, length in dims.items():
ds_new.createDimension(dim, length)
for name, var in ds.variables.items():
new_var = ds_new.createVariable(name, var.dtype, var.dimensions)
for attr in var.ncattrs():
new_var.setncattr(attr, var.getncattr(attr))
for name in ds.variables.keys():
ds_new.variables[name][:] = variables.get(name, ds.variables[name][:])
ds_new.close()