python中grid_python – 基于单元格区域的Regrid numpy数组

import numpy as np

from skimage.measure import block_reduce

arr = np.random.random((6, 6))

area_cell = np.random.random((6, 6))

block_reduce(arr, block_size=(2, 2), func=np.ma.mean)

我想重新调整一个从6 x 6大小到3 x 3的numpy数组arr.使用skimage函数block_reduce.

但是,block_reduce假设每个网格单元具有相同的大小.当每个网格单元具有不同的大小时,如何解决此问题?在这种情况下,每个网格单元的大小由numpy数组area_cell给出

– 编辑:

一个例子:

ARR

0.25 0.58 0.69 0.74

0.49 0.11 0.10 0.41

0.43 0.76 0.65 0.79

0.72 0.97 0.92 0.09

如果area_cell的所有元素都是1,我们将4 x 4 arr转换为2 x 2,结果将是:

0.36 0.48

0.72 0.61

但是,如果area_cell如下:

0.00 1.00 1.00 0.00

0.00 1.00 0.00 0.50

0.20 1.00 0.80 0.80

0.00 0.00 1.00 1.00

然后,结果变为:

0.17 0.22

0.21 0.54

最佳答案 看起来你仍在减少块数,但在使用area_cell缩放之后.所以,你只需要在这两个数组之间执行逐元素乘法,并在该产品数组上使用相同的block_reduce代码,就像这样 –

block_reduce(arr*area_cell, block_size=(2, 2), func=np.ma.mean)

或者,我们可以在重新塑造到产品阵列的4D版本之后简单地使用np.mean,就像这样 –

m,n = arr.shape

out = (arr*area_cell).reshape(m//2,2,n//2,2).mean(axis=(1,3))

样品运行 –

In [21]: arr

Out[21]:

array([[ 0.25, 0.58, 0.69, 0.74],

[ 0.49, 0.11, 0.1 , 0.41],

[ 0.43, 0.76, 0.65, 0.79],

[ 0.72, 0.97, 0.92, 0.09]])

In [22]: area_cell

Out[22]:

array([[ 0. , 1. , 1. , 0. ],

[ 0. , 1. , 0. , 0.5],

[ 0.2, 1. , 0.8, 0.8],

[ 0. , 0. , 1. , 1. ]])

In [23]: block_reduce(arr*area_cell, block_size=(2, 2), func=np.ma.mean)

Out[23]:

array([[ 0.1725 , 0.22375],

[ 0.2115 , 0.5405 ]])

In [24]: m,n = arr.shape

In [25]: (arr*area_cell).reshape(m//2,2,n//2,2).mean(axis=(1,3))

Out[25]:

array([[ 0.1725 , 0.22375],

[ 0.2115 , 0.5405 ]])

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
numpy数组元素周围的操作可以通过以下几种方式实现: 1. 切片操作:可以使用numpy数组的切片操作来获取数组元素的周围元素。 例如,对于一个二维数组arr,要获取第i行第j列元素周围的元素,可以使用如下切片操作: ```python arr[i-1:i+2, j-1:j+2] ``` 这将返回一个3x3的子数组,其心元素为arr[i,j],周围的8个元素为该子数组的其余元素。 2. 使用numpy.pad()函数:numpy.pad()函数可以用来在数组的边缘添加一个或多个值,从而扩展数组的大小。可以使用该函数来添加额外的行和列,然后通过索引访问周围的元素。 例如,对于一个二维数组arr,要获取第i行第j列元素周围的元素,可以使用如下代码: ```python padded_arr = np.pad(arr, ((1, 1), (1, 1)), mode='constant') surrounding = padded_arr[i:i+3, j:j+3] ``` 这将在数组的边缘添加一行和一列,并使用常量值填充这些额外的元素。然后可以使用切片操作来获取心元素周围的元素。 3. 使用numpy.roll()函数:numpy.roll()函数可以用来沿着给定轴滚动数组的元素。可以使用该函数来将数组的行和列进行滚动,从而获取周围的元素。 例如,对于一个二维数组arr,要获取第i行第j列元素周围的元素,可以使用如下代码: ```python rows, cols = arr.shape row_indices = np.arange(i-1, i+2) % rows col_indices = np.arange(j-1, j+2) % cols surrounding = arr[row_indices][:, col_indices] ``` 这将将第i行向上和向下滚动一行,并将第j列向左和向右滚动一列,从而获取心元素周围的元素。使用模运算可以确保在数组的边缘滚动时正确处理索引。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值