QQ登录

只需要一步,快速开始

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

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

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

1186

主题

4

听众

2923

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-23 16:21 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
  1. clear all
    \" v3 W) x' N: e
  2. syms x;
    $ W: T6 t' Y- w6 x
  3. f=(exp(x)-1)*(sin(x)-1);        %直接由已定义的符号变量产生符号表达式0 `+ U, B4 K+ p
  4. xx=-pi:pi/200:pi;& D/ x- h% Z3 m4 T8 G' P7 W
  5. yy=subs(f,x,xx);   %将符号表达式中的x符号变量变为xx数值量求值
    ! z7 K, d7 h5 r/ B! `9 Q
  6. n=9;. C% Z9 r9 g6 e. B
  7. f1=fseries(f,x,n); ! a/ }$ V( ~( r, x- {
  8. y1=subs(f1,x,xx);
    4 O3 O) _1 r1 }) h$ i
  9. plot(xx,y1,xx,yy)
复制代码
  1. function F=fseries(f,x,n,a,b)
    4 u+ v2 u: s: k1 A, M: ~
  2. if nargin==3                %若输入为三个参数(缺省)表示f(x)在[-pi,pi]上展开
    , N/ `+ r1 E2 T5 i4 y' g
  3.     a=-pi;$ s5 ^2 I0 ^3 M  i  i8 v8 J
  4.     b=pi;
    . G$ z\" \' D# H6 O0 X7 t1 }0 G
  5. end
    + e/ L6 r2 I/ [2 Q+ D! Z
  6. L=(b-a)/2;
    1 e- _2 U( k! c
  7. F=int(f,x,-L,L)/2*L;        %int(f,x,-L,L):以符号表达式或符号函数f为被积函数,x为积分变量,-L为下限,L为上限计算定积分
    2 y. D- D) J1 x2 v
  8. for i=1:n% I4 |. |  }  g4 v9 L. N, r$ {\" t
  9. an=int(f*cos(i*pi*x/L),x,-L,L)/L;/ K# l2 @! K\" t) d; b1 z% \
  10. bn=int(f*sin(i*pi*x/L),x,-L,L)/L;5 N9 _+ ~( V! Q1 w) W% f
  11. F=F+an*cos(i*pi*x/L)+bn*sin(i*pi*x/L);7 O! K/ `8 b- E, X
  12. end$ s* H\" H4 g5 e  m( h
复制代码
这段 MATLAB 代码使用了符号计算工具箱来进行函数的级数展开和绘图。以下是代码的逐行解释:; l$ D& t6 E( n
) W9 j6 w- `4 M' O! M
1.clear all: 清除当前工作区的所有变量。
) p: F* k+ \* z" |( w" z: ~! ]2.syms x;: 声明符号变量 x。
  u; `' d; Q" [) U2 T4 w  X3.f=(exp(x)-1)*(sin(x)-1);: 定义符号表达式 f,该表达式为 ((e^x - 1) \cdot (\sin(x) - 1))。
+ a- z  I# m2 J$ u* Y4.xx=-pi:pi/200:pi;: 生成一个包含从 (-\pi) 到 (\pi) 的数值的向量 xx。* ]+ L9 ~! m; Y5 _$ R1 X/ K
5.yy=subs(f,x,xx);: 使用 subs 函数将符号表达式中的符号变量 x 替换为数值向量 xx,得到数值向量 yy。( P+ O  h  W; g$ z$ P* J0 P) V& L
6.n=9;: 设定级数展开的阶数。8 {' Z- V( p) O  X  L) X
7.f1=fseries(f,x,n);: 使用 fseries 函数对符号表达式 f 进行级数展开,展开阶数为 n,得到符号表达式 f1。0 I! r& h# S* S8 O9 @: b: H) e
8.y1=subs(f1,x,xx);: 使用 subs 函数将符号表达式 f1 中的符号变量 x 替换为数值向量 xx,得到数值向量 y1。
1 }# g0 W+ [2 V9 u0 w; S7 F9.plot(xx,y1,xx,yy): 绘制级数展开后的函数曲线 y1 和原始函数曲线 yy。5 l7 l6 R3 p& e1 w0 J5 o

! j" w) ]* e$ q7 s0 L/ E+ w. x这段代码的目的是通过符号计算工具箱,展开给定函数的级数,并绘制级数展开后的函数曲线和原始函数曲线。
3 V8 ^5 t1 e9 f$ v$ a/ C; `% r QQ截图20231223160601.png : {" z5 B' Z' h5 J; M
9 G4 t, j, L& f: p  O; m- E# z

- t1 Z8 T, T- W$ h$ M" ^- d/ a4 s7 R

/ w) N, y2 _. i" o

傅里叶级数实验.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-27 09:27 , Processed in 0.422409 second(s), 54 queries .

回顶部