LoG函数可视化的Matlab实现
2021-04-10 本文已影响0人
北欧森林
Matlab 上运行:
N = 4;
x=linspace(-N, N,30);
[X,Y]=meshgrid(x,x);
z=del2((1000/sqrt(2*pi).*exp(-(X.^2/2)-(Y.^2/2))));
surf(X,Y,z);
Output:
data:image/s3,"s3://crabby-images/e0bd8/e0bd84537c292ef8ca22ae57827b1336b5b26332" alt=""
或者:
laplace_gaussian_filter = fspecial('log',[50 50],5);
subplot(121)
surf(laplace_gaussian_filter);
subplot(122)
surf(-laplace_gaussian_filter);
Output:
data:image/s3,"s3://crabby-images/46815/4681573a24d40388602b0a224236f4c90e4052ca" alt=""
俭朴版:
x = linspace(-4,4,41);
G = exp(-x.^2/2)/sqrt(2*pi);
Gxx = G .* (x.^2-1);
data = G .* Gxx.';
data = data + data.';
surf(x,x,data,'facecolor','white')
view(45,13)
set(gca,'dataaspectratio',[1,1,0.08])
grid off
xlabel('X')
ylabel('Y')
Output:
data:image/s3,"s3://crabby-images/6b75a/6b75a06af88d15134c0663aa79b836a270d28b2b" alt=""
参考资料
How to graph/plot 2D Laplacian of Gaussian (LoG) function in MATLAB or python?