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

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

[复制链接]

该用户从未签到

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

EDA365欢迎您登录!

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

x

. D/ f. g, P# Y, D% _% h周期方波的表达式我就不提炼了,既然你来看文章了,我就不信你周期方波都不知道。9 X* U* I8 F" c) o3 f

& Z1 S0 G' J! Q* x3 d/ |占空比定义为:L/N,N为周期,下面我们对 L = 5,N = 20; L = 5,N = 40;L = 5,N = 60;L = 7,N = 60分别画出它们的DFS图作比较。8 Z- D# ]4 X7 y* n* u! f
/ I5 z6 P/ {  p: R/ f
我觉得有必要先把对应的周期方波给出来(每幅图都只给出一个周期):
* @! n. `7 ~  n' e( t. L2 G' E, Y$ J9 q7 H# \" [
  • 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)');

  • ! ?$ X( G# {$ B6 b4 S
            
5 P+ n) M% M5 g6 ^

# a3 e! D* o- n! M" q2 k0 N9 W; {* s0 H! P$ r
上面程序中的DFS函数定义在另一篇博文中:【 MATLAB 】离散傅里叶级数(DFS)及 IDFS 的 MATLAB 实现8 [1 n6 f2 l8 k

+ i. l# [: |6 P5 u* e) k/ a0 T
+ ~4 u4 u8 E5 H

, C& p+ s, L# Z# l* n0 I# Q+ W4 X5 O6 H' V7 Z! `) D5 v+ }
直接给出MATLAB脚本:
  ]- C+ _8 r6 V# x( P8 W3 [5 j
. W2 Q, ]8 p" L( P, k3 e! o/ D& Q
  • 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)');

  • ) |& V$ o; O1 e" T9 X8 |& @" f- c
              
1 P' ]$ E* ?; d/ r
' N, a1 m$ K  |2 Y; f% G" \7 p
. w2 f! E( e+ x! i; T

" `/ d! B) k( I. N5 q* J8 ^) T! q( R6 r. F. }% g( [
5 }& ~# V9 X6 I- K9 _
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

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

EDA365公众号

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

GMT+8, 2025-11-24 00:07 , Processed in 0.171875 second(s), 26 queries , Gzip On.

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

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

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