2
这里是傅里叶级数的情节我的M-文件:傅里叶级数 - 情节在Matlab
clear
clc
syms n
a0=input('Enter coefficient a0: ');
an=input('Enter coefficient an: ');
bn=input('Enter coefficient bn: ');
a=input('Enter lower boundary: ');
b=input('Enter upper boundary: ');
t=linspace(a,b,10000);
suma=0;
for n=1:10 %% n could be any number, bigger n - better approximation
suma=suma+(subs(an,'n',n).*cos(2.*n.*pi.*t./(b-a))+subs(bn,'n',n).*sin(2.*n.*pi.*t./(b-a)));
end
series=a0+suma;
plot(t,series)
grid
问题是,它是如此之慢!为了提高速度,我应该在代码中更改哪些内容?
编辑:在参考macduff的评论: 这样的事情?
clear
clc
a0=input('Enter coefficient a0: ');
an=input('Enter coefficient an: ','s');
bn=input('Enter coefficient bn: ','s');
a=input('Enter lower boundary: ');
b=input('Enter upper boundary: ');
t=linspace(a,b,10000);
suma=0;
for n=1:10000 %% n could be any number, bigger n - better approximation
ebn = evalin('caller',bn);
ean = evalin('caller',an);
suma = suma + (ean.*cos(2.*n.*pi.*t./(b-a)) + ebn.*sin(2.*n.*pi.*t./(b-a)));
end
series=a0+suma;
plot(t,series)
grid
是的,这就是我所期待的,希望它有用! – macduff 2014-09-22 19:56:02
现在速度如此之快:)非常感谢! – etf 2014-09-22 20:43:58
您可以检查代码[在此可单击的链接](http://pastebin.com/DWrGPy6q)是否与您的代码产生相同的结果? – Divakar 2014-09-25 17:07:42