24小时热门版块排行榜    

查看: 2116  |  回复: 1
【奖励】 本帖被评价1次,作者baobiao007增加金币 0.6

baobiao007

木虫 (职业作家)


[资源] 【分享】线性卷积与循环卷积的比较c程序

#include
#include
#include
const int L1=4;
const int L2=6;
//普通线性卷积
void conv(float x[],int m,float y[],int n,float z[],int l)
{
        int i,j;
        for(i=0; i         {
                z=0.0;
                for(j=0; j                         if(i-j>=0&&i-j<=m-1)
                                z+=y[j]*x[i-j];
        }
}
//圆周移位,x1-原始有限长序列,x2-移位后的有限长序列,m-移动长度(>0右移,<0左移)
void CircleMove(float x1[],float x2[],int m,int num)
{
        int rr;
        for(int i=0; i         {
                x2=0.0;
                rr=(i-m)%num;
                if(r>=0)
                  x2=x1[rr];
                else
                  x2=x1[num+rr];
        }
}
//时域圆周卷积,两等长序列x,y圆周卷积后得到z
//三序列长度都是num
void CircleConvolution(float x[],float y[],float z[],int num)
{
        float *y1,t;
        int i,j;
        y1=(float *)calloc(num,sizeof(float));
        for(i=1; i<=num/2; i++)
        { t=y;y=y[num-i];y[num-i]=t;}
        for(j=0; j         { z[j]=0.0;
          CircleMove(y,y1,j,num);
          for(i=0; i                   z[j]+=x*y1;
        }
        free(y1);
}

void main()
{
        float x[L1]={1,1,1,1};
        float y[L2]={1,1,1,1,1,1};
        float z1[L1+L2-1],z2[L1+L2-1];
        //直接线性卷积
        conv(x,L1,y,L2,z1,L1+L2-1);

        //要使循环卷积与线性卷积的结果相同,首先要将x,y的
        //长度扩大为L1+L2-1
        float *x1,*y1;
        x1=(float *)calloc(L1+L2-1,sizeof(float));
    y1=(float *)calloc(L1+L2-1,sizeof(float));
        for(int i=0; i                 x1=x;
        for(i=0; i                 y1=y;
        CircleConvolution(x1,y1,z2,L1+L2-1);
        printf("线性卷积:       圆周卷积:\n";
        for(i=0; i            printf("z1[%d]=%f        z2[%d]=%f\n",i,z1,i,z2);

        free(x1);free(y1);
}
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

yanggis

木虫 (著名写手)


★★★ 三星级,支持鼓励

不错。。。。。。。。。。。。
2楼2011-02-10 22:06:22
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 baobiao007 的主题更新
☆ 无星级 ★ 一星级 ★★★ 三星级 ★★★★★ 五星级
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[公派出国] 售SCI一区文章,我:8 O5 51O 54,科目齐全 +3 5lbyq5wrhb 2026-02-07 3/150 2026-02-08 03:05 by vs90ilomwc
[考博] 售SCI一区文章,我:8 O5 51O 54,科目齐全 +3 5lbyq5wrhb 2026-02-07 3/150 2026-02-08 02:52 by vs90ilomwc
[论文投稿] 售SCI一区文章,我:8 O5 51O 54,科目齐全 +3 3rkserf6qr 2026-02-07 4/200 2026-02-08 02:45 by vs90ilomwc
[硕博家园] 售SCI一区文章,我:8 O5 51O 54,科目齐全 +3 3rkserf6qr 2026-02-07 3/150 2026-02-08 02:32 by vs90ilomwc
[硕博家园] 售SCI一区文章,我:8 O5 51O 54,科目齐全 +5 2h7du0nuhk 2026-02-07 5/250 2026-02-08 02:27 by vs90ilomwc
[考博] 售SCI一区文章,我:8 O5 51O 54,科目齐全 +5 2h7du0nuhk 2026-02-07 5/250 2026-02-08 02:25 by vs90ilomwc
[硕博家园] 售SCI一区文章,我:8 O5 51O 54,科目齐全 +4 2h7du0nuhk 2026-02-07 5/250 2026-02-08 02:12 by vs90ilomwc
[找工作] 售SCI一区文章,我:8 O5 51O 54,科目齐全 +4 2h7du0nuhk 2026-02-07 6/300 2026-02-08 01:46 by vs90ilomwc
[公派出国] 售SCI一区文章,我:8 O5 51O 54,科目齐全 +4 2h7du0nuhk 2026-02-07 7/350 2026-02-08 01:45 by vs90ilomwc
[考博] 售SCI一区文章,我:8 O5 51O 54,科目齐全 +4 2h7du0nuhk 2026-02-07 7/350 2026-02-08 01:32 by vs90ilomwc
[硕博家园] 售SCI一区文章,我:8 O5 51O 54,科目齐全 +4 2h7du0nuhk 2026-02-07 7/350 2026-02-08 01:12 by vs90ilomwc
[教师之家] 有院领导为了换新车,用横向课题经费买了俩车 +7 瞬息宇宙 2026-02-04 7/350 2026-02-07 21:47 by tfang
[有机交流] 酰胺脱乙酰基 10+5 chibby 2026-02-03 12/600 2026-02-07 19:29 by 江东闲人
[基金申请] 同年申请2项不同项目,第1个项目里不写第2个项目的信息,可以吗 +4 hitsdu 2026-02-06 4/200 2026-02-07 13:07 by jurkat.1640
[基金申请] 有时候真觉得大城市人没有县城人甚至个体户幸福 +9 苏东坡二世 2026-02-04 10/500 2026-02-07 12:37 by 小毛球
[考博] 天津大学招2026.09的博士生,欢迎大家推荐交流(博导是本人) +4 a793625982 2026-02-05 5/250 2026-02-07 10:57 by a793625982
[公派出国] CSC & MSCA 博洛尼亚大学能源材料课题组博士/博士后招生|MSCA经费充足、排名优 +4 雨念 2026-02-01 6/300 2026-02-06 23:32 by MelissaPon
[基金申请] 面上项目申报 +3 Tide man 2026-02-01 3/150 2026-02-05 22:56 by god_tian
[硕博家园] 博士延得我,科研能力直往上蹿 +7 偏振片 2026-02-02 7/350 2026-02-04 17:36 by 陈氏帝国
[教师之家] 遇见不省心的家人很难过 +18 otani 2026-02-03 22/1100 2026-02-04 11:06 by tangmnt
信息提示
请填处理意见