我需要Matlab(Octave)的Python/Numpy等价离散拉普拉斯算子(函数)del2()。我尝试了几个Python解决方案,其中没有一个与del2的输出相匹配。在八音我Python中的离散拉普拉斯算子(del2等价)
image = [3 4 6 7; 8 9 10 11; 12 13 14 15;16 17 18 19]
del2(image)
这给
0.25000 -0.25000 -0.25000 -0.75000
-0.25000 -0.25000 0.00000 0.00000
0.00000 0.00000 0.00000 0.00000
0.25000 0.25000 0.00000 0.00000
Python的我试过
import numpy as np
from scipy import ndimage
import scipy.ndimage.filters
image = np.array([[3, 4, 6, 7],[8, 9, 10, 11],[12, 13, 14, 15],[16, 17, 18, 19]])
stencil = np.array([[0, 1, 0],[1, -4, 1], [0, 1, 0]])
print ndimage.convolve(image, stencil, mode='wrap')
其给出结果
[[ 23 19 15 11]
[ 3 -1 0 -4]
[ 4 0 0 -4]
[-13 -17 -16 -20]]
我也试过
结果scipy.ndimage.filters.laplace(image)
这给出结果
[[ 6 6 3 3]
[ 0 -1 0 -1]
[ 1 0 0 -1]
[-3 -4 -4 -5]]
所以任何输出的似乎与海誓山盟。 Octave代码del2.m表明它是拉普拉斯算子。我错过了什么吗?
在内部,操作员都具有相同的实现(matlab显然除以4,其中Python不会)。在边界上,通过向`laplace()`提供'mode ='wrap'`,你可以使两个Python版本相同。但通过查看Matlab结果,我不知道Matlab在边界上做了什么。 – 2011-01-15 00:32:27
实际上它在边缘做立方外推: http://www.mathworks.it/it/help/matlab/ref/del2.html 所以,如果你尝试使用laplace()的最后一个例子,也可以在边界上获得正确的结果。 – astrojuanlu 2013-04-08 17:33:41