com.opengamma.strata.math.impl.rootfinding.QuadraticRealRootFinder 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.rootfinding;
import com.opengamma.strata.collect.ArgChecker;
import com.opengamma.strata.math.MathException;
import com.opengamma.strata.math.impl.function.RealPolynomialFunction1D;
/**
* Class that calculates the real roots of a quadratic function.
*
* The roots can be found analytically. For a quadratic $ax^2 + bx + c = 0$, the roots are given by:
* $$
* \begin{align*}
* x_{1, 2} = \frac{-b \pm \sqrt{b^2 - 4ac}}{2a}
* \end{align*}
* $$
* If no real roots exist (i.e. $b^2 - 4ac < 0$) then an exception is thrown.
*/
public class QuadraticRealRootFinder implements Polynomial1DRootFinder {
/**
* {@inheritDoc}
* @throws IllegalArgumentException If the function is not a quadratic
* @throws MathException If the roots are not real
*/
@Override
public Double[] getRoots(RealPolynomialFunction1D function) {
ArgChecker.notNull(function, "function");
double[] coefficients = function.getCoefficients();
ArgChecker.isTrue(coefficients.length == 3, "Function is not a quadratic");
double c = coefficients[0];
double b = coefficients[1];
double a = coefficients[2];
double discriminant = b * b - 4 * a * c;
if (discriminant < 0) {
throw new MathException("No real roots for quadratic");
}
double q = -0.5 * (b + Math.signum(b) * discriminant);
return new Double[] {q / a, c / q};
}
}