git: 9front

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