找回密码
 注册
关于网站域名变更的通知
查看: 599|回复: 1
打印 上一主题 下一主题

基于MATLAB序列运算的序列移位的函数实现

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2020-1-16 10:44 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式

EDA365欢迎您登录!

您需要 登录 才可以下载或查看,没有帐号?注册

x
6 l8 b+ k* h- R" |4 Z' X3 ?% f( N
这种运算有点理解,反正我是觉得有点绕,所以单独拿出来,表示注重。9 q$ G% }5 K/ w' R- J4 q
$ O( d( t, W) o9 A: ~3 \
在这种运算中,x(n)的每个样本都要移位一个量k得到一个移位的序列y(n).
; b  P% U" n. c5 N& z+ x  H  d# r1 W5 }- m9 Y
+ C1 d7 q$ R( O, @9 _$ `
+ Q' e: @6 V) [- V5 m
如果令m=n-k,那么n = m + k,上面运算给出为:
3 V! }+ s1 [3 |$ C* {3 `& {: J; s9 P% j) s: e, T

% ]1 ]7 Y( I) `+ A& Y# p+ J' y* C; b% T, q/ ]# D0 ]
这就是说,把m当成x的自变量,那么y的自变量n就等于m + k,对于n而言,相当于x右移了k位。  a0 o, b% w( l/ @
/ J$ ?4 d; u* Z, [% x. n1 N
响应的函数可以定义如下:
! i3 w6 E" v% D+ z. a
+ V7 Y) ?; ]# j" B  X2 f( y* x
  • function [y,n] = sigshift(x,m,k)
  • %implements y(n) = x(n - k)
  • %_________________________
  • %[y,n] = sigshift(x,m,k)
  • %
  • n = m+k;
  • y = x;$ L2 Q% V0 I/ V3 A
+ a) x7 o7 q3 ~2 G- f  n- X* o! V) I
下面我们验证下这个函数是否实现移位功能:! j' A) z" O% Q

: X3 i6 _0 E5 s/ H/ k# g
  • clc
  • clear
  • close all
  • n = 0:5;
  • x = randn(1,6);
  • subplot(2,1,1)
  • stem(n,x);
  • xlabel('n');ylabel('x(n)');
  • [y,n]=sigshift(x,n,4);
  • subplot(2,1,2)
  • stem(n,y);
  • xlabel('n');ylabel('y(n) = x(n -4)');
    . `. a* {" `+ q5 J( J9 H( F# p4 K
  
6 ]- s( r& o& U9 i3 ^/ O  Q
) v3 l. i7 T6 O' U ) E6 c! z5 B7 S* x$ H0 q9 |3 m! v
可见,实现了移位运算。  l$ E  X! U1 V0 H
* i, k# b6 V4 `- D, V  [9 I
  • TA的每日心情

    2019-11-29 15:37
  • 签到天数: 1 天

    [LV.1]初来乍到

    2#
    发表于 2020-1-16 19:39 | 只看该作者
    基于MATLAB序列运算的序列移位的函数实现
    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    关闭

    推荐内容上一条 /1 下一条

    EDA365公众号

    关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

    GMT+8, 2025-11-24 03:55 , Processed in 0.140625 second(s), 26 queries , Gzip On.

    深圳市墨知创新科技有限公司

    地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

    快速回复 返回顶部 返回列表