MATLAB - Angka

MATLAB mendukung berbagai kelas numerik yang mencakup bilangan bulat bertanda dan tidak bertanda tangan serta nomor floating-point presisi tunggal dan ganda. Secara default, MATLAB menyimpan semua nilai numerik sebagai angka floating point presisi ganda.

Anda dapat memilih untuk menyimpan angka atau deretan angka apa pun sebagai bilangan bulat atau sebagai angka presisi tunggal.

Semua tipe numerik mendukung operasi array dasar dan operasi matematika.

Konversi ke Berbagai Jenis Data Numerik

MATLAB menyediakan fungsi berikut untuk mengkonversi ke berbagai tipe data numerik -

Fungsi Tujuan
dua kali lipat Mengonversi ke angka presisi ganda
tunggal Mengonversi ke angka presisi tunggal
int8 Mengonversi menjadi bilangan bulat bertanda 8-bit
int16 Mengonversi menjadi bilangan bulat bertanda 16-bit
int32 Mengonversi menjadi bilangan bulat bertanda 32-bit
int64 Mengonversi menjadi bilangan bulat bertanda 64-bit
uint8 Mengonversi menjadi integer tanpa tanda tangan 8-bit
uint16 Mengonversi menjadi integer 16-bit unsigned
uint32 Mengonversi menjadi integer 32-bit unsigned
uint64 Mengonversi menjadi 64-bit unsigned integer

Contoh

Buat file script dan ketik kode berikut -

x = single([5.32 3.47 6.28]) .* 7.5
x = double([5.32 3.47 6.28]) .* 7.5
x = int8([5.32 3.47 6.28]) .* 7.5
x = int16([5.32 3.47 6.28]) .* 7.5
x = int32([5.32 3.47 6.28]) .* 7.5
x = int64([5.32 3.47 6.28]) .* 7.5

Saat Anda menjalankan file, ini menunjukkan hasil sebagai berikut -

x =

   39.900   26.025   47.100

x =

   39.900   26.025   47.100

x =

   38  23  45

x =

   38  23  45

x =

   38  23  45

x =

   38  23  45

Contoh

Mari kita kembangkan contoh sebelumnya sedikit lagi. Buat file script dan ketik kode berikut -

x = int32([5.32 3.47 6.28]) .* 7.5
x = int64([5.32 3.47 6.28]) .* 7.5
x = num2cell(x)

Saat Anda menjalankan file, ini menunjukkan hasil sebagai berikut -

x =

   38  23  45

x =

   38  23  45

x = 
{
   [1,1] = 38
   [1,2] = 23
   [1,3] = 45
}

Integer Terkecil dan Terbesar

Fungsinya intmax() dan intmin() mengembalikan nilai maksimum dan minimum yang dapat direpresentasikan dengan semua jenis bilangan bulat.

Kedua fungsi tersebut menggunakan tipe data integer sebagai argumennya, misalnya, intmax (int8) atau intmin (int64) dan mengembalikan nilai maksimum dan minimum yang dapat Anda wakili dengan tipe data integer.

Contoh

Contoh berikut menggambarkan cara mendapatkan nilai bilangan bulat terkecil dan terbesar. Buat file skrip dan tulis kode berikut di dalamnya -

% displaying the smallest and largest signed integer data
str = 'The range for int8 is:\n\t%d to %d ';
sprintf(str, intmin('int8'), intmax('int8'))

str = 'The range for int16 is:\n\t%d to %d ';
sprintf(str, intmin('int16'), intmax('int16'))

str = 'The range for int32 is:\n\t%d to %d ';
sprintf(str, intmin('int32'), intmax('int32'))

str = 'The range for int64 is:\n\t%d to %d ';
sprintf(str, intmin('int64'), intmax('int64'))
 
% displaying the smallest and largest unsigned integer data
str = 'The range for uint8 is:\n\t%d to %d ';
sprintf(str, intmin('uint8'), intmax('uint8'))

str = 'The range for uint16 is:\n\t%d to %d ';
sprintf(str, intmin('uint16'), intmax('uint16'))

str = 'The range for uint32 is:\n\t%d to %d ';
sprintf(str, intmin('uint32'), intmax('uint32'))

str = 'The range for uint64 is:\n\t%d to %d ';
sprintf(str, intmin('uint64'), intmax('uint64'))

Saat Anda menjalankan file, ini menunjukkan hasil sebagai berikut -

ans = The range for int8 is:
	-128 to 127 
ans = The range for int16 is:
	-32768 to 32767 
ans = The range for int32 is:
	-2147483648 to 2147483647 
ans = The range for int64 is:
	0 to 0 
ans = The range for uint8 is:
	0 to 255 
ans = The range for uint16 is:
	0 to 65535 
ans = The range for uint32 is:
	0 to -1 
ans = The range for uint64 is:
	0 to 18446744073709551616

Angka Floating Point Terkecil dan Terbesar

Fungsinya realmax() dan realmin() mengembalikan nilai maksimum dan minimum yang dapat direpresentasikan dengan angka floating point.

Kedua fungsi saat dipanggil dengan argumen 'tunggal', mengembalikan nilai maksimum dan minimum yang dapat Anda wakili dengan tipe data presisi tunggal dan saat dipanggil dengan argumen 'ganda', kembalikan nilai maksimum dan minimum yang dapat Anda wakili tipe data presisi ganda.

Contoh

Contoh berikut mengilustrasikan cara mendapatkan bilangan floating point terkecil dan terbesar. Buat file skrip dan tulis kode berikut di dalamnya -

% displaying the smallest and largest single-precision 
% floating point number
str = 'The range for single is:\n\t%g to %g and\n\t %g to  %g';
sprintf(str, -realmax('single'), -realmin('single'), ...
   realmin('single'), realmax('single'))

% displaying the smallest and largest double-precision 
% floating point number
str = 'The range for double is:\n\t%g to %g and\n\t %g to  %g';
sprintf(str, -realmax('double'), -realmin('double'), ...
   realmin('double'), realmax('double'))

Saat Anda menjalankan file, ini akan menampilkan hasil berikut -

ans = The range for single is:                                                  
        -3.40282e+38 to -1.17549e-38 and                                        
         1.17549e-38 to  3.40282e+38                                            
ans = The range for double is:                                                  
        -1.79769e+308 to -2.22507e-308 and                                      
         2.22507e-308 to  1.79769e+308