QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 3262|回复: 0
打印 上一主题 下一主题

[代码资源] matlab傅里叶实验

[复制链接]
字体大小: 正常 放大

1186

主题

4

听众

2923

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-23 16:21 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
  1. clear all2 {3 q: ?\" O0 i  b( L) c
  2. syms x;
    - M# k9 f. [6 Y* P( J/ @  w\" {
  3. f=(exp(x)-1)*(sin(x)-1);        %直接由已定义的符号变量产生符号表达式
    \" ^/ i# T% H% {2 d* X
  4. xx=-pi:pi/200:pi;
    : ^7 Q4 D3 J; |/ P
  5. yy=subs(f,x,xx);   %将符号表达式中的x符号变量变为xx数值量求值
    ) z7 y, L: O. A, u# i( M
  6. n=9;4 l+ D3 |3 X3 y$ K/ w
  7. f1=fseries(f,x,n); % a& W& {2 ^\" B& ]\" t3 S/ p. }
  8. y1=subs(f1,x,xx);
    ' D# J1 }- ]; t- U) l8 Z7 j
  9. plot(xx,y1,xx,yy)
复制代码
  1. function F=fseries(f,x,n,a,b)' r2 b3 M; _! u\" Q& }\" P  [9 g
  2. if nargin==3                %若输入为三个参数(缺省)表示f(x)在[-pi,pi]上展开
    ' H& b: ]% z. e' N- T. `
  3.     a=-pi;
    3 G* L- l% W# E  E: h! R! X
  4.     b=pi;
    \" E0 `1 d1 P% d
  5. end9 C' i+ O. [9 A; l/ c
  6. L=(b-a)/2;. Z3 k) M! d1 f3 L5 A( O0 W8 `
  7. F=int(f,x,-L,L)/2*L;        %int(f,x,-L,L):以符号表达式或符号函数f为被积函数,x为积分变量,-L为下限,L为上限计算定积分
    ' n2 O7 T# b: m4 ~; I
  8. for i=1:n
    ) O. `' k5 G. x- u6 M( V
  9. an=int(f*cos(i*pi*x/L),x,-L,L)/L;
    % P4 d6 P# z4 t: t/ w2 P9 G1 K
  10. bn=int(f*sin(i*pi*x/L),x,-L,L)/L;
    : e6 ~2 w; v/ V$ x; L0 T
  11. F=F+an*cos(i*pi*x/L)+bn*sin(i*pi*x/L);
    . S* a. d) ?2 ^& m
  12. end- D* L* {4 T: ~2 L3 j
复制代码
这段 MATLAB 代码使用了符号计算工具箱来进行函数的级数展开和绘图。以下是代码的逐行解释:
, \' A9 N2 [& Q7 B8 r$ b5 Y9 @! K) u
1.clear all: 清除当前工作区的所有变量。$ O' S5 }/ {) B' B; [  }+ l+ S8 M
2.syms x;: 声明符号变量 x。
& q+ _: G2 K$ W3.f=(exp(x)-1)*(sin(x)-1);: 定义符号表达式 f,该表达式为 ((e^x - 1) \cdot (\sin(x) - 1))。0 I' N! H- s4 {; Y
4.xx=-pi:pi/200:pi;: 生成一个包含从 (-\pi) 到 (\pi) 的数值的向量 xx。, L0 ^* x( l6 |. J2 g" V
5.yy=subs(f,x,xx);: 使用 subs 函数将符号表达式中的符号变量 x 替换为数值向量 xx,得到数值向量 yy。
+ b3 d7 U- }- I1 P1 D6.n=9;: 设定级数展开的阶数。
$ S# l- s- a& O# C7 C; g% o7.f1=fseries(f,x,n);: 使用 fseries 函数对符号表达式 f 进行级数展开,展开阶数为 n,得到符号表达式 f1。+ _( X4 F* Z2 E% \$ v1 O+ S1 M0 f
8.y1=subs(f1,x,xx);: 使用 subs 函数将符号表达式 f1 中的符号变量 x 替换为数值向量 xx,得到数值向量 y1。  ^* |5 i6 e! m
9.plot(xx,y1,xx,yy): 绘制级数展开后的函数曲线 y1 和原始函数曲线 yy。8 J2 G  X' f3 C/ x/ e7 M' x3 z

. B% z7 S' a4 \0 g" F8 G. A这段代码的目的是通过符号计算工具箱,展开给定函数的级数,并绘制级数展开后的函数曲线和原始函数曲线。
; k( c! l% a* F: A$ D" a# y: ` QQ截图20231223160601.png
3 a4 M) l8 w7 a" q: Y, o, o- E
& @7 y& D' W; D5 w+ D+ ^+ s
0 A* C- x' a/ W- q. n4 T$ G& ]) Z1 F, w1 ~9 d& ~

' j& N$ `% s/ w2 @! [/ m" `

傅里叶级数实验.rar

734 Bytes, 下载次数: 0, 下载积分: 体力 -2 点

售价: 1 点体力  [记录]  [购买]

zan
转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
您需要登录后才可以回帖 登录 | 注册地址

qq
收缩
  • 电话咨询

  • 04714969085
fastpost

关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

手机版|Archiver| |繁體中文 手机客户端  

蒙公网安备 15010502000194号

Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

GMT+8, 2026-4-21 10:47 , Processed in 0.445002 second(s), 55 queries .

回顶部