24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 831  |  回复: 3
【奖励】 本帖被评价1次,作者baobiao007增加金币 0.8

baobiao007

木虫 (职业作家)


[资源] 【分享】时域褶积带通滤波c程序【原创,无重复】

#include
#include
#include
#include"FFT.h"

/*带通滤波因子
  num--滤波因子长度(奇数)
  f0--通频带中心频率
  hf--通频带半宽度
  dt--时间采样间隔(与输入信号相同)
*/
void FilterH(float h[],int num,float f0,float hf,float dt)
{
        int i,j;
        double pi=3.1415926;
        float t;
        float *w;       
               //产生汉明时窗w[]
                w=(float *)calloc(num,sizeof(float));
        for(i=0; i<=num/2; i++)
             w[ i ]=0.54+0.46*cos(2*pi*i/num);
        for(i=num/2+1; i              w[ i ]=w[num-i];
        //产生滤波因子
        h[0]=4.0*hf;
        for(i=1; i         {
              h[ i ]=0.0;
                      if(i<=num/2)
              { t=i*dt;j=i;}
              else
              { j=num-i; t= -j*dt;}       
              h[ i ]=2.0*sin(2*pi*hf*t)*cos(2*pi*f0*t)*w[ j ]/(pi*t);
         }
}
/*输入信号与滤波因子褶积
  h[]--滤波因子,x[]--输入信号
  保证x[]更长,结果存放在y[],长度也为m
*/
void ConvFilter(float h[],int n,float x[],int m,float y[],float dt)
{
        int i,j,k;
                int half;
        half=(n-1)/2;
        for(i=0; i         {
                     y[ i ]=0.0;
             for(j= -half; j<=half; j++)
             {
                k=i-j;
                if(j<0 && k                         y[ i ]+=h[n+j]*x[k]*dt;
                if(j>=0 && k>=0)
                        y[ i ]+=h[j]*x[k]*dt;
              }
         }
}
//产生合成信号
//30 60 90hz正弦信号相加
void Generate(float x[],int num)
{
        int i;
        double pi=3.1415926;
        float dt=0.002;
        float f1,f2,f3;
        f1=30.0;
        f2=60.0;
        f3=90.0;
        for(i=0; i              x[ i ]=sin(2*pi*f1*i*dt)+sin(2*pi*f2*dt*i)+sin(2*pi*f3*i*dt);
}
void main()
{
        const int N=101;//滤波因子长度
        const int M=128;//信号长度
        float Inisig[M]={0};//要滤波的信号
        float Afsig2[M]={0};//滤波后的信号
        float Afsig[M]={0};//理想情况下滤波后的信号
        float h[N];//滤波因子
        int i;
        FILE *fp1,*fp2,*fp3;
        fp1=fopen("inisig.txt","w" );//合成信号
         fp2=fopen("afsig.txt","w" );//理想50hz信号
        fp3=fopen("afsig2.txt","w" );//滤波得到的50hz信号

        //产生信号,20hz,50hz,80hz正弦信号叠加
         double pi=3.1415926;
        float dt=0.002;
        float f1,f2,f3;
        f1=20.0;
        f2=50.0;
        f3=80.0;
        for(i=0; i         {        Afsig[ i ]=sin(2*pi*f2*dt*i);
                Inisig[ i ]=Afsig+sin(2*pi*f1*i*dt)+sin(2*pi*i*f3*dt);
        }
       
        FilterH(h,N,50.0,10.0,dt);
                //滤去低于70hz和高于80hz信号
        ConvFilter(h,N,Inisig,M,Afsig2,dt);

        for(i=0; i         {
                fprintf(fp1,"%f\n",Inisig[ i ]);
                        fprintf(fp2,"%f\n",Afsig[ i ]);
                        fprintf(fp3,"%f\n",Afsig2[ i ]);
        }
                fclose(fp1);
        fclose(fp2);
        fclose(fp3);
}
滤波前:
滤波后:

[ Last edited by baobiao007 on 2011-2-14 at 20:42 ]
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

流浪者之歌

铜虫 (小有名气)


谁能告诉我怎么提高编程
2楼2011-04-14 10:28:20
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

baobiao007

木虫 (职业作家)


引用回帖:
Originally posted by 流浪者之歌 at 2011-04-14 10:28:20:
谁能告诉我怎么提高编程

搞天然地震的兄弟啊。  狂看狂练呗
3楼2011-04-14 12:32:15
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

w1161392713

新虫 (初入文坛)


★★★★★ 五星级,优秀推荐

楼主太厉害了,但是网页上有些部分看不到了,能否补全下,谢谢,祝楼主万事如意
4楼2017-05-06 21:14:26
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 baobiao007 的主题更新
☆ 无星级 ★ 一星级 ★★★ 三星级 ★★★★★ 五星级
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 085600材料与化工301分求调剂院校 +15 刺痛jk 2026-04-06 16/800 2026-04-06 18:18 by 猪会飞
[考研] 生物与医药求调剂 +6 heguanhua 2026-04-05 7/350 2026-04-06 18:01 by 猪会飞
[考研] 求调剂 +8 张zic 2026-04-05 9/450 2026-04-06 13:03 by 猪会飞
[考研] 0855求调剂材料 +11 红桃灼灼 2026-04-04 12/600 2026-04-06 10:26 by 蓝云思雨
[考研] 331求调剂 +8 于征yz 2026-04-05 8/400 2026-04-06 00:54 by fmesaito
[考研] 272分求调剂 +4 wangyile2233 2026-04-02 4/200 2026-04-05 22:21 by 286640313
[考研] 生物与医药086000调剂一志愿西北农林320分 +3 美美女士 2026-04-03 3/150 2026-04-05 21:55 by 学员8dgXkO
[考研] 求调剂求调剂 +8 121. 2026-04-02 8/400 2026-04-05 20:15 by lys0704
[考研] 315求调剂 +5 &123456789 2026-04-05 5/250 2026-04-05 19:55 by nepu_uu
[考研] 本科211,293分请求调剂 +8 莲菜就是藕吧 2026-04-03 9/450 2026-04-05 19:12 by 蓝云思雨
[考研] 一志愿9材料学硕297已过六级求调剂推荐 +11 adaie 2026-04-04 12/600 2026-04-05 19:04 by 蓝云思雨
[考研] 材料专硕(0856) 339分求调剂 +10 哈哈哈鹅哈哈哈 2026-04-04 10/500 2026-04-05 18:51 by 蓝云思雨
[考研] 296求调剂 +3 汪!?! 2026-04-05 5/250 2026-04-05 17:38 by 蓝云思雨
[考研] 275求调剂 +16 waltzh 2026-04-01 16/800 2026-04-05 17:14 by Hdyxbekcb
[考研] 268求调剂 +8 你好tg 2026-04-03 9/450 2026-04-04 05:08 by gswylq
[考研] 265求调剂 +20 梁梁校校 2026-04-01 21/1050 2026-04-04 00:38 by userper
[考研] 311求调剂 +11 勇敢的小吴 2026-04-02 11/550 2026-04-03 21:46 by qlm5820
[考研] 0855机械初试280求调剂 +3 kazenotori 2026-03-31 3/150 2026-04-01 10:08 by JourneyLucky
[考研] 358求调剂 +3 王向阳花 2026-03-31 3/150 2026-04-01 09:56 by zzchen2000
[考研] 求0861交通运输专硕or材料专硕调剂 +4 勒布朗@ 2026-03-31 4/200 2026-04-01 09:54 by 一只好果子?
信息提示
请填处理意见