QQ登录

只需要一步,快速开始

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

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

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

1184

主题

4

听众

2911

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-23 16:21 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
  1. clear all
    $ S\" W0 I) q. k# X. V+ s# N
  2. syms x;
    \" ^0 L1 f, K\" @% A
  3. f=(exp(x)-1)*(sin(x)-1);        %直接由已定义的符号变量产生符号表达式
    9 H; _4 o' z( n8 f- h4 l- Y
  4. xx=-pi:pi/200:pi;
    * D7 V) u! D& @' e. A
  5. yy=subs(f,x,xx);   %将符号表达式中的x符号变量变为xx数值量求值
    + J) ~( |0 _/ ]\" a- L4 _
  6. n=9;
      j6 o& U# Y& c1 a: t\" `2 D
  7. f1=fseries(f,x,n); 4 B: P* [5 T% S& M8 s\" p' B9 o
  8. y1=subs(f1,x,xx);
    \" H- K$ w& V0 j3 P5 M( @5 E
  9. plot(xx,y1,xx,yy)
复制代码
  1. function F=fseries(f,x,n,a,b)
    : C8 R& l8 a; m+ r% d7 k; j8 F
  2. if nargin==3                %若输入为三个参数(缺省)表示f(x)在[-pi,pi]上展开3 P* r: L6 d\" |+ H  M) R- ]
  3.     a=-pi;
    \" D: B0 q2 L% y& ~0 n
  4.     b=pi;
    1 v% \5 v! z* B8 h  f3 I* g
  5. end
    : V) U0 i\" Q' p, d  W1 R8 ^
  6. L=(b-a)/2;
    # [) ~9 N7 I: `0 h\" p+ ^
  7. F=int(f,x,-L,L)/2*L;        %int(f,x,-L,L):以符号表达式或符号函数f为被积函数,x为积分变量,-L为下限,L为上限计算定积分( B\" U5 Z7 t1 F- A. h7 m! |
  8. for i=1:n
    7 ~/ |4 }, W. N  [! p
  9. an=int(f*cos(i*pi*x/L),x,-L,L)/L;2 d( E& J6 B! ^8 D% ]
  10. bn=int(f*sin(i*pi*x/L),x,-L,L)/L;2 X1 L& l7 c% `2 y) {$ D0 h
  11. F=F+an*cos(i*pi*x/L)+bn*sin(i*pi*x/L);
    \" T3 R0 {4 B8 i1 s* I7 D5 }
  12. end
    # X$ c: }$ j* {: q* F8 T- g0 |
复制代码
这段 MATLAB 代码使用了符号计算工具箱来进行函数的级数展开和绘图。以下是代码的逐行解释:
/ r, x4 L) c7 H! o6 F( t
; @* g* {2 C: O7 w' j! X1.clear all: 清除当前工作区的所有变量。
/ s8 u; x  _* M7 a3 S1 f$ T+ `2.syms x;: 声明符号变量 x。
9 A. S8 ?, |9 ^! Q/ l) Z6 [0 Q3.f=(exp(x)-1)*(sin(x)-1);: 定义符号表达式 f,该表达式为 ((e^x - 1) \cdot (\sin(x) - 1))。5 W' {+ `( V$ k. u# s0 Q$ v4 @. b
4.xx=-pi:pi/200:pi;: 生成一个包含从 (-\pi) 到 (\pi) 的数值的向量 xx。7 K8 T- [  a* }' R9 |, u
5.yy=subs(f,x,xx);: 使用 subs 函数将符号表达式中的符号变量 x 替换为数值向量 xx,得到数值向量 yy。  U* w- Z5 }- f  N8 i% L8 E
6.n=9;: 设定级数展开的阶数。
/ g% R& [  o( D8 }5 r7.f1=fseries(f,x,n);: 使用 fseries 函数对符号表达式 f 进行级数展开,展开阶数为 n,得到符号表达式 f1。3 c3 f9 a* @7 i
8.y1=subs(f1,x,xx);: 使用 subs 函数将符号表达式 f1 中的符号变量 x 替换为数值向量 xx,得到数值向量 y1。1 ^# _' N  Y* T6 ]! B
9.plot(xx,y1,xx,yy): 绘制级数展开后的函数曲线 y1 和原始函数曲线 yy。
# Q7 T6 X1 A9 S1 K9 r2 c1 v
1 w% c" S7 h0 h) _$ c* I这段代码的目的是通过符号计算工具箱,展开给定函数的级数,并绘制级数展开后的函数曲线和原始函数曲线。
1 _* I$ w7 k; b5 ^" E8 L( i QQ截图20231223160601.png
) v: L8 s/ H( H4 e3 k! I4 V. Y6 x2 l
) {1 ]0 j# F3 ^; x+ x

# M: {! K/ E: V/ |
0 E; S  Z1 N4 o4 J7 ?- L

傅里叶级数实验.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, 2025-12-17 21:47 , Processed in 0.815945 second(s), 55 queries .

回顶部