summaryrefslogtreecommitdiff
path: root/missing/hypot.c
blob: aad5259e924b36cf401ef13c8d514bf7bfb9717c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
/* public domain rewrite of hypot */

#include <math.h>

double hypot(x,y)
    double x, y;
{
    if (x < 0) x = -x;
    if (y < 0) y = -y;
    if (x < y) {
	double tmp = x;
	x = y; y = tmp;
    }
    if (y == 0.0) return x;
    y /= x;
    return x * sqrt(1.0+y*y);
}