Schmid滤波器

Schmid也是一种类Gabor图像滤波器,在这篇文章[1]中有详细推导和介绍。

一种更简洁的表达公式是:


当中,r为核半径,Z为归一化參数,τ和σ是比較重要的參数,在ReID提取TextFeature中,常常使用例如以下一系列參数:

(2,1), (4,1), (4,2), (6,1), (6,2), (6,3), (8,1), (8,2), (8,3), (10,1), (10,2), (10,3), (10,4)

此外,还结合前面的Gabor滤波器,γ,θ,λ,σ的參数分别使用:(0.3,0,4,2), (0.3,0,8,2), (0.4,0,4,1), (0.4,0,4,1), (0.3,π/2,4,2), (0.3,π/2,8,2), (0.4,π/2 ,4,1), (0.4,π/2,4,1)

下面是11个滤波核的示意图:


生成Schmid核函数代码:

Mat getSchmidFilter(float tao, float sigma){
	float r = sigma/(4.0f*tao);
	float sigma2 = sigma*sigma;
	//int half_filter_size = int(r+0.5);
	int half_filter_size = 10;
	int filter_size = 2*half_filter_size+1;
	Mat schmid = Mat::zeros(filter_size,filter_size,CV_32F);
	float filter_sum = 0.0f;
	for(int i=0;i<filter_size;i++){
		float* s = schmid.ptr<float>(i);
		for(int j=0;j<filter_size;j++){
			float x = i-half_filter_size;
			float y = j-half_filter_size;
			r = sqrt(x*x+y*y);
			float tmp = 2*PI*tao*r/sigma;
			float tmp2 = r*r/(2.0f*sigma2);
			s[j] = cos(tmp)*exp(-tmp2);
			filter_sum += s[j];
		}
	}
	//cout<<filter_size<<" "<<filter_sum<<endl;
	//cout<<schmid<<endl;
	if(abs(filter_sum-0.0f)<1e-6){
		return schmid;
	}
	for(int i=0;i<filter_size;i++){
		float* s = schmid.ptr<float>(i);
		for(int j=0;j<filter_size;j++){
			s[j]/=filter_sum;
		}
	}
	return schmid;
}


参考文献:

[1] Schmid, Cordelia. "Constructing models for content-based image retrieval."Computer Vision and Pattern Recognition, 2001. CVPR 2001. Proceedings of the 2001 IEEE Computer Society Conference on. Vol. 2. IEEE, 2001.

[2] Gray, Douglas, and Hai Tao. "Viewpoint invariant pedestrian recognition with an ensemble of localized features." Computer Vision–ECCV 2008. Springer Berlin Heidelberg, 2008. 262-275.


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值