LOG(3) Руководство программиста Linux LOG(3)

ИМЯ

log, logf, logl - функция вычисления натурального логарифма

ОБЗОР

#include <math.h>
double log(double x);
float logf(float x);
long double logl(long double x);

Компонуется при указании параметра -lm.

Требования макроса тестирования свойств для glibc (см. feature_test_macros(7)):

logf(), logl():

_ISOC99_SOURCE || _POSIX_C_SOURCE >= 200112L || /* начиная с glibc 2.19: */ _DEFAULT_SOURCE || /* версии glibc <= 2.19: */ _BSD_SOURCE || _SVID_SOURCE

ОПИСАНИЕ

Данные функции возвращают натуральный логарифм от x.

ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ

При успешном выполнении данные функции возвращают натуральный логарифм от x.

Если x равно NaN, будет возвращено NaN.

Если x равно 1, результат будет +0.

Если x стремится к плюс бесконечности, то будет возвращена плюс бесконечность.

Если x равно нулю, возникнет ошибка особой точки, и функция вернет -HUGE_VAL, -HUGE_VALF или -HUGE_VALL, соответственно.

Если x отрицательно (включая минус бесконечность), то будет сгенерирована ошибка области, и будет возвращено NaN (Not a Number, не число).

ОШИБКИ

Смотрите math_error(7), чтобы определить, какие ошибки могут возникать при вызове этих функций.

Могут возникать следующие ошибки:

Ошибка области: x является отрицательным
errno устанавливается в EDOM. Вызывается исключение неправильной плавающей точки (FE_INVALID).
Ошибка особой точки: x равен нулю
errno устанавливается в ERANGE. Возникает исключение деления плавающей точки на ноль (FE_DIVBYZERO).

АТРИБУТЫ

Описание терминов данного раздела смотрите в attributes(7).

Интерфейс Атрибут Значение
log(), logf(), logl() Безвредность в нитях MT-Safe

СООТВЕТСТВИЕ СТАНДАРТАМ

C99, POSIX.1-2001, POSIX.1-2008.

Вариант, возвращающий значение типа double, также соответствует SVr4, 4.3BSD, C89.

ДЕФЕКТЫ

В версии glibc 2.5 и ниже значение log() от NaN ошибочно производила исключение неправильной плавающей запятой (FE_INVALID).

СМОТРИТЕ ТАКЖЕ

cbrt(3), clog(3), log10(3), log1p(3), log2(3), sqrt(3)

2017-09-15