git: 9front

ref: c90d38382860b13a7d6a804cb3db7e0ff9b8e0e1
dir: /sys/src/cmd/python/Python/hypot.c/

View raw version
/* hypot() replacement */

#include "pyconfig.h"
#include "pyport.h"

double hypot(double x, double y)
{
	double yx;

	x = fabs(x);
	y = fabs(y);
	if (x < y) {
		double temp = x;
		x = y;
		y = temp;
	}
	if (x == 0.)
		return 0.;
	else {
		yx = y/x;
		return x*sqrt(1.+yx*yx);
	}
}