QQ登录

只需要一步,快速开始

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

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

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

1186

主题

4

听众

2923

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-23 16:21 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
  1. clear all
    6 b0 A+ ?6 `# h
  2. syms x;
    ( P  X1 a# O, }! W. k
  3. f=(exp(x)-1)*(sin(x)-1);        %直接由已定义的符号变量产生符号表达式
    / ]! ?  q& _2 D6 T2 N& ]' [
  4. xx=-pi:pi/200:pi;
    9 A! h+ ^0 s1 b8 n6 t0 B
  5. yy=subs(f,x,xx);   %将符号表达式中的x符号变量变为xx数值量求值
    % R7 T1 T& }; s, j
  6. n=9;
    7 f+ y3 c0 l6 a\" S' b7 B% }% \
  7. f1=fseries(f,x,n);
    0 X  L$ w. P0 }3 I( |( M
  8. y1=subs(f1,x,xx);
      y. ^$ ~9 s  _; Q* K3 i; \
  9. plot(xx,y1,xx,yy)
复制代码
  1. function F=fseries(f,x,n,a,b)
    $ z5 p. I4 n+ p
  2. if nargin==3                %若输入为三个参数(缺省)表示f(x)在[-pi,pi]上展开
    ( K, P5 H4 r8 _4 S7 ?\" _; M
  3.     a=-pi;
    6 S  p2 W0 ]0 `( i
  4.     b=pi;
    5 F- P4 t% `/ T1 s/ S, f% L0 j
  5. end
    3 i/ B0 t$ ]7 U, F; j/ `
  6. L=(b-a)/2;
    % E/ u' k1 A% B- ^
  7. F=int(f,x,-L,L)/2*L;        %int(f,x,-L,L):以符号表达式或符号函数f为被积函数,x为积分变量,-L为下限,L为上限计算定积分
    % E+ o& G; {1 [7 }
  8. for i=1:n, r: X- r+ B& ]$ S) M1 c: C
  9. an=int(f*cos(i*pi*x/L),x,-L,L)/L;
    5 q# z3 [4 e4 h6 }& C9 u5 L! j: c
  10. bn=int(f*sin(i*pi*x/L),x,-L,L)/L;; u- i' o- F0 |& m0 I
  11. F=F+an*cos(i*pi*x/L)+bn*sin(i*pi*x/L);  j. u% Y4 Z' ?; p8 h7 |
  12. end
    ) ^$ m1 M: |7 ?3 o
复制代码
这段 MATLAB 代码使用了符号计算工具箱来进行函数的级数展开和绘图。以下是代码的逐行解释:- F$ n, a+ J- O9 j, ~$ n9 M, q
, C5 p6 M, a3 f
1.clear all: 清除当前工作区的所有变量。, g2 S7 L/ k4 I% i: O/ \4 l
2.syms x;: 声明符号变量 x。
% @  J7 @. u5 i6 j  z+ p: w3.f=(exp(x)-1)*(sin(x)-1);: 定义符号表达式 f,该表达式为 ((e^x - 1) \cdot (\sin(x) - 1))。
0 c7 o, T; |) c' a( R* A' w4.xx=-pi:pi/200:pi;: 生成一个包含从 (-\pi) 到 (\pi) 的数值的向量 xx。' j* |+ J# c+ p( l8 L; g5 p! W
5.yy=subs(f,x,xx);: 使用 subs 函数将符号表达式中的符号变量 x 替换为数值向量 xx,得到数值向量 yy。
! `! ?" t4 M' T6.n=9;: 设定级数展开的阶数。
: m, e; w9 a: C7.f1=fseries(f,x,n);: 使用 fseries 函数对符号表达式 f 进行级数展开,展开阶数为 n,得到符号表达式 f1。
2 o+ H4 ^( Y# M  T) m8.y1=subs(f1,x,xx);: 使用 subs 函数将符号表达式 f1 中的符号变量 x 替换为数值向量 xx,得到数值向量 y1。3 }! m- y8 M: G' I4 k5 K' _) `7 r
9.plot(xx,y1,xx,yy): 绘制级数展开后的函数曲线 y1 和原始函数曲线 yy。
+ D, B# A( n! R2 i* `/ {' x* y% J' o! x* \" S7 J+ }* _
这段代码的目的是通过符号计算工具箱,展开给定函数的级数,并绘制级数展开后的函数曲线和原始函数曲线。4 G2 K  ?/ i+ w: `; H1 t
QQ截图20231223160601.png & b* H. S" D, [: T

, f2 }% Q' [. S, F* o! N) U: A4 O* l. O: L* Y& O1 T) O4 @

" D+ v8 V8 x0 F; a+ ?# {- Z
- t3 @! X! `7 O* C: v  U) |- p

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

回顶部