数学建模社区-数学中国

标题: matlab傅里叶实验 [打印本页]

作者: 2744557306    时间: 2023-12-23 16:21
标题: matlab傅里叶实验
  1. clear all
      u0 g( d- R, j. |, u8 P
  2. syms x;/ c2 V% ~8 Y+ Z
  3. f=(exp(x)-1)*(sin(x)-1);        %直接由已定义的符号变量产生符号表达式2 ]9 U+ G, N# D: r. q
  4. xx=-pi:pi/200:pi;
    1 K" d. c3 v9 x- T, o
  5. yy=subs(f,x,xx);   %将符号表达式中的x符号变量变为xx数值量求值' g/ V- g8 v* A0 a
  6. n=9;
    4 f6 B) r# }; N, r$ g* N0 V
  7. f1=fseries(f,x,n);
    7 ]6 G' k, V8 l5 s+ ]3 q
  8. y1=subs(f1,x,xx);" @  i4 [* e' y/ O! i  k
  9. plot(xx,y1,xx,yy)
复制代码
  1. function F=fseries(f,x,n,a,b)6 V9 w3 H' \- J" I; I9 @1 I
  2. if nargin==3                %若输入为三个参数(缺省)表示f(x)在[-pi,pi]上展开
    ) z6 h- ^! O3 |6 o  }2 Z
  3.     a=-pi;
    $ x2 ^  F; i: U/ m; [8 \
  4.     b=pi;
    9 r: z3 y5 h! B9 m3 g: S0 j3 r! k
  5. end0 a3 o( x, E/ g6 i& L$ X) s1 T: g8 f
  6. L=(b-a)/2;
    9 c" A, I4 O3 `1 d
  7. F=int(f,x,-L,L)/2*L;        %int(f,x,-L,L):以符号表达式或符号函数f为被积函数,x为积分变量,-L为下限,L为上限计算定积分# L* _* l0 b; _! Y0 d4 C
  8. for i=1:n( }2 @) q% a: ^: K
  9. an=int(f*cos(i*pi*x/L),x,-L,L)/L;
    ; q! K4 C* a- T7 ^# i7 Q4 z
  10. bn=int(f*sin(i*pi*x/L),x,-L,L)/L;
    % Q8 Y2 B0 p  |: _7 |& Q* \6 g
  11. F=F+an*cos(i*pi*x/L)+bn*sin(i*pi*x/L);
    ! k5 m, y2 V/ K" r' t- h( A
  12. end
    $ l& M& d+ l4 g
复制代码
这段 MATLAB 代码使用了符号计算工具箱来进行函数的级数展开和绘图。以下是代码的逐行解释:
2 r6 k& r5 u, F; g* ^0 R. P4 q$ b; D# ^' b' q
1.clear all: 清除当前工作区的所有变量。
. Q$ X/ {- o1 @4 y2.syms x;: 声明符号变量 x。4 F- S/ ]# ^% Q) F
3.f=(exp(x)-1)*(sin(x)-1);: 定义符号表达式 f,该表达式为 ((e^x - 1) \cdot (\sin(x) - 1))。
- p1 t& q( t7 e; ?4.xx=-pi:pi/200:pi;: 生成一个包含从 (-\pi) 到 (\pi) 的数值的向量 xx。2 `1 ~4 W; K7 n; I& {- `
5.yy=subs(f,x,xx);: 使用 subs 函数将符号表达式中的符号变量 x 替换为数值向量 xx,得到数值向量 yy。
8 s: d! o$ m# a8 ?3 F6.n=9;: 设定级数展开的阶数。( _0 D6 R6 E+ w4 c
7.f1=fseries(f,x,n);: 使用 fseries 函数对符号表达式 f 进行级数展开,展开阶数为 n,得到符号表达式 f1。
1 }! W% j7 b  c4 Z+ X: J8.y1=subs(f1,x,xx);: 使用 subs 函数将符号表达式 f1 中的符号变量 x 替换为数值向量 xx,得到数值向量 y1。7 N/ J% Y9 W; h8 C; j+ j
9.plot(xx,y1,xx,yy): 绘制级数展开后的函数曲线 y1 和原始函数曲线 yy。' W6 |# e4 E* c+ f: C

' ^; R+ V5 h; M+ x; J这段代码的目的是通过符号计算工具箱,展开给定函数的级数,并绘制级数展开后的函数曲线和原始函数曲线。) \! J0 A0 x5 I
QQ截图20231223160601.png : S) J; a$ N/ k. ~0 U. ]7 L
, r. b4 A5 ]. N

9 g6 U( R( N, Q3 F6 [9 Y$ Z; f; G$ b' W: C4 @

/ G' c1 N: S9 Z# a2 I& m

傅里叶级数实验.rar

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

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






欢迎光临 数学建模社区-数学中国 (http://www.madio.net/) Powered by Discuz! X2.5