Fourier Series Fit in Python(傅里叶级数在Python中的拟合)
问题描述
我有一些数据要使用二次、三次或四次傅立叶级数进行拟合。 虽然this关于堆栈溢出的问题和答案与我希望使用Scipy完成的任务很接近,但他们已经将其系数预定义为tau=0.045。我希望我的Fit能够找到具有95%可信区间的可能系数(a0、w1、w2、w3等),就像傅立叶级数的MATLAB curve fit等效项一样。我看到的另一个选项是使用fourier_series from sympy,但是这个函数只适用于与已定义函数匹配的符号参数,而不是原始数据。
1)是否有办法使渐近傅里叶级数接受原始数据,而不是使用此库的函数或其他变通方法?
2)或对给定多个未知数(系数)的数据进行Scipy曲线拟合
推荐答案
如果您愿意,您可以非常接近sympy
代码以进行数据拟合,使用我为此编写的名为symfit
的包。它基本上使用sympy
接口包装scipy
。使用symfit
,您可以执行类似以下操作:
这将打印我们需要的符号模型:
接下来,我将用一个简单的步长函数来拟合这个函数,向您展示它是如何工作的:
这将打印:
并生成以下图表:
就这么简单!我把剩下的留给你的想象。有关更多信息,请访问documentation here。
这篇关于傅里叶级数在Python中的拟合的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!