| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 856 人关注过本帖
标题:请教一个关于用C来编写高通滤波和FFT的小项目
只看楼主 加入收藏
fu563048951
Rank: 2
等 级:论坛游民
帖 子:18
专家分:20
注 册:2012-2-19
结帖率:75%
收藏
已结贴  问题点数:30 回复次数:2 
请教一个关于用C来编写高通滤波和FFT的小项目
现在有32768个采样数据,采样频率是30000HZ,条件就这么多,让写一个程序对采样数据进行高通滤波和FFT,我查了几天的资料了还是没有头绪,书上介绍的都是跟公式有关的,可是项目中只有采样的离散数据,没有其他的了,想不出思路,求大神跟讲解一下
搜索更多相关主题的帖子: 高通滤波 小项目 资料 
2013-09-19 10:51
fu563048951
Rank: 2
等 级:论坛游民
帖 子:18
专家分:20
注 册:2012-2-19
收藏
得分:0 
没有人吗?很着急的
2013-09-19 11:05
pauljames
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:千里冰封
威 望:9
帖 子:1555
专家分:10000
注 册:2011-5-8
收藏
得分:30 
《信号处理与软计算》当年信号处理课做过FIR滤波器和FFT算法实现,里面有提到算法思想。
另外,网上有现成的FFT算法,比如下面这个,滤波器你自己找吧
#include <stdio.h>
#include <math.h>
//此代码来源《数字信号处理C语言程序集》殷福亮、宋爱军,沈阳:辽宁科学技术出版社,1997.7
//数组x存储时域序列的实部,数组y存储时域序列的虚部
//n代表N点FFT,sign=1为FFT,sign=-1为IFFT
void FFT(double x[],double y[],int n,int sign)
{
int i,j,k,l,m,n1,n2;
double c,c1,e,s,s1,t,tr,ti;
//Calculate i = log2N
for(j = 1,i = 1; i<16; i++)
{
     m = i;
     j = 2*j;
     if(j == n)
         break;
}
//计算蝶形图的输入下标(码位倒读)
n1 = n - 1;
for(j=0,i=0; i<n1; i++)
{
    if(i<j)         
    {
         tr = x[j];
         ti = y[j];
         x[j] = x[i];
         y[j] = y[i];
         x[i] = tr;
         y[i] = ti;               
    }
    k = n/2;
    while(k<(j+1))
    {
        j = j - k;
        k = k/2;            
    }
    j = j + k;
}
//计算每一级的输出,l为某一级,i为同一级的不同群,使用同一内存(即位运算)
n1 = 1;
for(l=1; l<=m; l++)
{
    n1 = 2*n1;
    n2 = n1/2;
    e = 3.1415926/n2;
    c = 1.0;
    s = 0.0;
    c1 = cos(e);
    s1 = -sign*sin(e);
    for(j=0; j<n2; j++)
    {
        for(i=j; i<n; i+=n1)      
        {
            k = i + n2;
            tr = c*x[k] - s*y[k];
            ti = c*y[k] + s*x[k];
            x[k] = x[i] - tr;
            y[k] = y[i] - ti;
            x[i] = x[i] + tr;
            y[i] = y[i] + ti;      
        }
        t = c;
        c = c*c1 - s*s1;
        s = t*s1 + s*c1;
    }
}
//如果是求IFFT,再除以N
if(sign == -1)
{
for(i=0; i<n; i++)
{
   x[i] /= n;
   y[i] /= n;
}
}
}
int main()
{
double x[4] = {1,2,-1,3};//郑君里《信号与系统》上的例子,下P145
double y[4] = {0};
int i;
for(i=0; i<4; i++)
printf("%d %f %fn",i,x[i],y[i]);
FFT(x,y,4,1);
for(i=0; i<4; i++)
printf("%d %f %fn",i,x[i],y[i]);
FFT(x,y,4,-1);
for(i=0; i<4; i++)
printf("%d %f %fn",i,x[i],y[i]);
return 1;
}

经常不在线不能及时回复短消息,如有c/单片机/运动控制/数据采集等方面的项目难题可加qq1921826084。
2013-09-19 15:43
快速回复:请教一个关于用C来编写高通滤波和FFT的小项目
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.019010 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved