Perpustakaan C - <float.h>

Itu float.hFile header dari C Standard Library berisi sekumpulan berbagai konstanta yang bergantung pada platform yang terkait dengan nilai floating point. Konstanta ini diusulkan oleh ANSI C. Mereka memungkinkan pembuatan program yang lebih portabel. Sebelum memeriksa semua konstanta, sebaiknya dipahami bahwa bilangan floating-point terdiri dari empat elemen berikut -

Sr.No. Komponen & Deskripsi Komponen
1

S

tanda (+/-)

2

b

basis atau radix dari representasi eksponen, 2 untuk biner, 10 untuk desimal, 16 untuk heksadesimal, dan seterusnya ...

3

e

eksponen, bilangan bulat antara minimum emin dan maksimal emax.

4

p

presisi, jumlah digit basis-b di signifikan.

Berdasarkan 4 komponen di atas, floating point akan memiliki nilai sebagai berikut:

floating-point = ( S ) p x be

or

floating-point = (+/-) precision x baseexponent

Makro Perpustakaan

Nilai berikut khusus untuk penerapan dan ditentukan dengan arahan #define, tetapi nilai ini mungkin tidak lebih rendah dari yang diberikan di sini. Perhatikan bahwa dalam semua kasus FLT mengacu pada tipefloat, DBL mengacu pada double, dan mengacu pada LDBL long double.

Sr.No. Makro & Deskripsi
1

FLT_ROUNDS

Mendefinisikan mode pembulatan untuk penambahan floating point dan itu dapat memiliki salah satu nilai berikut -

  • -1 - tidak dapat ditentukan
  • 0 - menuju nol
  • 1 - ke terdekat
  • 2 - menuju tak terhingga positif
  • 3 - menuju ketidakterbatasan negatif
2

FLT_RADIX 2

Ini mendefinisikan representasi radix dasar dari eksponen. Basis-2 adalah biner, basis 10 adalah representasi desimal normal, basis-16 adalah Hex.

3

FLT_MANT_DIG

DBL_MANT_DIG

LDBL_MANT_DIG

Makro ini menentukan jumlah digit angka (dalam basis FLT_RADIX).

4

FLT_DIG 6

DBL_DIG 10

LDBL_DIG 10

Makro ini menentukan digit desimal bilangan maksimum (basis 10) yang dapat direpresentasikan tanpa perubahan setelah pembulatan.

5

FLT_MIN_EXP

DBL_MIN_EXP

LDBL_MIN_EXP

Makro ini menentukan nilai bilangan bulat negatif minimum untuk eksponen dalam basis FLT_RADIX.

6

FLT_MIN_10_EXP -37

DBL_MIN_10_EXP -37

LDBL_MIN_10_EXP -37

Makro ini menentukan nilai bilangan bulat negatif minimum untuk eksponen dalam basis 10.

7

FLT_MAX_EXP

DBL_MAX_EXP

LDBL_MAX_EXP

Makro ini menentukan nilai bilangan bulat maksimum untuk eksponen dalam basis FLT_RADIX.

8

FLT_MAX_10_EXP +37

DBL_MAX_10_EXP +37

LDBL_MAX_10_EXP +37

Makro ini menentukan nilai bilangan bulat maksimum untuk eksponen dalam basis 10.

9

FLT_MAX 1E+37

DBL_MAX 1E+37

LDBL_MAX 1E+37

Makro ini menentukan nilai floating-point hingga maksimum.

10

FLT_EPSILON 1E-5

DBL_EPSILON 1E-9

LDBL_EPSILON 1E-9

Makro ini menentukan angka paling signifikan yang dapat diwakili.

11

FLT_MIN 1E-37

DBL_MIN 1E-37

LDBL_MIN 1E-37

Makro ini menentukan nilai titik mengambang minimum.

Contoh

Contoh berikut menunjukkan penggunaan beberapa konstanta yang ditentukan dalam file float.h.

#include <stdio.h>
#include <float.h>

int main () {
   printf("The maximum value of float = %.10e\n", FLT_MAX);
   printf("The minimum value of float = %.10e\n", FLT_MIN);

   printf("The number of digits in the number = %.10e\n", FLT_MANT_DIG);
}

Mari kita kompilasi dan jalankan program di atas yang akan menghasilkan hasil sebagai berikut -

The maximum value of float = 3.4028234664e+38
The minimum value of float = 1.1754943508e-38
The number of digits in the number = 7.2996655210e-312