The ldexp functions - ldexp, ldexpf, ldexpl

浮動小数点数と 2 の整数べき乗の乗算を計算します.

ldexp

#include <math.h>
double ldexp(
    double x,
    int exp
);

ldexp 関数は,x と 2 の exp 乗の乗算を計算し,結果を double 型で返します.

ldexpf (C99)

#include <math.h>
float ldexpf(
    float x,
    int exp
);

ldexpf 関数は,x と 2 の exp 乗の乗算を計算し,結果を float 型で返します.

ldexpl (C99)

#include <math.h>
long double ldexpl(
    long double x,
    int exp
);

ldexpl 関数は,x と 2 の exp 乗の乗算を計算し,結果を long double 型で返します.

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

戻り値

  • x * 2^exp の値

数学上の表記

x*2^exp

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

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

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

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

    y = ldexp(x, exp);
    printf("ldexp(%.2f, %d) = %.2f\n", x, exp, y);

    return EXIT_SUCCESS;
}

実行例

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

ldexp(2.00, 4) = 32.00

Cプログラマの必読書

たくさんあるC言語関連の書籍の中でも特に役に立った本です.よかったら参考にしてみてください.

C実践プログラミング 第3版

C言語の実践的参考書.少々値段は張りますが初心者を脱しようとしている人は絶対に読むべきです.
文法だけでなく,コーディングスタイルやデバッグなど文字通り「実践的」なことが書かれているので非常にためになります. オライリーの本は,読みにくい本が多いのですが本書はとても読みやすくオススメです.


C言語ポインタ完全制覇 (標準プログラマーズライブラリ)

ポインタの解説書としては最高の書籍です.
この1冊でポインタを完全に理解することができます.全くの初学者が読むには敷居が高いですが,入門書を読み終えた後に読むと非常に有益です.