QQ登录

只需要一步,快速开始

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

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

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

1003

主题

4

听众

2531

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-23 16:21 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
  1. clear all0 M* b) m0 o( _# K. Y
  2. syms x;
    % S' h+ }3 C\" {4 m
  3. f=(exp(x)-1)*(sin(x)-1);        %直接由已定义的符号变量产生符号表达式; d\" ^+ N$ |- f8 G* ?4 g6 O
  4. xx=-pi:pi/200:pi;7 X% e4 \7 a5 G- X\" s3 S
  5. yy=subs(f,x,xx);   %将符号表达式中的x符号变量变为xx数值量求值* j- d& f8 S$ L( i0 Q8 a% T* V3 v
  6. n=9;
    $ O) x. z- H6 x; n/ m7 w0 ^8 J
  7. f1=fseries(f,x,n);
    % _; i) ?! A3 [4 Q\" \
  8. y1=subs(f1,x,xx);
    0 ^- F6 \% _+ E4 U9 V4 l
  9. plot(xx,y1,xx,yy)
复制代码
  1. function F=fseries(f,x,n,a,b)0 C4 F1 J  i\" {$ ~& k
  2. if nargin==3                %若输入为三个参数(缺省)表示f(x)在[-pi,pi]上展开; t  L) A8 h3 I( {) P+ N, p
  3.     a=-pi;4 d  Q8 n' u# D
  4.     b=pi;0 N+ w% B9 a! J; g
  5. end
    5 G4 |) X6 S  ]; l$ {
  6. L=(b-a)/2;5 M; @+ B2 f) ]8 Y
  7. F=int(f,x,-L,L)/2*L;        %int(f,x,-L,L):以符号表达式或符号函数f为被积函数,x为积分变量,-L为下限,L为上限计算定积分, {, x8 N2 E+ ?# s* [
  8. for i=1:n  z/ c, Y' k% V% P# }: x
  9. an=int(f*cos(i*pi*x/L),x,-L,L)/L;' `/ M* {8 i\" T7 A/ j
  10. bn=int(f*sin(i*pi*x/L),x,-L,L)/L;
    , @2 U8 f7 x, ^) {- R& Z
  11. F=F+an*cos(i*pi*x/L)+bn*sin(i*pi*x/L);
    7 e9 Y! [& }, T' U0 m- g+ f6 ~0 F
  12. end
    0 a  z/ K4 E- q\" g3 ^$ P0 P$ \
复制代码
这段 MATLAB 代码使用了符号计算工具箱来进行函数的级数展开和绘图。以下是代码的逐行解释:! V4 @( k! R( o) a' a! l7 D7 {! y5 n

! u! ?; P  L8 v  T' u1.clear all: 清除当前工作区的所有变量。
7 `  K/ Q3 v" F7 ?( y! i6 i2.syms x;: 声明符号变量 x。7 Q6 `  C1 \9 D' a+ u
3.f=(exp(x)-1)*(sin(x)-1);: 定义符号表达式 f,该表达式为 ((e^x - 1) \cdot (\sin(x) - 1))。3 }6 M* k% n8 N* S5 W& J3 W+ n6 |. `
4.xx=-pi:pi/200:pi;: 生成一个包含从 (-\pi) 到 (\pi) 的数值的向量 xx。
0 ]. f3 y! G( T5.yy=subs(f,x,xx);: 使用 subs 函数将符号表达式中的符号变量 x 替换为数值向量 xx,得到数值向量 yy。
- m0 v, l  ~' E* y: O, U7 z6.n=9;: 设定级数展开的阶数。
; ~1 j( a6 v. d9 V3 F/ \% E5 H* Q7.f1=fseries(f,x,n);: 使用 fseries 函数对符号表达式 f 进行级数展开,展开阶数为 n,得到符号表达式 f1。# u7 N* @9 y  _4 q
8.y1=subs(f1,x,xx);: 使用 subs 函数将符号表达式 f1 中的符号变量 x 替换为数值向量 xx,得到数值向量 y1。- p& m( l1 s2 e
9.plot(xx,y1,xx,yy): 绘制级数展开后的函数曲线 y1 和原始函数曲线 yy。  B4 z  ~9 H. h1 {+ i/ I/ W  f! Z
5 j- {! V" |3 [
这段代码的目的是通过符号计算工具箱,展开给定函数的级数,并绘制级数展开后的函数曲线和原始函数曲线。
; \3 O+ f, F; f QQ截图20231223160601.png 9 V% J3 W3 i6 ]/ J  h# Z
3 b& Y# f! \; z: r4 z& @

7 v' k; R# J, o( _9 P$ X
- j* b8 o4 @4 T! ~' _& l4 @2 a  Z, @; 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, 2024-9-21 18:30 , Processed in 0.343707 second(s), 55 queries .

回顶部