编程计算循环卷积

function [ y ] = cyclic_conv( xn0,hn0,N )
%cyclic_conv 循环卷积运算
%计算xn与yn的N点循环卷积
%xn0-序列,hn0-序列,N-循环卷积点数
xn1=[xn0,zeros(1,N-length(xn0))];        %补零
hn=[hn0,zeros(1,N-length(hn0))]';
xn2=fliplr(xn1);                         %元素按索引倒序排列
for i=1:N
    xn(i,:)=circshift(xn2,[1,-(N-i)]);   %循环卷积矩阵
end
y=xn*hn;
end

测试代码如下:

xn=[1 2 3 4];
hn=[1 1 1 1];
N1=4;
N2=8;
y1=cyclic_conv(xn,hn,N1)
y2=cyclic_conv(xn,hn,N2)

 

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值