Last change
on this file was 2, checked in by bird, 22 years ago |
Initial revision
|
-
Property cvs2svn:cvs-rev
set to
1.1
-
Property svn:eol-style
set to
native
-
Property svn:executable
set to
*
|
File size:
427 bytes
|
Line | |
---|
1 | #ifdef KR_headers
|
---|
2 | extern double sqrt();
|
---|
3 | double f__cabs(real, imag) double real, imag;
|
---|
4 | #else
|
---|
5 | #undef abs
|
---|
6 | #include <math.h>
|
---|
7 | double f__cabs(double real, double imag)
|
---|
8 | #endif
|
---|
9 | {
|
---|
10 | double temp;
|
---|
11 |
|
---|
12 | if(real < 0)
|
---|
13 | real = -real;
|
---|
14 | if(imag < 0)
|
---|
15 | imag = -imag;
|
---|
16 | if(imag > real){
|
---|
17 | temp = real;
|
---|
18 | real = imag;
|
---|
19 | imag = temp;
|
---|
20 | }
|
---|
21 | if((real+imag) == real)
|
---|
22 | return(real);
|
---|
23 |
|
---|
24 | temp = imag/real;
|
---|
25 | temp = real*sqrt(1.0 + temp*temp); /*overflow!!*/
|
---|
26 | return(temp);
|
---|
27 | }
|
---|
Note:
See
TracBrowser
for help on using the repository browser.