diff options
author | Martynas Venckus <martynas@cvs.openbsd.org> | 2011-07-09 22:17:23 +0000 |
---|---|---|
committer | Martynas Venckus <martynas@cvs.openbsd.org> | 2011-07-09 22:17:23 +0000 |
commit | 80c7c39d3da4d1eb6a92d1e2bc80c6ed76c52a45 (patch) | |
tree | 8604c93de34b44b89595afa18550dbd9c4638c72 | |
parent | e432b1fbd41c77abbf078d905af3d26c3e595a24 (diff) |
- Fix the cabs, and cabsf prototypes in the manual pages; it's
been C99 complex (not struct complex) for couple of years.
- Remove BUGS section; cabs is finally prototyped in complex.h.
- Also document cabsl.
-rw-r--r-- | lib/libm/Makefile | 3 | ||||
-rw-r--r-- | lib/libm/man/hypot.3 | 53 |
2 files changed, 22 insertions, 34 deletions
diff --git a/lib/libm/Makefile b/lib/libm/Makefile index 987a53d2ab8..cb70d7015f2 100644 --- a/lib/libm/Makefile +++ b/lib/libm/Makefile @@ -1,4 +1,4 @@ -# $OpenBSD: Makefile,v 1.92 2011/07/09 02:13:52 martynas Exp $ +# $OpenBSD: Makefile,v 1.93 2011/07/09 22:17:22 martynas Exp $ # $NetBSD: Makefile,v 1.28 1995/11/20 22:06:19 jtc Exp $ # # @(#)Makefile 5.1beta 93/09/24 @@ -323,6 +323,7 @@ MLINKS+=floor.3 floorl.3 MLINKS+=fmax.3 fmaxl.3 MLINKS+=fmax.3 fminl.3 MLINKS+=fmod.3 fmodl.3 +MLINKS+=hypot.3 cabsl.3 MLINKS+=hypot.3 hypotl.3 MLINKS+=ilogb.3 ilogbl.3 MLINKS+=lgamma.3 lgammal.3 diff --git a/lib/libm/man/hypot.3 b/lib/libm/man/hypot.3 index 83ee862a81f..b71a7ca3463 100644 --- a/lib/libm/man/hypot.3 +++ b/lib/libm/man/hypot.3 @@ -1,4 +1,4 @@ -.\" $OpenBSD: hypot.3,v 1.17 2011/07/07 01:34:52 martynas Exp $ +.\" $OpenBSD: hypot.3,v 1.18 2011/07/09 22:17:22 martynas Exp $ .\" Copyright (c) 1985, 1991 Regents of the University of California. .\" All rights reserved. .\" @@ -28,7 +28,7 @@ .\" .\" from: @(#)hypot.3 6.7 (Berkeley) 5/6/91 .\" -.Dd $Mdocdate: July 7 2011 $ +.Dd $Mdocdate: July 9 2011 $ .Dt HYPOT 3 .Os .Sh NAME @@ -36,7 +36,8 @@ .Nm hypotf , .Nm hypotl , .Nm cabs , -.Nm cabsf +.Nm cabsf , +.Nm cabsl .Nd Euclidean distance and complex absolute value functions .Sh SYNOPSIS .Fd #include <math.h> @@ -46,33 +47,24 @@ .Fn hypotf "float x" "float y" .Ft long double .Fn hypotl "long double x" "long double y" +.Fd #include <complex.h> .Ft double -.Fn cabs "struct complex { double x; double y; } z" +.Fn cabs "double complex z" .Ft float -.Fn cabsf "struct complex { float x; float y; } z" +.Fn cabsf "float complex z" +.Ft long double +.Fn cabsl "long double complex z" .Sh DESCRIPTION The -.Fn hypot +.Fn hypot , +.Fn hypotf and -.Fn cabs +.Fn hypotl functions compute the sqrt(x*x+y*y) in such a way that underflow will not happen, and overflow occurs only if the final result deserves it. -The -.Fn hypotf -and -.Fn cabsf -functions are single precision versions of -.Fn hypot -and -.Fn cabs , -respectively. -The -.Fn hypotl -function is an extended precision version of -.Fn hypot . .Pp .Fn hypot "\*(If" "v" = @@ -80,6 +72,14 @@ function is an extended precision version of = +\*(If for all .Ar v , including \*(Na. +.Pp +The +.Fn cabs , +.Fn cabsf +and +.Fn cabsl +functions return the absolute value of the complex number +.Fa z . .Sh ERRORS (due to Roundoff, etc.) Below 0.97 .Em ulps . @@ -89,11 +89,6 @@ Consequently exactly; in general, hypot and cabs return an integer whenever an integer might be expected. -.Pp -The same cannot be said for the shorter and faster version of hypot -and cabs that is provided in the comments in cabs.c; its error can -exceed 1.2 -.Em ulps . .Sh NOTES As might be expected, .Fn hypot "v" "\*(Na" @@ -139,11 +134,3 @@ function and a function appeared in .At v7 . -.Sh BUGS -The -.Fn cabs -and -.Fn cabsf -functions use structures that are not defined in any header and need to -be defined by the user. -As such they cannot be prototyped properly. |