QQ登录

只需要一步,快速开始

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

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

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

1175

主题

4

听众

2810

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-23 16:21 |只看该作者 |正序浏览
|招呼Ta 关注Ta
  1. clear all2 p' U/ N7 f1 T) Y% @2 Z
  2. syms x;9 y, H9 k& e\" ^: E) s
  3. f=(exp(x)-1)*(sin(x)-1);        %直接由已定义的符号变量产生符号表达式
    ( a4 j4 }1 X\" C\" [0 u# M& H
  4. xx=-pi:pi/200:pi;
    / ?  t) V/ [. {( f3 i. N
  5. yy=subs(f,x,xx);   %将符号表达式中的x符号变量变为xx数值量求值
    7 T  p9 h+ c' \8 V8 d
  6. n=9;* G0 r& b0 a2 L6 h+ y0 \3 [
  7. f1=fseries(f,x,n); # M  G3 r+ R3 x0 C1 ]
  8. y1=subs(f1,x,xx);2 n! W4 H# v6 q( c+ d
  9. plot(xx,y1,xx,yy)
复制代码
  1. function F=fseries(f,x,n,a,b)
    : f1 |2 a4 c! ^( ]7 h; b# ?8 ^5 G
  2. if nargin==3                %若输入为三个参数(缺省)表示f(x)在[-pi,pi]上展开
    ! l6 b2 p6 ^; n; p& G  F\" [
  3.     a=-pi;
    ( O/ ?* a' K* l6 q% }7 n1 W
  4.     b=pi;0 K' |5 `- D( D
  5. end) W/ |9 H9 ^6 k# a, q& B, Y% c
  6. L=(b-a)/2;
    4 I3 q* {0 y3 K- U; e* {
  7. F=int(f,x,-L,L)/2*L;        %int(f,x,-L,L):以符号表达式或符号函数f为被积函数,x为积分变量,-L为下限,L为上限计算定积分  k7 f$ K1 I# k
  8. for i=1:n
    * Q! q) }% i  o( ]5 `5 C7 N
  9. an=int(f*cos(i*pi*x/L),x,-L,L)/L;
    7 E8 F. k% l! @% f
  10. bn=int(f*sin(i*pi*x/L),x,-L,L)/L;6 c1 ?' F- f3 q
  11. F=F+an*cos(i*pi*x/L)+bn*sin(i*pi*x/L);! s. [\" X) O% n+ `3 G/ L( M
  12. end
    . ?8 g4 A- C( @# G4 ]\" c
复制代码
这段 MATLAB 代码使用了符号计算工具箱来进行函数的级数展开和绘图。以下是代码的逐行解释:
" f, b+ |5 l/ H- C3 }
3 O7 c6 [  d7 {: }% I0 m: ^- L1.clear all: 清除当前工作区的所有变量。
8 C  ?5 M/ r9 {( U# l+ M9 x/ e2.syms x;: 声明符号变量 x。! z8 `9 }& w6 G8 [- i3 c' W# s
3.f=(exp(x)-1)*(sin(x)-1);: 定义符号表达式 f,该表达式为 ((e^x - 1) \cdot (\sin(x) - 1))。2 Z+ C) f+ Y2 W% r
4.xx=-pi:pi/200:pi;: 生成一个包含从 (-\pi) 到 (\pi) 的数值的向量 xx。
* ^' G6 W  C# B2 D$ d5.yy=subs(f,x,xx);: 使用 subs 函数将符号表达式中的符号变量 x 替换为数值向量 xx,得到数值向量 yy。$ \# ~, @0 Z% d; o2 e  ^7 J4 M" F
6.n=9;: 设定级数展开的阶数。7 b# u" o- K& r" ~. B' s
7.f1=fseries(f,x,n);: 使用 fseries 函数对符号表达式 f 进行级数展开,展开阶数为 n,得到符号表达式 f1。
$ R* {/ Z2 s. B+ W, t8.y1=subs(f1,x,xx);: 使用 subs 函数将符号表达式 f1 中的符号变量 x 替换为数值向量 xx,得到数值向量 y1。( a) C- X1 f7 K. q8 x
9.plot(xx,y1,xx,yy): 绘制级数展开后的函数曲线 y1 和原始函数曲线 yy。9 z6 ]: Q: v! P: F# x

" B3 W- B" u, e& I$ d& u这段代码的目的是通过符号计算工具箱,展开给定函数的级数,并绘制级数展开后的函数曲线和原始函数曲线。
" E- P" e8 H7 S2 ~* m3 Q9 Y8 _% \ QQ截图20231223160601.png & o0 ?  o% A/ j; \" [( o
5 }& V, [5 W& ^7 l4 S
1 Y: S% @& l( v5 E

8 M, e% v( N7 V2 {6 X1 u5 K( E7 Z
; l  U3 H: H) [- h2 N+ R

傅里叶级数实验.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-7-10 01:14 , Processed in 1.214946 second(s), 55 queries .

回顶部