Fortran - Angka
Angka di Fortran diwakili oleh tiga tipe data intrinsik -
- Jenis bilangan bulat
- Tipe nyata
- Tipe kompleks
Jenis Integer
Jenis integer hanya dapat menampung nilai integer. Contoh berikut mengekstrak nilai terbesar yang dapat disimpan dalam bilangan bulat empat byte biasa -
program testingInt
implicit none
integer :: largeval
print *, huge(largeval)
end program testingInt
Ketika Anda mengkompilasi dan menjalankan program di atas, ini menghasilkan hasil sebagai berikut -
2147483647
Harap dicatat bahwa huge()function memberikan angka terbesar yang dapat dipegang oleh tipe data integer tertentu. Anda juga dapat menentukan jumlah byte menggunakankindpenentu. Contoh berikut menunjukkan ini -
program testingInt
implicit none
!two byte integer
integer(kind = 2) :: shortval
!four byte integer
integer(kind = 4) :: longval
!eight byte integer
integer(kind = 8) :: verylongval
!sixteen byte integer
integer(kind = 16) :: veryverylongval
!default integer
integer :: defval
print *, huge(shortval)
print *, huge(longval)
print *, huge(verylongval)
print *, huge(veryverylongval)
print *, huge(defval)
end program testingInt
Ketika Anda mengkompilasi dan menjalankan program di atas, ini menghasilkan hasil sebagai berikut -
32767
2147483647
9223372036854775807
170141183460469231731687303715884105727
2147483647
Tipe Nyata
Ini menyimpan angka floating point, seperti 2.0, 3.1415, -100.876, dll.
Secara tradisional ada dua perbedaan real jenis: tipe asli default dan double precision Tipe.
Namun, Fortran 90/95 memberikan kontrol lebih besar atas ketepatan tipe data nyata dan integer melalui kind specifier, yang akan kita pelajari sebentar lagi.
Contoh berikut menunjukkan penggunaan tipe data nyata -
program division
implicit none
! Define real variables
real :: p, q, realRes
! Define integer variables
integer :: i, j, intRes
! Assigning values
p = 2.0
q = 3.0
i = 2
j = 3
! floating point division
realRes = p/q
intRes = i/j
print *, realRes
print *, intRes
end program division
Ketika Anda mengkompilasi dan menjalankan program di atas, ini menghasilkan hasil sebagai berikut -
0.666666687
0
Tipe Kompleks
Ini digunakan untuk menyimpan bilangan kompleks. Bilangan kompleks memiliki dua bagian: bagian nyata dan bagian imajiner. Dua unit penyimpanan numerik yang berurutan menyimpan dua bagian ini.
Misalnya, bilangan kompleks (3.0, -5.0) sama dengan 3.0 - 5.0i
Fungsi generik cmplx()membuat bilangan kompleks. Ini menghasilkan hasil yang bagian nyata dan imajiner adalah presisi tunggal, terlepas dari jenis argumen input.
program createComplex
implicit none
integer :: i = 10
real :: x = 5.17
print *, cmplx(i, x)
end program createComplex
Ketika Anda mengkompilasi dan menjalankan program di atas, ini menghasilkan hasil sebagai berikut -
(10.0000000, 5.17000008)
Program berikut menunjukkan aritmatika bilangan kompleks -
program ComplexArithmatic
implicit none
complex, parameter :: i = (0, 1) ! sqrt(-1)
complex :: x, y, z
x = (7, 8);
y = (5, -7)
write(*,*) i * x * y
z = x + y
print *, "z = x + y = ", z
z = x - y
print *, "z = x - y = ", z
z = x * y
print *, "z = x * y = ", z
z = x / y
print *, "z = x / y = ", z
end program ComplexArithmatic
Ketika Anda mengkompilasi dan menjalankan program di atas, ini menghasilkan hasil sebagai berikut -
(9.00000000, 91.0000000)
z = x + y = (12.0000000, 1.00000000)
z = x - y = (2.00000000, 15.0000000)
z = x * y = (91.0000000, -9.00000000)
z = x / y = (-0.283783793, 1.20270276)
Rentang, Presisi dan Ukuran Angka
Kisaran pada bilangan integer, presisi dan ukuran bilangan floating point bergantung pada jumlah bit yang dialokasikan untuk tipe data tertentu.
Tabel berikut menampilkan jumlah bit dan rentang untuk bilangan bulat -
Jumlah bit | Nilai maksimum | Alasan |
---|---|---|
64 | 9.223.372.036.854.774.807 | (2 ** 63) –1 |
32 | 2.147.483.647 | (2 ** 31) –1 |
Tabel berikut menampilkan jumlah bit, nilai terkecil dan terbesar, dan presisi untuk bilangan real.
Jumlah bit | Nilai terbesar | Nilai terkecil | Presisi |
---|---|---|---|
64 | 0.8E + 308 | 0,5E – 308 | 15–18 |
32 | 1.7E + 38 | 0,3E – 38 | 6-9 |
Contoh berikut menunjukkan ini -
program rangePrecision
implicit none
real:: x, y, z
x = 1.5e+40
y = 3.73e+40
z = x * y
print *, z
end program rangePrecision
Ketika Anda mengkompilasi dan menjalankan program di atas, ini menghasilkan hasil sebagai berikut -
x = 1.5e+40
1
Error : Real constant overflows its kind at (1)
main.f95:5.12:
y = 3.73e+40
1
Error : Real constant overflows its kind at (1)
Sekarang mari kita gunakan angka yang lebih kecil -
program rangePrecision
implicit none
real:: x, y, z
x = 1.5e+20
y = 3.73e+20
z = x * y
print *, z
z = x/y
print *, z
end program rangePrecision
Ketika Anda mengkompilasi dan menjalankan program di atas, ini menghasilkan hasil sebagai berikut -
Infinity
0.402144760
Sekarang mari kita perhatikan underflow -
program rangePrecision
implicit none
real:: x, y, z
x = 1.5e-30
y = 3.73e-60
z = x * y
print *, z
z = x/y
print *, z
end program rangePrecision
Ketika Anda mengkompilasi dan menjalankan program di atas, ini menghasilkan hasil sebagai berikut -
y = 3.73e-60
1
Warning : Real constant underflows its kind at (1)
Executing the program....
$demo
0.00000000E+00
Infinity
Penentu Jenis
Dalam pemrograman ilmiah, seseorang sering kali perlu mengetahui jangkauan dan ketepatan data dari platform perangkat keras tempat pekerjaan dilakukan.
Fungsi intrinsik kind() memungkinkan Anda untuk menanyakan detail representasi data perangkat keras sebelum menjalankan program.
program kindCheck
implicit none
integer :: i
real :: r
complex :: cp
print *,' Integer ', kind(i)
print *,' Real ', kind(r)
print *,' Complex ', kind(cp)
end program kindCheck
Ketika Anda mengkompilasi dan menjalankan program di atas, ini menghasilkan hasil sebagai berikut -
Integer 4
Real 4
Complex 4
Anda juga dapat memeriksa jenis semua tipe data -
program checkKind
implicit none
integer :: i
real :: r
character :: c
logical :: lg
complex :: cp
print *,' Integer ', kind(i)
print *,' Real ', kind(r)
print *,' Complex ', kind(cp)
print *,' Character ', kind(c)
print *,' Logical ', kind(lg)
end program checkKind
Ketika Anda mengkompilasi dan menjalankan program di atas, ini menghasilkan hasil sebagai berikut -
Integer 4
Real 4
Complex 4
Character 1
Logical 4