24小时热门版块排行榜    

查看: 2119  |  回复: 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 的主题更新
☆ 无星级 ★ 一星级 ★★★ 三星级 ★★★★★ 五星级
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[文学芳草园] 伙伴们,祝我生日快乐吧 +17 myrtle 2026-03-10 26/1300 2026-03-16 18:32 by 青橙Ln
[考研] 考研化学学硕调剂,一志愿985 +3 张vvvv 2026-03-15 4/200 2026-03-16 17:55 by 张vvvv
[考研] 304求调剂 +5 素年祭语 2026-03-15 5/250 2026-03-16 17:00 by 我的船我的海
[考研] 化学工程321分求调剂 +9 大米饭! 2026-03-15 9/450 2026-03-16 16:41 by 我的船我的海
[考研] 312求调剂 +3 陌宸希 2026-03-16 4/200 2026-03-16 15:06 by peike
[考研] 0703化学调剂 290分有科研经历,论文在投 +7 腻腻gk 2026-03-14 7/350 2026-03-16 10:12 by houyaoxu
[教师之家] 焦虑 +7 水冰月月野兔 2026-03-13 9/450 2026-03-16 10:00 by Quakerbird
[考研] 复试调剂 +4 z1z2z3879 2026-03-14 5/250 2026-03-14 16:30 by JourneyLucky
[考研] 学硕285求调剂 +13 Wisjxn 2026-03-12 46/2300 2026-03-14 10:33 by JourneyLucky
[考研] 材料工程专硕,一志愿中国矿业大学,总分314,求调剂 +5 无懈可击的巨人 2026-03-10 5/250 2026-03-14 00:37 by JourneyLucky
[考研] 招收0805(材料)调剂 +3 18595523086 2026-03-13 3/150 2026-03-14 00:33 by 123%、
[考研] 279求调剂 +3 Dizzy123@ 2026-03-10 3/150 2026-03-13 23:02 by JourneyLucky
[考研] 一志愿西南交大,材料专硕317求调剂 +5 lx8568 2026-03-11 5/250 2026-03-13 21:43 by peike
[考研] 302求调剂 +6 负心者当诛 2026-03-11 6/300 2026-03-13 16:11 by JourneyLucky
[考研] 工科278分求调剂 +5 周慢热啊 2026-03-12 7/350 2026-03-13 15:49 by JourneyLucky
[考研] 274求调剂 +3 S.H1 2026-03-12 3/150 2026-03-13 15:15 by JourneyLucky
[考研] 085600材料与化工 309分请求调剂 +7 dtdxzxx 2026-03-12 8/400 2026-03-13 14:43 by jxchenghu
[考研] 0817化学工程与技术考研312分调剂 +3 T123 tt 2026-03-12 3/150 2026-03-13 10:49 by houyaoxu
[考研] 大连大学化学专业研究生调剂 +3 琪久. 2026-03-10 8/400 2026-03-11 10:02 by 琪久.
[考研] 求调剂材料专硕293 +6 段_(:з」∠)_ 2026-03-10 6/300 2026-03-10 18:22 by ms629
信息提示
请填处理意见