国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > Java > 正文

Java實(shí)現(xiàn)的n階曲線擬合功能示例

2024-07-13 10:16:53
字體:
供稿:網(wǎng)友

本文實(shí)例講述了Java實(shí)現(xiàn)的n階曲線擬合功能。分享給大家供大家參考,具體如下:

前面一篇文章Java實(shí)現(xiàn)求解一元n次多項(xiàng)式的方法,能解多項(xiàng)式以后,還需要利用那個(gè)類,根據(jù)若干采樣點(diǎn)數(shù)據(jù)來對未來數(shù)據(jù)進(jìn)行預(yù)測,擬合的矩陣在上一篇文章中已經(jīng)貼出來了,這里就不說了,本篇主要是如何根據(jù)采樣點(diǎn)來計(jì)算系數(shù)矩陣,并計(jì)算預(yù)測點(diǎn)的值。

原理很簡單,公式在上一篇文章中也有了,此處直接貼代碼。

其中用到了上一篇文章中寫的類commonAlgorithm.PolynomiaSoluter

package commonAlgorithm;import commonAlgorithm.PolynomialSoluter;import java.lang.Math;public class LeastSquare {  private double[][] matrixA;  private double[] arrayB;  private double[] factors;  private int order;  public LeastSquare() {  }  /*   * 實(shí)例化后,計(jì)算前,先要輸入?yún)?shù)并生成公式 arrayX為采樣點(diǎn)的x軸坐標(biāo),按照采樣順序排列   * arrayY為采樣點(diǎn)的y軸坐標(biāo),按照采樣順序與x一一對應(yīng)排列 order   * 為進(jìn)行擬合的階數(shù)。用低階來擬合高階曲線時(shí)可能會不準(zhǔn)確,但階數(shù)過高會導(dǎo)致計(jì)算緩慢   */  public boolean generateFormula(double[] arrayX, double[] arrayY, int order) {    if (arrayX.length != arrayY.length)      return false;    this.order = order;    int len = arrayX.length;    // 擬合運(yùn)算中的x矩陣和y矩陣    matrixA = new double[order + 1][order + 1];    arrayB = new double[order + 1];    // 生成y矩陣以及x矩陣中冪<=order的部分    for (int i = 0; i < order + 1; i++) {      double sumX = 0;      for (int j = 0; j < len; j++) {        double tmp = Math.pow(arrayX[j], i);        sumX += tmp;        arrayB[i] += tmp * arrayY[j];      }      for (int j = 0; j <= i; j++)        matrixA[j][i - j] = sumX;    }    // 生成x矩陣中冪>order的部分    for (int i = order + 1; i <= order * 2; i++) {      double sumX = 0;      for (int j = 0; j < len; j++)        sumX += Math.pow(arrayX[j], i);      for (int j = i - order; j < order + 1; j++) {        matrixA[i - j][j] = sumX;      }    }    // 實(shí)例化PolynomiaSoluter并解方程組,得到各階的系數(shù)序列factors    PolynomialSoluter soluter = new PolynomialSoluter();    factors = soluter.getResult(matrixA, arrayB);    if (factors == null)      return false;    else      return true;  }  // 根據(jù)輸入坐標(biāo),以及系數(shù)序列factors計(jì)算指定坐標(biāo)的結(jié)果  public double calculate(double x) {    double result = factors[0];    for (int i = 1; i <= order; i++)      result += factors[i] * Math.pow(x, i);    return result;  }}

希望本文所述對大家java程序設(shè)計(jì)有所幫助。


注:相關(guān)教程知識閱讀請移步到JAVA教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 额济纳旗| 四会市| 黑龙江省| 泰和县| 全州县| 濮阳县| 霍山县| 永和县| 江口县| 永济市| 铜梁县| 泸水县| 宝应县| 桓台县| 金塔县| 盐山县| 永定县| 玛曲县| 岳阳市| 天峨县| 镇康县| 云安县| 遂平县| 邵武市| 沁水县| 洛南县| 信阳市| 安平县| 高要市| 泾川县| 通化县| 临沧市| 通州区| 兖州市| 资源县| 罗田县| 嘉兴市| 和硕县| 昭觉县| 沙洋县| 涿鹿县|