QQ登录

只需要一步,快速开始

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

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

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

1189

主题

4

听众

2934

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-23 16:21 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
  1. clear all
    / x6 j3 {9 Q( o2 ^$ s, l
  2. syms x;. b6 m& T. `\" Y$ H3 l) J- G/ M
  3. f=(exp(x)-1)*(sin(x)-1);        %直接由已定义的符号变量产生符号表达式0 V( A0 r8 j9 |7 R
  4. xx=-pi:pi/200:pi;6 h- ^, o3 f( D
  5. yy=subs(f,x,xx);   %将符号表达式中的x符号变量变为xx数值量求值4 Q, u* V* q. Z7 V\" T6 C7 @6 `
  6. n=9;
    6 U3 P: Q\" }5 L' h
  7. f1=fseries(f,x,n); 8 m. p! w# {6 K* n8 m. p
  8. y1=subs(f1,x,xx);
    / A\" }1 H  {+ U# E4 E0 o  H1 ?
  9. plot(xx,y1,xx,yy)
复制代码
  1. function F=fseries(f,x,n,a,b)2 m0 h* ]5 e/ g8 M' ^0 I- i
  2. if nargin==3                %若输入为三个参数(缺省)表示f(x)在[-pi,pi]上展开& V; k6 D2 e4 v' i( G5 g0 u
  3.     a=-pi;
    3 Z\" j1 K3 J+ I7 w# X: s
  4.     b=pi;\" ^9 R: s5 W: [0 m8 b
  5. end
    ! `3 k, p1 C* ]  {3 s1 v8 y
  6. L=(b-a)/2;0 C1 m+ N! s& ]* q. X; b& i
  7. F=int(f,x,-L,L)/2*L;        %int(f,x,-L,L):以符号表达式或符号函数f为被积函数,x为积分变量,-L为下限,L为上限计算定积分
    1 J% }% S4 d0 t, ]& e% N% J' _
  8. for i=1:n( b2 _& y0 |- ~4 a, a7 O4 z
  9. an=int(f*cos(i*pi*x/L),x,-L,L)/L;7 s- k- @5 K6 W$ y5 y5 v
  10. bn=int(f*sin(i*pi*x/L),x,-L,L)/L;
    % {( y6 s) }, O3 L2 U# ^
  11. F=F+an*cos(i*pi*x/L)+bn*sin(i*pi*x/L);% f. K7 t4 ]+ i* s) G1 I
  12. end
    ( l9 F2 W0 q0 w0 A! ^& _\" s# c
复制代码
这段 MATLAB 代码使用了符号计算工具箱来进行函数的级数展开和绘图。以下是代码的逐行解释:
3 `. v5 m5 s+ M* N$ P/ Q$ g; C) P
4 W- g, d& v' k  D" W" e, T# G& s1.clear all: 清除当前工作区的所有变量。
9 m& n4 N: A! s7 b) n2 A2.syms x;: 声明符号变量 x。
3 R7 i. |+ p: B6 S+ D/ E/ ~3.f=(exp(x)-1)*(sin(x)-1);: 定义符号表达式 f,该表达式为 ((e^x - 1) \cdot (\sin(x) - 1))。* h: Y" ?! N/ N1 E0 @
4.xx=-pi:pi/200:pi;: 生成一个包含从 (-\pi) 到 (\pi) 的数值的向量 xx。
' ^  h4 f! i3 f, V8 ?6 Q6 a5.yy=subs(f,x,xx);: 使用 subs 函数将符号表达式中的符号变量 x 替换为数值向量 xx,得到数值向量 yy。
* C& w6 G7 [: V6.n=9;: 设定级数展开的阶数。# g4 I8 R$ Q1 G
7.f1=fseries(f,x,n);: 使用 fseries 函数对符号表达式 f 进行级数展开,展开阶数为 n,得到符号表达式 f1。
4 E' {8 P7 l5 Q2 q9 M8.y1=subs(f1,x,xx);: 使用 subs 函数将符号表达式 f1 中的符号变量 x 替换为数值向量 xx,得到数值向量 y1。: h' q) A+ x5 @7 w6 R  n
9.plot(xx,y1,xx,yy): 绘制级数展开后的函数曲线 y1 和原始函数曲线 yy。
) w4 u( X2 T( Z1 }" g* _, G- v/ T# y& }. n" W  M
这段代码的目的是通过符号计算工具箱,展开给定函数的级数,并绘制级数展开后的函数曲线和原始函数曲线。
' G5 S, ^. j4 T- `  h; o! d  B; v QQ截图20231223160601.png
" {$ J( c6 d/ c- B6 B/ B0 E4 G+ u7 Y9 S7 t

" H: w- R1 o4 R# n+ f& _/ T" q+ a- {* o/ D  G" T( ]0 _
# |8 U$ ]# R, K2 }' h

傅里叶级数实验.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-6-12 01:55 , Processed in 0.544657 second(s), 54 queries .

回顶部