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

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

[复制链接]

该用户从未签到

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

EDA365欢迎您登录!

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

x

5 o; d8 b9 g2 {& H周期方波的表达式我就不提炼了,既然你来看文章了,我就不信你周期方波都不知道。
# L% o0 a' g1 K5 w/ x) {4 b$ w2 o  K$ U  C+ E0 d; O, W" |
占空比定义为:L/N,N为周期,下面我们对 L = 5,N = 20; L = 5,N = 40;L = 5,N = 60;L = 7,N = 60分别画出它们的DFS图作比较。" T- W3 |$ h& o8 j4 e
0 t1 ~( o, @; T% X: T" b
我觉得有必要先把对应的周期方波给出来(每幅图都只给出一个周期):* ], {5 H( s7 X% u+ C
- y. f( y# A( }
  • 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)');
  • , i* T) H+ \& |! @# m& y& w7 s/ ^; n
            
  _  Y. r* h3 a$ y4 }
, B: z; v  ^9 t

, a+ \) Q' A9 v上面程序中的DFS函数定义在另一篇博文中:【 MATLAB 】离散傅里叶级数(DFS)及 IDFS 的 MATLAB 实现
) [& p1 m$ b! k# \, G
; d- x3 ^5 T2 |: t
! H8 |- Y  `8 ^8 S" f* I

( U, P3 x, d) J7 L6 ]$ S% Z% p4 k
+ Q* v2 r2 e9 z) E8 i! t* g: K0 ~  o直接给出MATLAB脚本:
$ Z  @/ G5 @# @2 X7 X; f0 {1 f6 w' E  v, p; Z/ M
  • 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)');

  • 7 j+ X! A6 f; H% F5 C" p
              7 M, C3 O$ _1 g+ R" d
* [7 x2 |. S1 K8 D$ o& r( n

8 c/ W( w8 _; n0 E% v8 Q+ d& q9 m6 H
& N+ d9 B' c) n3 z7 S' N8 S# F$ e  m, b' S

" i+ ]5 q* g9 r1 p
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

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

EDA365公众号

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

GMT+8, 2025-11-23 20:50 , Processed in 0.187500 second(s), 26 queries , Gzip On.

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

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

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