QQ登录

只需要一步,快速开始

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

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

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

795

主题

1

听众

1982

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-23 16:21 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
  1. clear all
    \" `5 N. X& ^8 q% @; T8 e$ Z* @
  2. syms x;
    & l. F3 \# `7 l\" _' F\" Y$ v( Z4 W$ W/ b$ f
  3. f=(exp(x)-1)*(sin(x)-1);        %直接由已定义的符号变量产生符号表达式
    ' M( J9 s# z3 h
  4. xx=-pi:pi/200:pi;
    . A, ^( B$ y* Z9 t3 b
  5. yy=subs(f,x,xx);   %将符号表达式中的x符号变量变为xx数值量求值
    # @( }4 l% R' @' _7 N1 N+ w$ M  I' \
  6. n=9;0 O/ i% c6 u$ {9 F) _5 [
  7. f1=fseries(f,x,n);
    . n7 K' S' @) }- s1 X1 y, P
  8. y1=subs(f1,x,xx);
    3 ~- w! N0 S& z1 z8 o. x( z
  9. plot(xx,y1,xx,yy)
复制代码
  1. function F=fseries(f,x,n,a,b)* i/ ]% O3 V! k0 i3 m
  2. if nargin==3                %若输入为三个参数(缺省)表示f(x)在[-pi,pi]上展开' g7 |- C$ l( f# U
  3.     a=-pi;0 v: n& J2 n8 x  u% f) Q: O
  4.     b=pi;* S* R! T* m5 W4 t7 P
  5. end6 o, x& J! Z/ ^- ?) Y( R) Y+ h
  6. L=(b-a)/2;( l; J' ^; H4 t1 q6 d# A6 C
  7. F=int(f,x,-L,L)/2*L;        %int(f,x,-L,L):以符号表达式或符号函数f为被积函数,x为积分变量,-L为下限,L为上限计算定积分) c! F  B4 X, }4 I
  8. for i=1:n1 O% [) u, c4 M
  9. an=int(f*cos(i*pi*x/L),x,-L,L)/L;
    , k& k  W+ i. }  g  k
  10. bn=int(f*sin(i*pi*x/L),x,-L,L)/L;
    8 m$ v  L; \8 O% |: P
  11. F=F+an*cos(i*pi*x/L)+bn*sin(i*pi*x/L);  m$ L/ {+ u, I/ |
  12. end7 Q7 Z! n3 d6 {5 J
复制代码
这段 MATLAB 代码使用了符号计算工具箱来进行函数的级数展开和绘图。以下是代码的逐行解释:
2 }  m* I5 y1 A& Y6 r- m2 g8 A  j2 i: B% |3 A" X8 c/ P1 i7 I
1.clear all: 清除当前工作区的所有变量。
3 X& h" b' F! j, S& U2.syms x;: 声明符号变量 x。
$ z: R: K+ I' k3.f=(exp(x)-1)*(sin(x)-1);: 定义符号表达式 f,该表达式为 ((e^x - 1) \cdot (\sin(x) - 1))。# P0 c4 J7 D  s
4.xx=-pi:pi/200:pi;: 生成一个包含从 (-\pi) 到 (\pi) 的数值的向量 xx。
* E! }' P' |8 W5.yy=subs(f,x,xx);: 使用 subs 函数将符号表达式中的符号变量 x 替换为数值向量 xx,得到数值向量 yy。& u# O$ [- H7 y5 E& `
6.n=9;: 设定级数展开的阶数。' K8 K8 l$ K! m4 F
7.f1=fseries(f,x,n);: 使用 fseries 函数对符号表达式 f 进行级数展开,展开阶数为 n,得到符号表达式 f1。1 S  z9 C" Y. x! l+ z% y( v9 A
8.y1=subs(f1,x,xx);: 使用 subs 函数将符号表达式 f1 中的符号变量 x 替换为数值向量 xx,得到数值向量 y1。  x0 ]7 p  e. P
9.plot(xx,y1,xx,yy): 绘制级数展开后的函数曲线 y1 和原始函数曲线 yy。
9 [3 k( N# Z9 ?4 [
7 v$ U/ N8 u) D# R这段代码的目的是通过符号计算工具箱,展开给定函数的级数,并绘制级数展开后的函数曲线和原始函数曲线。
* g% N8 \4 q& L% S QQ截图20231223160601.png 0 ]. B* v  j" X/ T# p- i. L9 @2 z* R
4 j' v: v1 `$ R  p0 r9 b

' f4 O. |$ q& m% `2 R
+ |" A6 z. K7 X) s: e5 V! F/ Z4 M3 Y  q3 M

傅里叶级数实验.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-5-6 15:15 , Processed in 0.315164 second(s), 54 queries .

回顶部