以前学习图像处理的时候下的函数呀!
编程环境:windows下结合opencv库。
//频域滤波器的类型 使用时一般使用前三种类型与后两种 "或操作" 一起使用,默认为低通滤波器
//例:DFT_FILTER_GAUSSIAN | DFT_FILTER_HIGH 表示高斯高通滤波器
enum DFT_FILTER_TYPE
{
DFT_FILTER_IDEAL,//理想频域滤波器
DFT_FILTER_BTW,//巴特沃兹频域滤波器
DFT_FILTER_GAUSSIAN,//高斯频域滤波器
DFT_FILTER_LOW,//低通频域滤波器
DFT_FILTER_HIGH//高通频域滤波器
};
//频域滤波
//根据上述提供的不同种滤波器 fD0 和 nN 含义不同
//fD0表示在距离原点D0处出现截断频率
//nN表示巴特沃兹滤波器的阶数,默认为1阶
void DFTFilt(IplImage* src, IplImage* dst, DFT_FILTER_TYPE dftFilterType, float fD0, int nN = 1);
//频域滤波
//根据提供的不同种滤波器 fD0 和 nN 含义不同
//fD0表示在距离原点D0处出现截断频率
//nN表示巴特沃兹滤波器的阶数,默认为1阶
//dst类型为IPL_DEPTH_8U,通道为1,大小与src相同
void DFTFilt(IplImage* src, IplImage* dst, DFT_FILTER_TYPE dftFilterType, float fD0, int nN)
{
if (!src || !dst)
{
return;
}
if (src->nChannels == 3)
{
cvCvtColor(src, src, CV_BGR2GRAY);
}
int nDFTWidth = cvGetOptimalDFTSize(src->width);//傅里叶变换宽度
int nDFTHeight = cvGetO