Chr*_*ina 4 matlab image-processing computer-vision
我试图创建一个Gabor过滤器.我们都知道这种滤波器比任何其他滤波器更复杂,因为它具有更复杂的特征,例如具有不同的尺度和方向.Gabor滤波器的等式是:

为了创建具有特定比例和方向的Gabor滤波器,维基百科向我们提供了一个简单的matlab代码:
sigma_x = sigma;
sigma_y = sigma/gamma;
nstds = 3;
xmax = max(abs(nstds*sigma_x*cos(theta)),abs(nstds*sigma_y*sin(theta)));
xmax = ceil(max(1,xmax));
ymax = max(abs(nstds*sigma_x*sin(theta)),abs(nstds*sigma_y*cos(theta)));
ymax = ceil(max(1,ymax));
xmin = -xmax; ymin = -ymax;
[x,y] = meshgrid(xmin:xmax,ymin:ymax);
x_theta=x*cos(theta)+y*sin(theta);
y_theta=-x*sin(theta)+y*cos(theta);
gb= exp(-.5*(x_theta.^2/sigma_x^2+y_theta.^2/sigma_y^2)).*cos(2*pi/lambda*x_theta+psi);
Run Code Online (Sandbox Code Playgroud)
我想知道这段代码是否正确.我注意到上面的代码并没有完全响应Gabor滤波器的等式.例如:在代码中,我们有:sigma_x=sigma和sigma_y=sigma/gamma......我们有gb=exp(-.5*(x_theta.....)).我不明白5这个等式是什么..
上面写的matlab代码是否正确地响应了Gabor滤波器的等式?我需要您的意见,如果可能的话,如果不正确则优化代码.
任何帮助将不胜感激.
替换代码中的以下行:
gb= exp(-.5*(x_theta.^2/sigma_x^2+y_theta.^2/sigma_y^2)).*cos(2*pi/lambda*x_theta+psi);
Run Code Online (Sandbox Code Playgroud)
我在上面的matlab代码中用sin替换了cos.