Apache Commons Math3学习笔记(2) - 多项式曲线拟合(转)
多项式曲线拟合:org.apache.commons.math3.fitting.PolynomialCurveFitter类。
用法示例代码:
- // ... 创建并初始化输入数据:
- double[] x = new double[...];
- double[] y = new double[...];
- 将原始的x-y数据序列合成带权重的观察点数据序列:
- WeightedObservedPoints points = new WeightedObservedPoints();
- // 将x-y数据元素调用points.add(x[i], y[i])加入到观察点序列中
- // ...
- PolynomialCurveFitter fitter = PolynomialCurveFitter.create(degree); // degree 指定多项式阶数
- double[] result = fitter.fit(points.toList()); // 曲线拟合,结果保存于双精度数组中,由常数项至最高次幂系数排列
首先要准备好待拟合的曲线数据x和y,这是两个double数组,然后把这两个数组合并到WeightedObservedPoints对象实例中,可以调用WeightedObservedPoints.add(x[i], y[i])将x和y序列中的数据逐个添加到观察点序列对象中。随后创建PolynomialCurveFitter对象,创建时要指定拟合多项式的阶数,注意阶数要选择适当,不是越高越好,否则拟合误差会很大。最后调用PolynomialCurveFitter的fit方法即可完成多项式曲线拟合,fit方法的参数通过WeightedObservedPoints.toList()获得。拟合结果通过一个double数组返回,按元素顺序依次是常数项、一次项、二次项、……。
完整的演示代码如下:
package fitting; import org.apache.commons.math3.fitting.PolynomialCurveFitter;
import org.apache.commons.math3.fitting.WeightedObservedPoints; import java.util.ArrayList;
import java.util.List; public class TimeCostCalculator {
public static void main(String[] args) throws Exception {
TimeCostCalculator tcc = new TimeCostCalculator();
double timeCost = tcc.calcTimeCost(new CalcCurveFitting());
System.out.println("--------------------------------------------------------------------------");
System.out.println("time cost is: " + timeCost + "s");
System.out.println("--------------------------------------------------------------------------");
} /**
* 计算指定对象的运行时间开销。
*
* @param curveFitting 指定被测对象。
* @return 返回sub.run的时间开销,单位为s。
* @throws Exception
*/
public double calcTimeCost(CurveFitting curveFitting) throws Exception {
List<Object> params = curveFitting.getParams();
long startTime = System.nanoTime();
Object result = curveFitting.run(params);
long stopTime = System.nanoTime();
curveFitting.printResult(result);
System.out.println("start: " + startTime + " / stop: " + stopTime);
return 1.0e-9 * (stopTime - startTime);
} } interface CurveFitting {
public List<Object> getParams(); public Object run(List<Object> params) throws Exception; public void printResult(Object result);
} class CalcCurveFitting implements CurveFitting { private WeightedObservedPoints points; private final int degree = 5; // 阶数 public CalcCurveFitting() {
int arrayLength = 200000;
System.out.println(String.format("本算例用于计算多项式曲线拟合。正在初始化计算数据(%s点,%s阶......", arrayLength, degree));
double[] inputDataX = new double[arrayLength];
// inputDataX = new double[] {1, 2, 3, 4, 5, 6, 7};
double[] inputDataY = new double[inputDataX.length];
double[] factor = new double[degree + 1]; // N阶多项式会有N+1个系数,其中之一为常数项
for (int index = 0; index < factor.length; index++) {
factor[index] = index + 1;
}
for (int index = 0; index < inputDataY.length; index++) {
inputDataX[index] = index * 0.00001;
inputDataY[index] = calcPoly(inputDataX[index], factor); // y = sum(x[n) * fact[n])
// System.out.print(inputDataY[index] + ", ");
}
points = new WeightedObservedPoints();
for (int index = 0; index < inputDataX.length; index++) {
points.add(inputDataX[index], inputDataY[index]);
}
System.out.println("init completely");
} @Override
public List<Object> getParams() {
List<Object> params = new ArrayList<Object>();
params.add(points);
return params;
} @Override
public Object run(List<Object> params) throws Exception {
PolynomialCurveFitter fitter = PolynomialCurveFitter.create(degree);
WeightedObservedPoints points = (WeightedObservedPoints) params.get(0);
double[] result = fitter.fit(points.toList());
return result;
} @Override
public void printResult(Object result) {
for (double data : (double[]) result) {
System.out.println(data);
}
} private double calcPoly(double x, double[] factor) {
double y = 0;
for (int deg = 0; deg < factor.length; deg++) {
y += Math.pow(x, deg) * factor[deg];
}
return y;
} }
http://blog.csdn.net/kingfox/article/details/44118319
Apache Commons Math3学习笔记(2) - 多项式曲线拟合(转)的更多相关文章
- CloudSim4.0报错NoClassDefFoundError,Caused by: java.lang.ClassNotFoundException: org.apache.commons.math3.distribution.UniformRealDistribution
今天下载了CloudSim 4.0的代码,运行其中自带的示例程序,结果有一部分运行错误: 原因是找不到org.apache.commons.math3.distribution.UniformReal ...
- Apache Commons Lang 学习栏目
Apache Commons Lang 学习栏目 Apache Commons Lang 3.8.1 API https://mvnrepository.com/artifact/org.apache ...
- Apache Calcite 论文学习笔记
特别声明:本文来源于掘金,"预留"发表的[Apache Calcite 论文学习笔记](https://juejin.im/post/5d2ed6a96fb9a07eea32a6f ...
- Maven+Spring Batch+Apache Commons VF学习
Apache Commons VFS资料:例子:http://www.zihou.me/html/2011/04/12/3377.html详细例子:http://p7engqingyang.iteye ...
- 快速沃尔什变换 FWT 学习笔记【多项式】
〇.前言 之前看到异或就担心是 FWT,然后才开始想别的. 这次学了 FWT 以后,以后判断应该就很快了吧? 参考资料 FWT 详解 知识点 by neither_nor 集训队论文 2015 集合幂 ...
- java apache commons HttpClient发送get和post请求的学习整理(转)
文章转自:http://blog.csdn.net/ambitiontan/archive/2006/01/06/572171.aspx HttpClient 是我最近想研究的东西,以前想过的一些应用 ...
- apache commons类库的学习
原文地址http://www.tuicool.com/articles/iyEbquE 1.1. 开篇 在Java的世界,有很多(成千上万)开源的框架,有成功的,也有不那么成功的,有声名显赫的,也有默 ...
- 一篇关于apache commons类库的详解
1.1. 开篇 在Java的世界,有很多(成千上万)开源的框架,有成功的,也有不那么成功的,有声名显赫的,也有默默无闻的.在我看来,成功而默默无闻的那些框架值得我们格外的尊敬和关注,Jakarta C ...
- Solr学习笔记---部署Solr到Tomcat上,可视化界面的介绍和使用,Solr的基本内容介绍,SolrJ的使用
学习Solr前需要有Lucene的基础 Lucene的一些简单用法:https://www.cnblogs.com/dddyyy/p/9842760.html 1.部署Solr到Tomcat(Wind ...
随机推荐
- hdu1260(dp)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1260 分析:简单dp,dp[i]=min(dp[i-1]+a[i],dp[i-2]); #includ ...
- SharePoint 2013的HTML5特性之响应式布局
今天偶然看到一本书<Pro SharePoint 2013 Branding and Responsive Web Development>,看到SharePoint 2013基于HTML ...
- Flex中的DataGrid报错(二)
1.错误描写叙述 此行的多个标记: -holeNum -1067: String 类型值的隐式强制指令的目标是非相关类型 mx.controls:Text. 2.错误原因 将字符串类型赋值给Text ...
- qt安装遇到的错误
/usr/bin/ld: cannot find -lXrender collect2: ld returned 1 exit status make[1]: *** [../../../../lib ...
- SE 2014年4月12日
BGP基础实验 拓扑 步骤: 1. 完成基本的配置 2. 按照需求自治系统AS 100 全网运行OSPF 单区域 3. 完成BGP基本配置 [RT2]bgp 100 [RT2-bgp]peer 67. ...
- MySQL 模拟Oracle邻接模型树形处理
数据库对层次结构的处理模型有好多种,能够依据自己的需求来设计模型.当然最简单的也是最easy设计的模型就是所谓的邻接模型.在这方面,其它数据库比方Oracle 提供了现成的分析方法 connect b ...
- 《JavaScript设计模式与开发实践》读书笔记之单例模式
1.单例模式 保证一个类仅有一个实例,并提供一个访问它的全局访问点 1.1 传统的单例模式 var Singleton=function(name){ this.name=name; } Single ...
- kafka解释三的具体:发展Kafka应用
一个.整体外观Kafka 我们知道.Kafka系统有三大组件:Producer.Consumer.broker . producers 生产(produce)消息(message)并推(push)送给 ...
- Android kxml解析WBXML
WAP Binary XML定义好XML片断表述出同步server地址.远程数据库名称.登录账号等等内容一.两种訪问方法: 眼下的kxml支持两种wap格式:WBXML/WML. 而有两种方法将解析 ...
- Windows Phone开发(22):启动器与选择器之BingMapsDirectionsTask
原文:Windows Phone开发(22):启动器与选择器之BingMapsDirectionsTask 从今天开发始,我们又开始新的征程,接下来的课程我们要熟悉一下启动器和选择器,其实二者是一样的 ...