【 MATLAB 】两个序列的卷积和运算的MATLAB实现(2)

举报
李锐博恩 发表于 2021/07/15 07:12:28 2021/07/15
4k+ 0 0
【摘要】 已知下面两个序列: 求这两个序列的卷积。 求卷积的函数是conv,但是使用这个函数有个问题,就是下标问题,也就是求卷积之后的元素值的位置。因此,我们必须要定一个起始点和一个结束点。 方法: 是两个有限长序列,二者卷积的起始点和结束点定义为: 测试脚本: clcclearclose all nx = -3:3;x = [3,11,7,0...

已知下面两个序列:

x(n) = [3, 11, 7, 0, -1, 4, 2], -3 \leq n \leq 3

h(n) = [2, 3, 0, -5, 2, 1], -1 \leq n \leq 4

求这两个序列的卷积。


求卷积的函数是conv,但是使用这个函数有个问题,就是下标问题,也就是求卷积之后的元素值的位置。因此,我们必须要定一个起始点和一个结束点。

方法:

\left \{ x(n); n_{xb} \leq n \leq n_{xe} \right \}

\left \{ h(n); n_{hb} \leq n \leq n_{he}\right \}

是两个有限长序列,二者卷积的起始点和结束点定义为:

n_{yb} = n_{xb} + n_{hb}

n_{ye}= n_{xe} + n_{he}


测试脚本:


      clc
      clear
      close all
      nx = -3:3;
      x = [3,11,7,0,-1,4,2];
      nh = -1:4;
      h = [2,3,0,-5,2,1];
      nyb = nx(1) + nh(1);
      nye = nx(length(x)) + nh(length(h));
      ny = nyb:nye;
      y = conv(x,h);
      subplot(3,1,1);
      stem(nx,x);
      title('x(n)');
      subplot(3,1,2);
      stem(nh,h);
      title('h(n)');
      subplot(3,1,3);
      stem(ny, y);
      title('y(n)');
  
 

昨天,这篇博文就到此结束了,可是呢?你不觉得每次卷积时候都要进行求卷积之后得到的卷积值的位置麻烦吗?

包括上篇博文:【 MATLAB 】两个序列的卷积和运算的MATLAB实现(1)

那我们考虑下把两个信号的卷积简单扩展为一个函数conv_m。

如下:


      function [y,ny] = conv_m(x,nx,h,nh)
      % Modified convolution routine for signal processing
      %___________________________________________________
      % [y,ny] = conv_m(x,nx,h,nh)
      % [y,ny] = convolution result
      % [x,nx] = first signal
      % [h,nh] = second signal
      %
      nyb = nx(1) + nh(1);
      nye = nx(length(x)) + nh(length(h));
      ny = nyb:nye;
      y = conv(x,h);
  
 

我们在验证下:


      clc
      clear
      close all
      nx = -3:3;
      x = [3,11,7,0,-1,4,2];
      nh = -1:4;
      h = [2,3,0,-5,2,1];
      [y,ny]=conv_m(x,nx,h,nh);
      subplot(3,1,1);
      stem(nx,x);
      title('x(n)');
      subplot(3,1,2);
      stem(nh,h);
      title('h(n)');
      subplot(3,1,3);
      stem(ny, y);
      title('y(n)');
  
 

文章来源: reborn.blog.csdn.net,作者:李锐博恩,版权归原作者所有,如需转载,请联系作者。

原文链接:reborn.blog.csdn.net/article/details/83280559

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

作者其他文章

评论(0

抱歉,系统识别当前为高风险访问,暂不支持该操作

    全部回复

    上滑加载中

    设置昵称

    在此一键设置昵称,即可参与社区互动!

    *长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

    *长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。