java – OpenCV中的Gabor内核参数
发布时间:2020-12-15 04:23:36 所属栏目:Java 来源:网络整理
导读:我必须在我的应用程序中使用Gabor过滤器,但我对这个OpenCV方法参数值没有任何线索. 我想编码一个虹膜.开始Gabor滤波器并获取特征(我想对12组Gabor参数值执行此操作).然后我想算一个汉明dystans并做认证. 如果有人可以在这里写params范围,或者如何在函数中计
我必须在我的应用程序中使用Gabor过滤器,但我对这个OpenCV方法参数值没有任何线索.
我想编码一个虹膜.开始Gabor滤波器并获取特征(我想对12组Gabor参数值执行此操作).然后我想算一个汉明dystans并做认证. 如果有人可以在这里写params范围,或者如何在函数中计算它: Imgproc.getGaborKernel(new Size(kSize[j],kSize[j]),sigma,theta,lambda,gamma); 我将非常感激.我当然试图自己分配,但没有成功. 示例文件: 解决方法
你可以参考这个c代码找到你的图像的Gabor Edge检测器输出.我相信你也可以在java中形成类似的东西!使用这些值来查找所需的内核类型.
#include <opencv2/core/core.hpp> #include <opencv2/imgproc/imgproc.hpp> #include <opencv2/highgui/highgui.hpp> #include <math.h> using namespace cv; int pos_kernel_size=21; int pos_sigma= 5; int pos_lm = 50; int pos_th = 0; int pos_gamma= 0; int pos_psi = 90; Mat src_f; Mat dest; void Process(int,void *) { int kernel_size=(pos_kernel_size-1)/2; Size KernalSize(kernel_size,kernel_size); double Sigma = pos_sigma; double Lambda = 0.5+pos_lm/100.0; double Theta = pos_th*CV_PI/180; double psi = pos_psi*CV_PI/180;; double Gamma = pos_gamma; Mat kernel = getGaborKernel(KernalSize,Sigma,Theta,Lambda,Gamma,psi); filter2D(src_f,dest,CV_32F,kernel); imshow("Process window",dest); Mat Lkernel(kernel_size*20,kernel_size*20,CV_32F); resize(kernel,Lkernel,Lkernel.size()); Lkernel /= 2.; Lkernel += 0.5; imshow("Kernel",Lkernel); Mat mag; pow(dest,2.0,mag); imshow("Mag",mag); } int main(int argc,char** argv) { Mat image = imread("Gabor.bmp",0); cv::imshow("Src",image); image.convertTo(src_f,1.0/255,0); if (!pos_kernel_size%2) { pos_kernel_size+=1; } cv::namedWindow("Process window",1); cv::createTrackbar("Sigma","Process window",&pos_sigma,pos_kernel_size,Process); cv::createTrackbar("Lambda",&pos_lm,100,Process); cv::createTrackbar("Theta",&pos_th,180,Process); cv::createTrackbar("Psi",&pos_psi,360,Process); cv::createTrackbar("Gamma",&pos_gamma,Process); Process(0,0); waitKey(0); return 0; } (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |