matlab的grayscale,Python 是否等效于Matlab函数“imfill”的grayscale??

小编典典

此处已在Python中实现了洪水填充算法的两个版本:

第一个简单的变量包含两个未定义的变量,但这是一个

有效的版本:

import numpy as np

import scipy as sp

import scipy.ndimage

def flood_fill(test_array,h_max=255):

input_array = np.copy(test_array)

el = sp.ndimage.generate_binary_structure(2,2).astype(np.int)

inside_mask = sp.ndimage.binary_erosion(~np.isnan(input_array), structure=el)

output_array = np.copy(input_array)

output_array[inside_mask]=h_max

output_old_array = np.copy(input_array)

output_old_array.fill(0)

el = sp.ndimage.generate_binary_structure(2,1).astype(np.int)

while not np.array_equal(output_old_array, output_array):

output_old_array = np.copy(output_array)

output_array = np.maximum(input_array,sp.ndimage.grey_erosion(output_array, size=(3,3), footprint=el))

return output_array

2021-01-20

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值