首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >傅里叶级数Matlab程序

傅里叶级数Matlab程序
EN

Stack Overflow用户
提问于 2018-01-10 20:24:46
回答 1查看 2.5K关注 0票数 0

我创建了这段代码,以计算和勾勒傅里叶系数A0、An和Bn,而不使用Fourier Series命令,但不幸的是,绘图结果并不像Fourier级数。如果有人能指导我解决这个问题。谢谢

我确定了我将要在这个项目中使用的所有术语。

代码语言:javascript
复制
T=1; %Time Period 
wo=2*pi/T;
a0=0;% coefficient 
A0=0;% coefficient
a1=0;% coefficient
A1=0;% coefficient
a2=0;% coefficient
A2=0;% coefficient
a3=0;% coefficient
A3=0;% coefficient
a4=0;% coefficient
A4=0;% coefficient
a5=0;% coefficient
A5=0;% coefficient
a6=0;% coefficient
A6=0;% coefficient
a7=0;% coefficient
B7=0;% coefficient
b1=0;% coefficient
B1=0;% coefficient
b2=0;% coefficient
B2=0;% coefficient
b3=0;% coefficient
B3=0;% coefficient
b4=0;% coefficient
B4=0;% coefficient
b5=0;% coefficient
B5=0;% coefficient
b6=0;% coefficient
B6=0;% coefficient
b7=0;% coefficient
B7=0;% coefficient

在这一步。我想要计算我的函数的值并将它们存储在一个矩阵中。

代码语言:javascript
复制
x=0:0.1:T; % x is the time axis
k=1:T/0.1+1;
funcation=x;
F(k)=funcation;
for x=0:0.1:T;
  k=1:T/0.1+1;
  a0=F(k)+a0;
end
A0=0.1*a0/T;
for x=0:0.1:T;
  k=1:T/0.1+1;
  b1=F(k).*sin(1.*wo.*x)+b1;
  b2=F(k).*sin(2.*wo.*x)+b2;
  b3=F(k).*sin(3.*wo.*x)+b3;
  b4=F(k).*sin(4.*wo.*x)+b4;
  b5=F(k).*sin(5.*wo.*x)+b5;
  b6=F(k).*sin(6.*wo.*x)+b6;
  b7=F(k).*sin(7.*wo.*x)+b7;
end
for x=0:0.1:T;
  B1=0.1.*2.*b1./T.*sin(1.*wo.*x);
  B2=0.1.*2.*b2./T.*sin(2.*wo.*x);
  B3=0.1.*2.*b3./T.*sin(3.*wo.*x);
  B4=0.1.*2.*b4./T.*sin(4.*wo.*x);
  B5=0.1.*2.*b5./T.*sin(5.*wo.*x);
  B6=0.1.*2.*b6./T.*sin(6.*wo.*x);
  B7=0.1.*2.*b7./T.*sin(7.*wo.*x);
end
bq=B1+B2+B3+B4+B5+B6+B7;

for x=0:0.1:T;
  k=1:T/0.1+1;
  a1=F(k).*cos(1.*wo.*x)+a1;
  a2=F(k).*cos(2.*wo.*x)+a2;
  a3=F(k).*cos(3.*wo.*x)+a3;
  a4=F(k).*cos(4.*wo.*x)+a4;
  a5=F(k).*cos(5.*wo.*x)+a5;
  a6=F(k).*cos(6.*wo.*x)+a6;
  a7=F(k).*cos(7.*wo.*x)+a7;
end
for x=0:0.1:T;
  A1=0.1.*2.*a1./T.*cos(1.*wo.*x);
  A2=0.1.*2.*a2./T.*cos(2.*wo.*x);
  A3=0.1.*2.*a3./T.*cos(3.*wo.*x);
  A4=0.1.*2.*a4./T.*cos(4.*wo.*x);
  A5=0.1.*2.*a5./T.*cos(5.*wo.*x);
  A6=0.1.*2.*a6./T.*cos(6.*wo.*x);
  A7=0.1.*2.*a7./T.*cos(7.*wo.*x);
end
aq=A1+A2+A3+A4+A5+A6+A7;

FQ=bq+aq+A0;
plot(F(k))
figure
plot(FQ)
EN

回答 1

Stack Overflow用户

发布于 2018-01-13 08:05:36

问题是在脚本中定义for循环。您不应该在;表达式的末尾插入分号for。而不是:

for x=0:0.1:T;

您应该省略;并将其写成如下:

for x=0:0.1:T

然后,这些情节运作良好,两个情节将是相同的。因为这里的函数是y=x,它将是一条45度的直线。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/48195497

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档