table of contents
POW(3) | Руководство программиста Linux | POW(3) |
ИМЯ¶
pow, powf, powl - функции возведения в степень
ОБЗОР¶
#include <math.h> double pow(double x, double y);
float powf(float x, float y);
long double powl(long double x, long double y);
Компонуется при указании параметра -lm.
Требования
макроса
тестирования
свойств
для glibc (см.
feature_test_macros(7)):
powf(), powl():
или cc -std=c99
ОПИСАНИЕ¶
Функция pow() возвращает значение x, возведённое в степень y.
ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ¶
При успешном выполнении данные функции возвращают значение x, возведённое в степень y.
Если x — конечное значение меньшее 0 и y — конечное не целое, то будет сгенерирована ошибка выхода за пределы области, а в качестве результата будет возвращено NaN.
Если происходит переполнение результата, возникает ошибка диапазона, а функция возвращает HUGE_VAL, HUGE_VALF или HUGE_VALL, соответственно, с математически правильным знаком.
Если в результате исчезает порядок числа и он не представим, то возникает ошибка диапазона и возвращается 0.0.
За исключениями, указанными далее, если значение x или y равно NaN, то результат равен NaN.
Если x равно +1, то результат равен 1.0 (даже если y равно NaN).
Если y равно 0, то результат равен 1.0 (даже если x равно NaN).
Если x равно +0 (-0) и y — нечётное целое большее 0, то результат равен +0 (-0).
Если x равно 0 и y больше 0 и не чётное целое, то результат равен +0.
Если x равно -1 и y стремится к плюс или минус бесконечности, то результат равен 1.0.
Если абсолютное значение x меньше 1 и y стремится к минус бесконечности, то результат стремится к плюс бесконечности.
Если абсолютное значение x больше 1 и y стремится к минус бесконечности, то результат равен +0.
Если абсолютное значение x меньше 1 и y стремится к плюс бесконечности, то результат равен +0.
Если абсолютное значение x больше 1 и y стремится к плюс бесконечности, то результат стремится к плюс бесконечности.
Если x стремится к минус бесконечности и y — нечётное целое меньшее 0, то результат равен -0.
Если x стремится к минус бесконечности и y — меньше 0 и чётное целое, то результат равен +0.
Если x стремится к минус бесконечности и y — нечётное целое большее 0, то результат стремится к минус бесконечности.
Если x стремится к минус бесконечности и y — больше 0 и чётное целое, то результат стремится к плюс бесконечности.
Если x стремится к плюс бесконечности и y — меньше 0, то результат равен +0.
Если x стремится к плюс бесконечности и y — больше 0, то результат стремится к плюс бесконечности.
Если x равно +0 или -0 и y — нечётное целое меньшее 0, то генерируется ошибка особой точки и возвращается HUGE_VAL, HUGE_VALF или HUGE_VALLс тем же знаком что и у x.
Если x равно + или -0 и y — меньше 0 и чётное целое, то генерируется ошибка особой точки и возвращается +HUGE_VAL, +HUGE_VALF или +HUGE_VALL.
ОШИБКИ¶
Смотрите math_error(7), чтобы определить, где возникла ошибка при вызове этих функций.
Могут возникать следующие ошибки:
- Ошибка области: x является отрицательным и y конечное нецелое
- errno устанавливается в EDOM. Возникает исключение неправильной плавающей запятой (FE_INVALID).
- Ошибка особой точки: x равно нулю и y отрицательно
- errno устанавливается в ERANGE (но смотрите ДЕФЕКТЫ). Возникает исключение деления плавающей запятой на ноль (FE_DIVBYZERO).
- Ошибка диапазона: результат превысил разрядность
- Значение errno устанавливается в ERANGE. Возникает исключение переполнения плавающей запятой (FE_OVERFLOW).
- Ошибка диапазона: результат потерял разрядность
- Значение errno устанавливается в ERANGE. Возникает исключение исчезновение порядка плавающей запятой (FE_UNDERFLOW).
СООТВЕТСТВИЕ СТАНДАРТАМ¶
C99, POSIX.1-2001. Вариант, возвращающий значение типа double, также соответствует SVr4, 4.3BSD и C89.
ДЕФЕКТЫ¶
В glibc 2.9 и ранее при возникновении ошибки особой точки, значению errno присваивается EDOM вместо ERANGE согласно POSIX. Начиная с версии 2.10, в glibc это исправлено.
Если x отрицательно, то большие отрицательные или положительные значения y приводят к результату NaN, с присвоением errno значения EDOM или исключению неправильной плавающей запятой (FE_INVALID). Например для pow() такое случает когда абсолютное значение y больше 9.223373e18.
В glibc версии 2.3.2 или старее при возникновении ошибки переполнения или потери разрядов функция pow() кроме исключения переполнения или потери генерирует необоснованное исключение неправильной плавающей запятой (FE_INVALID).
СМОТРИТЕ ТАКЖЕ¶
2010-09-12 |