mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
18 lines
269 B
C
18 lines
269 B
C
|
/* 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);
|
||
|
}
|