上一篇文章中我们了解了ApacheCommonsMath3探索之多项式曲线拟合实现代码,今天我们就来看看如何通过apachecommonsmath3实现快速傅里叶变换,下面是具体内容。
傅立叶变换:org.apache.commons.math3.transform.FastFourierTransformer类。
用法示例代码:
doubleinputData=newdouble[arrayLength];
//...给inputData赋值
FastFourierTransformerfft=newFastFourierTransformer(DftNormalization.STANDARD);
Complex[]result=fft.transform(inputData,TransformType.FORWARD);
使用还是非常简单的。首先要创建待计算数据的数组,可以是double类型,亦可是org.apache.commons.math3.complex.Complex类型,然后创建org.apache.commons.math3.transform.FastFourierTransformer对象实例,最后调用其transform方法即可得到存放于复数数组中的傅立叶变换结果。
完整的示例代码如下:
importorg.apache.commons.math3.transform.DftNormalization;
importorg.apache.commons.math3.transform.FastFourierTransformer;
importorg.apache.commons.math3.transform.TransformType;
interfaceTestCase
{
publicObjectrun(List
在i5四核处理器+16GB内存的台式机上,计算4百万点FFT,耗时0.7s。还是挺快的。
总结
以上就是本文关于ApacheCommonsMath3探索之快速傅立叶变换代码示例的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站:ApacheCommonsMath3学习之数值积分实例代码、apachezookeeper使用方法实例详解等,有什么问题可以随时留言,小编会及时回复大家的。最后推荐几本有关Java编程方面不错的书籍,免费下载,供广大编程爱好及工作者参考,提高!
JavaWeb开发就该这样学(王洋著)pdf扫描版
https://www.nhooo.com/books/561375.html
Spring+MyBatis企业应用实战完整pdf扫描版
https://www.nhooo.com/books/560647.html
希望大家喜欢,更多精彩内容,就在https://www.nhooo.com/