The scalbln functions (C99) - scalbln, scalblnf, scalblnl

効率よく x * FLT_RADIX^n を計算※ します.

scalbln (C99)

#include <math.h>
double scalbln(
    double x,
    long n
);

scalbln 関数は効率よく x * FLT_RADIX^n を計算※し,結果を double 型で返します.

scalblnf (C99)

#include <math.h>
float scalblnf(
    float x,
    long n
);

scalblnf 関数は効率よく x * FLT_RADIX^n を計算※し,結果を float 型で返します.

scalblnl (C99)

#include <math.h>
long double scalblnl(
    long double x,
    long n
);

scalblnl 関数は効率よく x * FLT_RADIX^n を計算※し,結果を long double 型で返します.

scalbln,scalblnf,scalblnl 関数を実行すると,値域エラー (range error) が発生することがあります.

※ 実際に FLT_RADIX^n を計算することはありません.

戻り値

  • x * FLT_RADIX^n の値

数学上の表記

x * FLT_RADIX^n

C言語サンプルプログラム

以下に scalbln 関数それぞれを使用したサンプルプログラムを示します.

/* header files */
#include <stdio.h>
#include <stdlib.h>
#include <math.h>

/* main */
int main(void) {
    double x = 2.0, y;
    long n = 4L;

    y = scalbln(x, n);
    printf("scalbln(%.2f, %ld) = %.2f\n", x, n, y);

    return EXIT_SUCCESS;
}

実行例

サンプルプログラムの実行結果は以下のようになります.

scalbln(2.00, 4) = 32.00