Skip to content

Commit

Permalink
add parameter coarsen to Topography.crop to allow coarsening of a gri…
Browse files Browse the repository at this point in the history
…d by sampling every points, defaults to 1. Also allow filter_region=None to use entire region when coarsening.
  • Loading branch information
rjleveque committed Jun 4, 2016
1 parent 2336a94 commit 20f3942
Showing 1 changed file with 9 additions and 5 deletions.
14 changes: 9 additions & 5 deletions src/python/geoclaw/topotools.py
Original file line number Diff line number Diff line change
Expand Up @@ -1420,7 +1420,7 @@ def smooth_data(self, indices, r=1):
self.Z[index[0], index[1]] = summation / num_points


def crop(self, filter_region):
def crop(self, filter_region=None, coarsen=1):
r"""Crop region to *filter_region*
Create a new Topography object that is identical to this one but cropped
Expand All @@ -1435,6 +1435,10 @@ def crop(self, filter_region):
if self.unstructured:
raise NotImplemented("*** Cannot currently crop unstructured topo")

if filter_region is None:
# only want to coarsen, so this is entire region:
filter_region = [self.x[0],self.x[-1],self.y[0],self.y[-1]]

# Find indices of region
region_index = [None, None, None, None]
region_index[0] = (self.x >= filter_region[0]).nonzero()[0][0]
Expand All @@ -1443,17 +1447,17 @@ def crop(self, filter_region):
region_index[3] = (self.y <= filter_region[3]).nonzero()[0][-1] + 1
newtopo = Topography()

newtopo._x = self._x[region_index[0]:region_index[1]]
newtopo._y = self._y[region_index[2]:region_index[3]]
newtopo._x = self._x[region_index[0]:region_index[1]:coarsen]
newtopo._y = self._y[region_index[2]:region_index[3]:coarsen]

# Force regeneration of 2d coordinate arrays and extent if needed
newtopo._X = None
newtopo._Y = None
newtopo._extent = None

# Modify Z array as well
newtopo._Z = self._Z[region_index[2]:region_index[3],
region_index[0]:region_index[1]]
newtopo._Z = self._Z[region_index[2]:region_index[3]:coarsen,
region_index[0]:region_index[1]:coarsen]

newtopo.unstructured = self.unstructured
newtopo.topo_type = self.topo_type
Expand Down

0 comments on commit 20f3942

Please sign in to comment.