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

MATLAB ------- 使用 MATLAB 比较占空比不同的周期方波的 DFS 图

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2019-10-30 11:22 | 只看该作者 |只看大图 回帖奖励 |正序浏览 |阅读模式

EDA365欢迎您登录!

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

x

6 R/ ]8 q! }9 C: m# ]0 ^周期方波的表达式我就不提炼了,既然你来看文章了,我就不信你周期方波都不知道。3 N0 f7 E% h( U, A5 o" E# A
2 u( A& k2 h: T6 p
占空比定义为:L/N,N为周期,下面我们对 L = 5,N = 20; L = 5,N = 40;L = 5,N = 60;L = 7,N = 60分别画出它们的DFS图作比较。
* n# u( f; o  Y3 D1 {
. y7 n2 W2 a1 Q' y4 e( d/ d9 H5 C- i我觉得有必要先把对应的周期方波给出来(每幅图都只给出一个周期):8 i+ k# f- }) l1 V9 D

4 f3 R0 i' U, u6 I* \7 \# [$ D
  • clc;clear;close all;
  • % Periodic square wave parameters L = 5,N = 20
  • L = 5;
  • N = 20;
  • n = 0:N-1;
  • xn = [ones(1,L),zeros(1,N-L)];
  • subplot(2,2,1)
  • stem(n,xn);
  • title('L = 5,N = 20');
  • xlabel('n');ylabel('xtilde(n)');
  • % Periodic square wave parameters L = 5,N = 40
  • L = 5;
  • N = 40;
  • n = 0:N-1;
  • xn = [ones(1,L),zeros(1,N-L)];
  • subplot(2,2,2)
  • stem(n,xn);
  • title('L = 5,N = 20');
  • xlabel('n');ylabel('xtilde(n)');
  • % Periodic square wave parameters L = 5,N = 60
  • L = 5;
  • N = 60;
  • n = 0:N-1;
  • xn = [ones(1,L),zeros(1,N-L)];
  • subplot(2,2,3)
  • stem(n,xn);
  • title('L = 5,N = 20');
  • xlabel('n');ylabel('xtilde(n)');
  • % Periodic square wave parameters L = 7,N = 60
  • L = 7;
  • N = 60;
  • n = 0:N-1;
  • xn = [ones(1,L),zeros(1,N-L)];
  • subplot(2,2,4)
  • stem(n,xn);
  • title('L = 5,N = 20');
  • xlabel('n');ylabel('xtilde(n)');
  • / Y/ J% [  A$ P9 ~( r  P4 H. I9 L
             $ |& {1 j9 g6 v
" C5 d4 ]6 h/ f% ?
. w; u( g, p9 |, b
上面程序中的DFS函数定义在另一篇博文中:【 MATLAB 】离散傅里叶级数(DFS)及 IDFS 的 MATLAB 实现1 ^! S1 B8 R% ^. Z3 V  O1 f

; H2 k1 y9 g" k5 a! Y5 p

) f, s0 G) ]! R# L/ b6 @4 g  i" k8 C0 P6 e) F) y. e7 Q3 K
- T. ?- ?9 ?; I' y* F
直接给出MATLAB脚本:5 R, Z6 t% b/ x" R, c$ l

" r4 ]  V  U, ]' q# F9 C/ R
  • clc;clear;close all;
  • % Periodic square wave parameters L = 5,N = 20
  • L = 5;
  • N = 20;
  • k = [-N/2:N/2];
  • xn = [ones(1,L),zeros(1,N-L)];
  • Xk = dfs(xn,N);
  • magXk = abs( [ Xk(N/2+1:N),Xk(1:N/2+1) ] );
  • subplot(2,2,1)
  • stem(k,magXk);
  • title('DFS of Square: L = 5,N = 20');
  • xlabel('k');ylabel('Xtilde(k)');
  • % Periodic square wave parameters L = 5,N = 40
  • L = 5;
  • N = 40;
  • k = [-N/2:N/2];
  • xn = [ones(1,L),zeros(1,N-L)];
  • Xk = dfs(xn,N);
  • magXk = abs( [ Xk(N/2+1:N),Xk(1:N/2+1) ] );
  • subplot(2,2,2)
  • stem(k,magXk);
  • title('DFS of Square: L = 5,N = 40');
  • xlabel('k');ylabel('Xtilde(k)');
  • % Periodic square wave parameters L = 5,N = 60
  • L = 5;
  • N = 60;
  • k = [-N/2:N/2];
  • xn = [ones(1,L),zeros(1,N-L)];
  • Xk = dfs(xn,N);
  • magXk = abs( [ Xk(N/2+1:N),Xk(1:N/2+1) ] );
  • subplot(2,2,3)
  • stem(k,magXk);
  • title('DFS of Square: L = 5,N = 60');
  • xlabel('k');ylabel('Xtilde(k)');
  • % Periodic square wave parameters L = 7,N = 60
  • L = 7;
  • N = 60;
  • k = [-N/2:N/2];
  • xn = [ones(1,L),zeros(1,N-L)];
  • Xk = dfs(xn,N);
  • magXk = abs( [ Xk(N/2+1:N),Xk(1:N/2+1) ] );
  • subplot(2,2,4)
  • stem(k,magXk);
  • title('DFS of Square: L = 7,N = 60');
  • xlabel('k');ylabel('Xtilde(k)');
  • ! C  \% F5 R# C. T- Y9 X$ X$ a
              
% r9 j. g; A. G, ]

( A" Q( n6 g3 m3 v2 a7 }5 x3 Y6 ]+ ]: _
2 q! F# _; H4 e9 ?3 K) V5 Z

1 b5 c9 b8 Q, t7 D: Q5 q( |8 L' I1 R  _! x1 L, o
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

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

EDA365公众号

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

GMT+8, 2025-11-23 22:45 , Processed in 0.171875 second(s), 27 queries , Gzip On.

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

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

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