QQ登录

只需要一步,快速开始

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

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

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

1175

主题

4

听众

2810

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-23 16:21 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
  1. clear all0 b3 N% F8 ~/ s% ^0 P
  2. syms x;
    ! ^. w/ X: B! @' j5 B2 C; Q* R5 F
  3. f=(exp(x)-1)*(sin(x)-1);        %直接由已定义的符号变量产生符号表达式6 g! C8 c$ Q/ s. {2 l; @2 T( M$ v0 E
  4. xx=-pi:pi/200:pi;0 v2 V. P  L' J% s; g
  5. yy=subs(f,x,xx);   %将符号表达式中的x符号变量变为xx数值量求值; R' b3 h/ m4 B) A9 p* ]( l
  6. n=9;) W$ b! q( H. E& B/ {
  7. f1=fseries(f,x,n); * P; o! S% T9 l0 s4 u: g- D
  8. y1=subs(f1,x,xx);
    7 O% T! Z, w. V\" P
  9. plot(xx,y1,xx,yy)
复制代码
  1. function F=fseries(f,x,n,a,b)
    4 r+ l! s- {2 q' V$ M
  2. if nargin==3                %若输入为三个参数(缺省)表示f(x)在[-pi,pi]上展开
    * n+ S% e/ M  f: B
  3.     a=-pi;$ x8 \+ G1 g( @: [. G9 {+ u. w+ |
  4.     b=pi;
    8 ?* w4 o# x, Z8 }: ]& T. n
  5. end9 N5 a, d5 g9 E\" q4 }7 W
  6. L=(b-a)/2;  @% P/ [# C4 e' L6 u
  7. F=int(f,x,-L,L)/2*L;        %int(f,x,-L,L):以符号表达式或符号函数f为被积函数,x为积分变量,-L为下限,L为上限计算定积分7 k- g& G1 a! M  w( a+ U0 ^
  8. for i=1:n; t; \8 k/ p\" _\" f8 A( _5 C: [
  9. an=int(f*cos(i*pi*x/L),x,-L,L)/L;3 d, b( c) U, G$ ?9 o+ q1 o
  10. bn=int(f*sin(i*pi*x/L),x,-L,L)/L;' e3 `, q; x: p+ o
  11. F=F+an*cos(i*pi*x/L)+bn*sin(i*pi*x/L);
    & N# }* N6 y) \) d# N0 _% Z
  12. end
    ' G; ^- U; {. a' }$ N
复制代码
这段 MATLAB 代码使用了符号计算工具箱来进行函数的级数展开和绘图。以下是代码的逐行解释:. u, L9 Y" C8 E
7 g4 P4 P, P  S' t0 Z1 c
1.clear all: 清除当前工作区的所有变量。
7 M, q9 O) X4 A. U+ Z8 q  k1 n2.syms x;: 声明符号变量 x。
9 [) ~1 _% Q3 f* @# T( V3.f=(exp(x)-1)*(sin(x)-1);: 定义符号表达式 f,该表达式为 ((e^x - 1) \cdot (\sin(x) - 1))。
  ?4 `3 [* a, C- N; W4.xx=-pi:pi/200:pi;: 生成一个包含从 (-\pi) 到 (\pi) 的数值的向量 xx。
- O% `& o  J; D4 `. R+ r+ |: r; {5.yy=subs(f,x,xx);: 使用 subs 函数将符号表达式中的符号变量 x 替换为数值向量 xx,得到数值向量 yy。! |4 d  U0 v% O3 Q- q. f7 U
6.n=9;: 设定级数展开的阶数。
. r  ~$ @  J% f4 n* C7.f1=fseries(f,x,n);: 使用 fseries 函数对符号表达式 f 进行级数展开,展开阶数为 n,得到符号表达式 f1。! z7 Z/ E  O2 s  ?0 y9 [
8.y1=subs(f1,x,xx);: 使用 subs 函数将符号表达式 f1 中的符号变量 x 替换为数值向量 xx,得到数值向量 y1。
8 F" X. G& n" `- {: j8 n9.plot(xx,y1,xx,yy): 绘制级数展开后的函数曲线 y1 和原始函数曲线 yy。
, ~7 G' @# K* o: a
/ d  M4 p' j8 P5 k* q" |% y& D这段代码的目的是通过符号计算工具箱,展开给定函数的级数,并绘制级数展开后的函数曲线和原始函数曲线。& S! `$ \, S" |6 V+ P& d
QQ截图20231223160601.png
. s/ a% k4 ^1 t% e- ~1 @0 N
4 W& G' c& p4 L- g  c* P/ n7 R6 R. e

! b9 w8 h" y# M' ?. R' D6 B. l% ^$ 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, 2025-7-10 10:04 , Processed in 0.329357 second(s), 55 queries .

回顶部