Movatterモバイル変換


[0]ホーム

URL:


man7.org > Linux >man-pages

Linux/UNIX system programming training


pow(3) — Linux manual page

NAME |LIBRARY |SYNOPSIS |DESCRIPTION |RETURN VALUE |ERRORS |ATTRIBUTES |STANDARDS |HISTORY |BUGS |SEE ALSO |COLOPHON

pow(3)                   Library Functions Manualpow(3)

NAME        top

       pow, powf, powl - power functions

LIBRARY        top

       Math library (libm,-lm)

SYNOPSIS        top

#include <math.h>double pow(doublex, doubley);float powf(floatx, floaty);long double powl(long doublex, long doubley);   Feature Test Macro Requirements for glibc (seefeature_test_macros(7)):powf(),powl():           _ISOC99_SOURCE || _POSIX_C_SOURCE >= 200112L               || /* Since glibc 2.19: */ _DEFAULT_SOURCE               || /* glibc <= 2.19: */ _BSD_SOURCE || _SVID_SOURCE

DESCRIPTION        top

       These functions return the value ofx raised to the power ofy.

RETURN VALUE        top

       On success, these functions return the value ofx to the power ofy.       If the result overflows, a range error occurs, and the functions       returnHUGE_VAL,HUGE_VALF, orHUGE_VALL, respectively, with the       mathematically correct sign.       If result underflows, and is not representable, a range error       occurs, and 0.0 with the appropriate sign is returned.       Ifx is +0 or -0, andy is an odd integer less than 0, a pole       error occurs andHUGE_VAL,HUGE_VALF, orHUGE_VALL, is returned,       with the same sign asx.       Ifx is +0 or -0, andy is less than 0 and not an odd integer, a       pole error occurs and +HUGE_VAL, +HUGE_VALF, or +HUGE_VALL, is       returned.       Ifx is +0 (-0), andy is an odd integer greater than 0, the       result is +0 (-0).       Ifx is 0, andy greater than 0 and not an odd integer, the result       is +0.       Ifx is -1, andy is positive infinity or negative infinity, the       result is 1.0.       Ifx is +1, the result is 1.0 (even ify is a NaN).       Ify is 0, the result is 1.0 (even ifx is a NaN).       Ifx is a finite value less than 0, andy is a finite noninteger,       a domain error occurs, and a NaN is returned.       If the absolute value ofx is less than 1, andy is negative       infinity, the result is positive infinity.       If the absolute value ofx is greater than 1, andy is negative       infinity, the result is +0.       If the absolute value ofx is less than 1, andy is positive       infinity, the result is +0.       If the absolute value ofx is greater than 1, andy is positive       infinity, the result is positive infinity.       Ifx is negative infinity, andy is an odd integer less than 0,       the result is -0.       Ifx is negative infinity, andy less than 0 and not an odd       integer, the result is +0.       Ifx is negative infinity, andy is an odd integer greater than 0,       the result is negative infinity.       Ifx is negative infinity, andy greater than 0 and not an odd       integer, the result is positive infinity.       Ifx is positive infinity, andy less than 0, the result is +0.       Ifx is positive infinity, andy greater than 0, the result is       positive infinity.       Except as specified above, ifx ory is a NaN, the result is a       NaN.

ERRORS        top

       Seemath_error(7) for information on how to determine whether an       error has occurred when calling these functions.       The following errors can occur:       Domain error:x is negative, andy is a finite nonintegererrno is set toEDOM.  An invalid floating-point exception              (FE_INVALID) is raised.       Pole error:x is zero, andy is negativeerrno is set toERANGE(but see BUGS).  A divide-by-zero              floating-point exception (FE_DIVBYZERO) is raised.       Range error: the result overflowserrno is set toERANGE.  An overflow floating-point              exception (FE_OVERFLOW) is raised.       Range error: the result underflowserrno is set toERANGE.  An underflow floating-point              exception (FE_UNDERFLOW) is raised.

ATTRIBUTES        top

       For an explanation of the terms used in this section, seeattributes(7).       ┌──────────────────────────────────────┬───────────────┬─────────┐       │InterfaceAttributeValue│       ├──────────────────────────────────────┼───────────────┼─────────┤       │pow(),powf(),powl()                │ Thread safety │ MT-Safe │       └──────────────────────────────────────┴───────────────┴─────────┘

STANDARDS        top

       C11, POSIX.1-2008.

HISTORY        top

       C99, POSIX.1-2001.       The variant returningdouble also conforms to SVr4, 4.3BSD, C89.

BUGS        top

Historical bugs (now fixed)       Before glibc 2.28, on some architectures (e.g., x86-64)pow() may       be more than 10,000 times slower for some inputs than for other       nearby inputs.  This affects onlypow(), and notpowf() norpowl().  This problem was fixed in glibc 2.28.       A number of bugs in the glibc implementation ofpow() were fixed       in glibc 2.16.       In glibc 2.9 and earlier, when a pole error occurs,errno is set       toEDOMinstead of the POSIX-mandatedERANGE.  Since glibc 2.10,       glibc does the right thing.       In glibc 2.3.2 and earlier, when an overflow or underflow error       occurs, glibc'spow() generates a bogus invalid floating-point       exception (FE_INVALID) in addition to the overflow or underflow       exception.

SEE ALSO        top

cbrt(3),cpow(3),sqrt(3)

COLOPHON        top

       This page is part of theman-pages (Linux kernel and C library       user-space interface documentation) project.  Information about       the project can be found at        ⟨https://www.kernel.org/doc/man-pages/⟩.  If you have a bug report       for this manual page, see       ⟨https://git.kernel.org/pub/scm/docs/man-pages/man-pages.git/tree/CONTRIBUTING⟩.       This page was obtained from the tarball man-pages-6.15.tar.gz       fetched from       ⟨https://mirrors.edge.kernel.org/pub/linux/docs/man-pages/⟩ on       2025-08-11.  If you discover any rendering problems in this HTML       version of the page, or you believe there is a better or more up-       to-date source for the page, or you have corrections or       improvements to the information in this COLOPHON (which isnot       part of the original manual page), send a mail to       man-pages@man7.orgLinux man-pages 6.15            2025-05-17pow(3)

Pages that refer to this page:cbrt(3)cpow(3)pow10(3)



HTML rendering created 2025-09-06 byMichael Kerrisk, author ofThe Linux Programming Interface.

For details of in-depthLinux/UNIX system programming training courses that I teach, lookhere.

Hosting byjambit GmbH.

Cover of TLPI


[8]ページ先頭

©2009-2025 Movatter.jp