/*
 * The Spar Library - modular math parser
 * Copyright (C) 2000,2001 Davide Angelocola <davide178@inwind.it>
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License.
 *
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library; if not, write to the
 * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
 * Boston, MA  02111-1307, USA.
 *
 */

/* solve_quadratic.c - finds the real roots of a x^2 + b x + c = 0 */
#include <spar/sl_poly.h>
#include <spar/sl_math.h>
#include <spar/sl_math_library.h>


int
sl_poly_solve_quadratic (double a, double b, double c, double *x1, double *x2)
{
  double disc = b * b - 4 * a * c;

  if (disc > 0)
    {
      if (b == 0)
	{
	  double r = SL_ABS (0.5 * sl_sqrn (disc, 2) / a);
	  *x1 = -r;
	  *x2 = r;
	}
      else
	{
	  double sgnb = SL_SGN (b);
	  double temp = -0.5 * (b + sgnb * sl_sqrn (disc, 2));
	  double r1 = temp / a;
	  double r2 = c / temp;

	  if (r1 < r2)
	    {
	      *x1 = r1;
	      *x2 = r2;
	    }
	  else
	    {
	      *x1 = r2;
	      *x2 = r1;
	    }
	}
      return 2;
    }
  else if (disc == 0)
    {
      *x1 = -0.5 * b / a;
      *x2 = -0.5 * b / a;
      return 2;
    }
  else
    {
      return 0;
    }
}


syntax highlighted by Code2HTML, v. 0.9.1