git: 9front

ref: dc463a66e342c6b979f97e9e7c164c8ed5ff03d8
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);
	}
}