All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.opengamma.strata.math.impl.interpolation.PolynomialsLeastSquaresFitterResult Maven / Gradle / Ivy

/*
 * Copyright (C) 2013 - present by OpenGamma Inc. and the OpenGamma group of companies
 *
 * Please see distribution for license.
 */
package com.opengamma.strata.math.impl.interpolation;

import com.opengamma.strata.collect.ArgChecker;
import com.opengamma.strata.collect.array.DoubleMatrix;

/**
 * Contains the result of a least squares regression for polynomial.
 */
public class PolynomialsLeastSquaresFitterResult {

  private double[] _coefficients;
  private DoubleMatrix _rMatrix;
  private int _dof;
  private double _diffNorm;
  private double[] _meanAndStd;

  /**
   * @param coefficients Coefficients of the polynomial
   * @param rMatrix R-matrix of the QR decomposition used in PolynomialsLeastSquaresRegression
   * @param dof Degrees of freedom = Number of data points - (degrees of Polynomial + 1) 
   * @param diffNorm Square norm of the vector, "residuals," whose components are yData_i - f(xData_i)
   */
  public PolynomialsLeastSquaresFitterResult(final double[] coefficients, final DoubleMatrix rMatrix, final int dof, final double diffNorm) {

    _coefficients = coefficients;
    _rMatrix = rMatrix;
    _dof = dof;
    _diffNorm = diffNorm;
    _meanAndStd = null;

  }

  /**
   * @param coefficients Coefficients {a_0, a_1, a_2 ...} of the polynomial a_0 + a_1 x^1 + a_2 x^2 + ....
   * @param rMatrix R-matrix of the QR decomposition used in PolynomialsLeastSquaresRegression
   * @param dof Degrees of freedom = Number of data points - (degrees of Polynomial + 1) 
   * @param diffNorm Norm of the vector, "residuals," whose components are yData_i - f(xData_i)
   * @param meanAndStd Vector (mean , standard deviation) used in normalization 
   */
  public PolynomialsLeastSquaresFitterResult(final double[] coefficients, final DoubleMatrix rMatrix, final int dof, final double diffNorm, final double[] meanAndStd) {

    _coefficients = coefficients;
    _rMatrix = rMatrix;
    _dof = dof;
    _diffNorm = diffNorm;
    _meanAndStd = meanAndStd;

  }

  /**
   * @return Coefficients {a_0, a_1, a_2 ...} of polynomial a_0 + a_1 x^1 + a_2 x^2 + ....
   */
  public double[] getCoeff() {
    return _coefficients;
  }

  /**
   * @return R Matrix of QR decomposition
   */
  public DoubleMatrix getRMat() {
    return _rMatrix;
  }

  /**
   * @return Degrees of freedom = Number of data points - (degrees of Polynomial + 1) 
   */
  public int getDof() {
    return _dof;
  }

  /**
   * @return Norm of the vector, "residuals," whose components are yData_i - f(xData_i)
   */
  public double getDiffNorm() {
    return _diffNorm;
  }

  /**
   * @return Vector (mean , standard deviation) used in normalization 
   */
  public double[] getMeanAndStd() {
    ArgChecker.notNull(_meanAndStd, "xData are not normalized");
    return _meanAndStd;
  }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy