QQ登录

只需要一步,快速开始

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

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

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

845

主题

1

听众

2212

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-23 16:21 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
  1. clear all
    ' r, H5 ?4 X% i0 p7 _( _5 j( h* `+ x/ s
  2. syms x;
    8 {' J  G* n5 J7 j
  3. f=(exp(x)-1)*(sin(x)-1);        %直接由已定义的符号变量产生符号表达式+ A( \6 l+ U3 \$ ^- l\" {1 h
  4. xx=-pi:pi/200:pi;
    * M& n$ A$ c% T9 W9 n; ]5 M3 N
  5. yy=subs(f,x,xx);   %将符号表达式中的x符号变量变为xx数值量求值' t, u2 m, i) U: }' G\" V/ `9 v! n
  6. n=9;6 ?, o3 F$ g1 n8 \* ~# F0 G1 \
  7. f1=fseries(f,x,n); ! T% J+ l$ c  ~  f2 Y' l
  8. y1=subs(f1,x,xx);
    % O9 N8 \# Y2 h, \( `: u\" Y* [7 o
  9. plot(xx,y1,xx,yy)
复制代码
  1. function F=fseries(f,x,n,a,b)
    5 A- I- \0 R  L# {5 y/ g3 o
  2. if nargin==3                %若输入为三个参数(缺省)表示f(x)在[-pi,pi]上展开$ t) T  C/ N) \8 R
  3.     a=-pi;# |9 }, c( P3 ]\" ]; _- I
  4.     b=pi;
    ) {4 r0 C. d2 F' X. Y
  5. end- `0 c0 c. i0 T0 @! [
  6. L=(b-a)/2;
    ' L& ]5 z  {' y5 X) \) `
  7. F=int(f,x,-L,L)/2*L;        %int(f,x,-L,L):以符号表达式或符号函数f为被积函数,x为积分变量,-L为下限,L为上限计算定积分
    * T& d( _1 ]/ S9 [; ~& `
  8. for i=1:n
    , L2 i8 D5 `$ D0 `7 t\" Q
  9. an=int(f*cos(i*pi*x/L),x,-L,L)/L;
    # m2 J. C, B- Q7 V
  10. bn=int(f*sin(i*pi*x/L),x,-L,L)/L;6 ?0 a) t5 {+ g% T
  11. F=F+an*cos(i*pi*x/L)+bn*sin(i*pi*x/L);6 s4 S4 Q  Y( h* `/ T6 w' g4 z
  12. end) z% N\" ]  [% Q( l8 K' C! Y( g
复制代码
这段 MATLAB 代码使用了符号计算工具箱来进行函数的级数展开和绘图。以下是代码的逐行解释:
* G- P# K. k) E, w, Q! G7 C% m+ b4 o1 T
1.clear all: 清除当前工作区的所有变量。
. _% [" X- |# m* e2 F5 H9 M8 U2.syms x;: 声明符号变量 x。+ ~  A4 L4 y9 o7 k$ E
3.f=(exp(x)-1)*(sin(x)-1);: 定义符号表达式 f,该表达式为 ((e^x - 1) \cdot (\sin(x) - 1))。
" {( G1 a( B7 e% F4.xx=-pi:pi/200:pi;: 生成一个包含从 (-\pi) 到 (\pi) 的数值的向量 xx。" {* u3 v+ ^* x) r/ W7 J: I
5.yy=subs(f,x,xx);: 使用 subs 函数将符号表达式中的符号变量 x 替换为数值向量 xx,得到数值向量 yy。
  Y% e, E- i9 l" i% |/ ^" M4 `6.n=9;: 设定级数展开的阶数。6 f- [3 y3 M9 o" [1 `- E/ @' l
7.f1=fseries(f,x,n);: 使用 fseries 函数对符号表达式 f 进行级数展开,展开阶数为 n,得到符号表达式 f1。
* ?& R2 z, c; Q, k8.y1=subs(f1,x,xx);: 使用 subs 函数将符号表达式 f1 中的符号变量 x 替换为数值向量 xx,得到数值向量 y1。. K6 |7 Q' ~( I) |3 N# a
9.plot(xx,y1,xx,yy): 绘制级数展开后的函数曲线 y1 和原始函数曲线 yy。
! v& y1 D8 I. b- Y
' |! e& \: _7 L: S' S, @这段代码的目的是通过符号计算工具箱,展开给定函数的级数,并绘制级数展开后的函数曲线和原始函数曲线。+ w" l# _( Q8 l
QQ截图20231223160601.png
: C" s: R" r% [: |1 A" M
" k8 f* I( K/ Q2 R  A6 b. H) ?5 R' c$ a4 c7 e+ B
) k* y0 v4 k1 I+ \/ B
6 d8 x- y; u- {

傅里叶级数实验.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-6-17 02:05 , Processed in 0.286355 second(s), 54 queries .

回顶部