QQ登录

只需要一步,快速开始

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

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

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

1189

主题

4

听众

2934

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-23 16:21 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
  1. clear all
    ( F3 D8 R\" s4 a! X( h
  2. syms x;
    6 S* j6 S6 \# k  p' d9 V9 ]
  3. f=(exp(x)-1)*(sin(x)-1);        %直接由已定义的符号变量产生符号表达式0 q0 i5 {0 C- k+ Y7 |4 P
  4. xx=-pi:pi/200:pi;& A& S3 G4 T: E! o* g8 C
  5. yy=subs(f,x,xx);   %将符号表达式中的x符号变量变为xx数值量求值
    ; a% R3 D7 i; p& k! R8 K* t6 \
  6. n=9;
    . t. I\" W( }/ z# u0 N9 {7 z
  7. f1=fseries(f,x,n); 7 `, m; g. D  a\" }3 {0 Y
  8. y1=subs(f1,x,xx);
    # J+ \6 t; h! f3 w9 ]8 P
  9. plot(xx,y1,xx,yy)
复制代码
  1. function F=fseries(f,x,n,a,b)* q9 {+ f! C4 ~8 k- d$ G
  2. if nargin==3                %若输入为三个参数(缺省)表示f(x)在[-pi,pi]上展开
    \" h6 V5 @' v! e  P, e. ~+ R3 f- ]/ C3 I1 J
  3.     a=-pi;8 Q. t2 t: T8 [! O
  4.     b=pi;
    0 \6 w; I8 e/ x
  5. end
    : T3 N# e# z1 F( d
  6. L=(b-a)/2;
    7 ?0 s0 a% X, w: y3 @
  7. F=int(f,x,-L,L)/2*L;        %int(f,x,-L,L):以符号表达式或符号函数f为被积函数,x为积分变量,-L为下限,L为上限计算定积分
    ) \1 e\" F. q. k
  8. for i=1:n+ I, ]& O4 d+ T% n7 _2 W
  9. an=int(f*cos(i*pi*x/L),x,-L,L)/L;- h) r0 P) p# J8 J
  10. bn=int(f*sin(i*pi*x/L),x,-L,L)/L;) Y0 S2 o) J; o
  11. F=F+an*cos(i*pi*x/L)+bn*sin(i*pi*x/L);
    # f$ i& C2 k$ h! r
  12. end
    # _( Q! S8 L* z3 L1 b' O3 }
复制代码
这段 MATLAB 代码使用了符号计算工具箱来进行函数的级数展开和绘图。以下是代码的逐行解释:: [: s' e, f7 s! v1 `* i
* n: L' t; }3 h& g6 n  z( m
1.clear all: 清除当前工作区的所有变量。9 w1 l5 g  ^8 [3 x
2.syms x;: 声明符号变量 x。+ r+ r% ^$ U  x( o- Q
3.f=(exp(x)-1)*(sin(x)-1);: 定义符号表达式 f,该表达式为 ((e^x - 1) \cdot (\sin(x) - 1))。1 _2 ]" s; o7 R3 e6 T% J
4.xx=-pi:pi/200:pi;: 生成一个包含从 (-\pi) 到 (\pi) 的数值的向量 xx。
2 W7 M, [4 P& j5.yy=subs(f,x,xx);: 使用 subs 函数将符号表达式中的符号变量 x 替换为数值向量 xx,得到数值向量 yy。' }# k  d+ G1 g
6.n=9;: 设定级数展开的阶数。
8 {0 |) W$ L* z7.f1=fseries(f,x,n);: 使用 fseries 函数对符号表达式 f 进行级数展开,展开阶数为 n,得到符号表达式 f1。8 d4 M; z" L" i: M6 \9 U
8.y1=subs(f1,x,xx);: 使用 subs 函数将符号表达式 f1 中的符号变量 x 替换为数值向量 xx,得到数值向量 y1。
" F8 G& N; R! Q) E9.plot(xx,y1,xx,yy): 绘制级数展开后的函数曲线 y1 和原始函数曲线 yy。) ?7 y4 J5 @, q- I. \8 l
' o: x9 v9 q& J. `8 a9 A( \: W- b
这段代码的目的是通过符号计算工具箱,展开给定函数的级数,并绘制级数展开后的函数曲线和原始函数曲线。
$ G5 ?! J3 K2 h+ b/ h2 `+ P QQ截图20231223160601.png
4 \* F! N3 x+ t5 L
5 G- J2 O" i  \- L# B' ?
: l' R0 ~, G& X+ Z3 b; W: L6 `
+ H7 s  r; D# Q/ B$ ^; X7 {& J' ?# B1 D4 J/ f( j" S

傅里叶级数实验.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-6-15 22:15 , Processed in 0.418756 second(s), 55 queries .

回顶部