名 前
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():
_BSD_SOURCE || _SVID_SOURCE ||
_XOPEN_SOURCE >= 600 || _ISOC99_SOURCE ||
_POSIX_C_SOURCE >= 200112L;
or cc −std=c99
説 明
log() 関 数 は x の 自 然 対 数 を 返 す 。
返 り 値
成 功 す る と 、 こ れ ら の 関 数 は x の 自 然 対 数 を 返 す 。
x が NaN の 場 合 、 NaN が 返 さ れ る 。
x が 1 の 場 合 、 +0 が 返 さ れ る 。
x が 正 の 無 限 大 の 場 合 、 正 の 無 限 大 が 返 さ れ る 。
x が 0 の 場 合 、 極 エ ラ ー (pole error) が 発 生 し 、 各 関 数 は そ れ ぞ れ −HUGE_VAL, −HUGE_VALF, −HUGE_VALL を 返 す 。
x が 負 の 場 合 (負 の 無 限 大 も 含 む )、 領 域 エ ラ ー (domain error) が 発 生 し 、 NaN (not a number) が 返 さ れ る 。
エ ラ ー
こ れ ら の 関 数 を 呼 び 出 し た 際 に エ ラ ー が 発 生 し た か の 判 定 方 法 に つ い て の 情 報 は math_error(7) を 参 照 の こ と 。 以 下 の エ ラ ー が 発 生 す る 可 能 性 が あ る 。 領 域 エ ラ ー
(domain error): x が 負 で あ る
errno に EDOM が 設 定 さ れ る 。 不 正 (invalid) 浮 動 小 数 点 例 外 (FE_INVALID) が 上 が る 。 極 エ ラ ー
(pole error): x が 0 で あ る
errno に ERANGE が 設 定 さ れ る 。 0 に よ る 除 算 (divide−by−zero) 浮 動 小 数 点 例 外 (FE_DIVBYZERO) が 上 が る 。
準 拠
C99, POSIX.1−2001. double 版 の 関 数 は SVr4, 4.3BSD, C89 に も 準 拠 し て い る 。
バ グ
glibc 2.5 以 前 で は 、 NaN に 対 し て log() を と る と 、 間 違 っ て 不 正 浮 動 小 数 点 例 外 (FE_INVALID) が 発 生 し て い た 。
関 連 項 目
cbrt(3), clog(3), log10(3), log1p(3), log2(3), sqrt(3)
こ の 文 書 に つ い て
こ の man ペ ー ジ は Linux man−pages プ ロ ジ ェ ク ト の リ リ ー ス 3.79 の 一 部 で あ る 。 プ ロ ジ ェ ク ト の 説 明 と バ グ 報 告 に 関 す る 情 報 は http://www.kernel.org/doc/man−pages/ に 書 か れ て い る 。