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

com.opengamma.strata.math.impl.regression.NamedVariableLeastSquaresRegressionResult Maven / Gradle / Ivy

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

import java.util.ArrayList;
import java.util.List;
import java.util.Map;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * 
 */
//CSOFF: JavadocMethod
public class NamedVariableLeastSquaresRegressionResult extends LeastSquaresRegressionResult {

  private static final Logger log = LoggerFactory.getLogger(NamedVariableLeastSquaresRegressionResult.class);
  private final List _independentVariableNames;
  private final LeastSquaresRegressionResult _result;
  private static final String INTERCEPT_STRING = "Intercept";

  public NamedVariableLeastSquaresRegressionResult(
      List independentVariableNames,
      LeastSquaresRegressionResult result) {

    super(result);
    if (independentVariableNames == null) {
      throw new IllegalArgumentException("List of independent variable names was null");
    }
    _independentVariableNames = new ArrayList<>();
    if (result.hasIntercept()) {
      if (independentVariableNames.size() != result.getBetas().length - 1) {
        throw new IllegalArgumentException("Length of variable name array did not match number of results in the regression");
      }
      _independentVariableNames.add(INTERCEPT_STRING);
    } else {
      if (independentVariableNames.size() != result.getBetas().length) {
        throw new IllegalArgumentException("Length of variable name array did not match number of results in the regression");
      }
    }
    _independentVariableNames.addAll(independentVariableNames);
    _result = result;
  }

  /**
   * @return the _independentVariableNames
   */
  public List getIndependentVariableNames() {
    return _independentVariableNames;
  }

  /**
   * @return the _result
   */
  public LeastSquaresRegressionResult getResult() {
    return _result;
  }

  public Double getPredictedValue(Map namesAndValues) {
    if (namesAndValues == null) {
      throw new IllegalArgumentException("Map was null");
    }
    if (namesAndValues.isEmpty()) {
      log.warn("Map was empty: returning 0");
      return 0.;
    }
    double[] betas = getBetas();
    double sum = 0;
    if (hasIntercept()) {
      if (namesAndValues.size() < betas.length - 1) {
        throw new IllegalArgumentException("Number of named variables in map was smaller than that in regression");
      }
    } else {
      if (namesAndValues.size() < betas.length) {
        throw new IllegalArgumentException("Number of named variables in map was smaller than that in regression");
      }
    }
    int i = hasIntercept() ? 1 : 0;
    for (String name : getIndependentVariableNames()) {
      if (name.equals(INTERCEPT_STRING)) {
        sum += betas[0];
      } else {
        if (!namesAndValues.containsKey(name) || namesAndValues.get(name) == null) {
          throw new IllegalArgumentException("Do not have value for " + name);
        }
        sum += betas[i++] * namesAndValues.get(name);
      }
    }
    return sum;
  }

  @Override
  public int hashCode() {
    int prime = 31;
    int result = super.hashCode();
    result = prime * result + (_independentVariableNames == null ? 0 : _independentVariableNames.hashCode());
    result = prime * result + (_result == null ? 0 : _result.hashCode());
    return result;
  }

  @Override
  public boolean equals(Object obj) {
    if (this == obj) {
      return true;
    }
    if (!super.equals(obj)) {
      return false;
    }
    if (getClass() != obj.getClass()) {
      return false;
    }
    NamedVariableLeastSquaresRegressionResult other = (NamedVariableLeastSquaresRegressionResult) obj;
    if (_independentVariableNames == null) {
      if (other._independentVariableNames != null) {
        return false;
      }
    } else if (!_independentVariableNames.equals(other._independentVariableNames)) {
      return false;
    }
    if (_result == null) {
      if (other._result != null) {
        return false;
      }
    } else if (!_result.equals(other._result)) {
      return false;
    }
    return true;
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy