数学建模社区-数学中国

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

作者: 2744557306    时间: 2023-12-23 16:21
标题: matlab傅里叶实验
  1. clear all% I0 s( Z0 h) Y3 ?1 ?; O
  2. syms x;
      n) G- I5 ?- j1 X3 ?) y6 P" k/ v
  3. f=(exp(x)-1)*(sin(x)-1);        %直接由已定义的符号变量产生符号表达式: C+ f  ^$ B2 j- ?& A/ T# I- J5 S
  4. xx=-pi:pi/200:pi;
    ( }  R: s$ B" T) j  n2 e) v' u
  5. yy=subs(f,x,xx);   %将符号表达式中的x符号变量变为xx数值量求值
    9 L$ I4 O+ F& H: x* v. G+ y& s
  6. n=9;
    , F2 ]  F; w9 K6 u) k1 z
  7. f1=fseries(f,x,n);
    + D3 D2 f8 j) w7 @1 c. R$ C8 p
  8. y1=subs(f1,x,xx);
    - Z! ?* `1 A& f8 H; j8 W+ S0 s
  9. plot(xx,y1,xx,yy)
复制代码
  1. function F=fseries(f,x,n,a,b)
    9 B0 {/ ~: T) Y8 i& n
  2. if nargin==3                %若输入为三个参数(缺省)表示f(x)在[-pi,pi]上展开8 u: ^, E/ H4 ^; f6 l! l
  3.     a=-pi;
    " [6 g1 H7 y" |* m
  4.     b=pi;
    0 n2 S! ]. Z& r
  5. end3 F* c5 k8 Y) q0 k/ G! {
  6. L=(b-a)/2;$ _3 D. U$ o/ Q' v5 ]
  7. F=int(f,x,-L,L)/2*L;        %int(f,x,-L,L):以符号表达式或符号函数f为被积函数,x为积分变量,-L为下限,L为上限计算定积分5 C6 y) ]9 d7 L3 X& |- c# U/ ?
  8. for i=1:n5 H2 ^( T/ g& ]( n, d
  9. an=int(f*cos(i*pi*x/L),x,-L,L)/L;; N( D+ z; y- q8 C* l- Q$ O
  10. bn=int(f*sin(i*pi*x/L),x,-L,L)/L;& v- P) Y1 T9 l3 i1 c
  11. F=F+an*cos(i*pi*x/L)+bn*sin(i*pi*x/L);0 R* f$ O! ^& Y! K: Z; N
  12. end
    4 A5 L% k% g' F2 i( K
复制代码
这段 MATLAB 代码使用了符号计算工具箱来进行函数的级数展开和绘图。以下是代码的逐行解释:
7 U6 ?1 a) ?$ W! p! z# U7 x! @& x- i3 X+ S3 H+ X$ ^, N
1.clear all: 清除当前工作区的所有变量。. B% E& I& t0 e& e6 k1 {
2.syms x;: 声明符号变量 x。
: [: Q, d3 y3 R" f# Z3.f=(exp(x)-1)*(sin(x)-1);: 定义符号表达式 f,该表达式为 ((e^x - 1) \cdot (\sin(x) - 1))。" G! w5 D+ j; C# L8 {3 @1 b' n- V
4.xx=-pi:pi/200:pi;: 生成一个包含从 (-\pi) 到 (\pi) 的数值的向量 xx。7 \2 p/ M8 h* W: m, i$ d( x
5.yy=subs(f,x,xx);: 使用 subs 函数将符号表达式中的符号变量 x 替换为数值向量 xx,得到数值向量 yy。7 o" t# s( _% M+ a9 X" ^/ e
6.n=9;: 设定级数展开的阶数。
; H  L: S# c& w! C; C7.f1=fseries(f,x,n);: 使用 fseries 函数对符号表达式 f 进行级数展开,展开阶数为 n,得到符号表达式 f1。
3 W% o. v9 H( ^# {  A8.y1=subs(f1,x,xx);: 使用 subs 函数将符号表达式 f1 中的符号变量 x 替换为数值向量 xx,得到数值向量 y1。
7 k  v) Z3 H! S9.plot(xx,y1,xx,yy): 绘制级数展开后的函数曲线 y1 和原始函数曲线 yy。1 W9 @! d& B. q$ \, d" p

, v5 H% W" v$ c" X- m这段代码的目的是通过符号计算工具箱,展开给定函数的级数,并绘制级数展开后的函数曲线和原始函数曲线。( x3 K. |! \- {) U# j+ q
QQ截图20231223160601.png . d6 i: f9 W9 `3 G6 t
, O% D( U' e' h# x' {' [
0 H0 Z, U( D$ A2 N$ r

3 e' G1 G8 M! T2 p" a& O1 o- T% U6 e0 q

傅里叶级数实验.rar

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

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






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