फोरट्रान - संख्याएँ
फोरट्रान में संख्याओं को तीन आंतरिक डेटा प्रकारों द्वारा दर्शाया जाता है -
- पूर्णांक प्रकार
- वास्तविक प्रकार
- जटिल प्रकार
पूर्णांक प्रकार
पूर्णांक प्रकार केवल पूर्णांक मान रख सकते हैं। निम्नलिखित उदाहरण सबसे बड़ा मूल्य निकालता है जो एक सामान्य चार बाइट पूर्णांक में हो सकता है -
program testingInt
implicit none
integer :: largeval
print *, huge(largeval)
end program testingInt
जब आप उपरोक्त कार्यक्रम को संकलित और निष्पादित करते हैं तो यह निम्नलिखित परिणाम उत्पन्न करता है -
2147483647
कृपया ध्यान दें कि huge()फ़ंक्शन सबसे बड़ी संख्या देता है जिसे विशिष्ट पूर्णांक डेटा प्रकार द्वारा आयोजित किया जा सकता है। आप बाइट्स की संख्या का उपयोग करके भी निर्दिष्ट कर सकते हैंkindविनिर्देशक। निम्न उदाहरण यह प्रदर्शित करता है -
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
जब आप उपरोक्त कार्यक्रम को संकलित और निष्पादित करते हैं तो यह निम्नलिखित परिणाम उत्पन्न करता है -
32767
2147483647
9223372036854775807
170141183460469231731687303715884105727
2147483647
वास्तविक प्रकार
यह फ्लोटिंग पॉइंट नंबरों को स्टोर करता है, जैसे 2.0, 3.1415, -100.876, आदि।
परंपरागत रूप से दो अलग-अलग थे real प्रकार: डिफ़ॉल्ट वास्तविक प्रकार और double precision प्रकार।
हालांकि, फोरट्रान 90/95 वास्तविक और पूर्णांक डेटा प्रकारों की सटीकता पर अधिक नियंत्रण प्रदान करता है kind विनिर्देशक, जिसे हम शीघ्र ही अध्ययन करेंगे।
निम्न उदाहरण वास्तविक डेटा प्रकार के उपयोग को दर्शाता है -
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
जब आप उपरोक्त कार्यक्रम को संकलित और निष्पादित करते हैं तो यह निम्नलिखित परिणाम उत्पन्न करता है -
0.666666687
0
जटिल प्रकार
इसका उपयोग जटिल संख्याओं के भंडारण के लिए किया जाता है। एक जटिल संख्या के दो भाग होते हैं: वास्तविक भाग और काल्पनिक भाग। दो लगातार संख्यात्मक भंडारण इकाइयां इन दो भागों को संग्रहीत करती हैं।
उदाहरण के लिए, जटिल संख्या (3.0, -5.0) 3.0 - 5.0i के बराबर है
सामान्य कार्य cmplx()एक जटिल संख्या बनाता है। यह एक परिणाम उत्पन्न करता है जो वास्तविक और काल्पनिक भागों एकल परिशुद्धता हैं, भले ही इनपुट तर्कों के प्रकार के बावजूद।
program createComplex
implicit none
integer :: i = 10
real :: x = 5.17
print *, cmplx(i, x)
end program createComplex
जब आप उपरोक्त कार्यक्रम को संकलित और निष्पादित करते हैं तो यह निम्नलिखित परिणाम उत्पन्न करता है -
(10.0000000, 5.17000008)
निम्नलिखित कार्यक्रम जटिल संख्या अंकगणितीय प्रदर्शित करता है -
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
जब आप उपरोक्त कार्यक्रम को संकलित और निष्पादित करते हैं तो यह निम्नलिखित परिणाम उत्पन्न करता है -
(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)
रेंज, परिशुद्धता और संख्याओं का आकार
पूर्णांक संख्याओं पर सीमा, फ़्लोटिंग पॉइंट संख्याओं का सटीक और आकार विशिष्ट डेटा प्रकार के लिए आवंटित बिट्स की संख्या पर निर्भर करता है।
निम्न तालिका बिट्स की संख्या और पूर्णांक के लिए सीमा प्रदर्शित करती है -
बिट्स की संख्या | अधिकतम मूल्य | कारण |
---|---|---|
64 | 9.223.372.036.854.774.807 | (2 ** 63) -1 |
32 | 2,147,483,647 | (2 ** 31) -1 |
निम्न तालिका बिट्स की संख्या, सबसे छोटी और सबसे बड़ी मूल्य, और वास्तविक संख्या के लिए सटीक प्रदर्शित करती है।
बिट्स की संख्या | सबसे बड़ा मूल्य | सबसे छोटा मान | शुद्धता |
---|---|---|---|
64 | 0.8E + 308 | 0.5E-308 | 15-18 |
32 | 1.7E + 38 | 0.3E-38 | 6-9 |
निम्नलिखित उदाहरण इसे प्रदर्शित करते हैं -
program rangePrecision
implicit none
real:: x, y, z
x = 1.5e+40
y = 3.73e+40
z = x * y
print *, z
end program rangePrecision
जब आप उपरोक्त कार्यक्रम को संकलित और निष्पादित करते हैं तो यह निम्नलिखित परिणाम उत्पन्न करता है -
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)
अब एक छोटी संख्या का उपयोग करते हैं -
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
जब आप उपरोक्त कार्यक्रम को संकलित और निष्पादित करते हैं तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Infinity
0.402144760
अब देखते हैं अंडरफ्लो -
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
जब आप उपरोक्त कार्यक्रम को संकलित और निष्पादित करते हैं तो यह निम्नलिखित परिणाम उत्पन्न करता है -
y = 3.73e-60
1
Warning : Real constant underflows its kind at (1)
Executing the program....
$demo
0.00000000E+00
Infinity
तरह का विनिर्देशक
वैज्ञानिक प्रोग्रामिंग में, किसी को अक्सर हार्डवेयर प्लेटफॉर्म के डेटा की सीमा और सटीकता की आवश्यकता होती है, जिस पर काम किया जा रहा है।
आंतरिक कार्य kind() आपको प्रोग्राम चलाने से पहले हार्डवेयर के डेटा अभ्यावेदन का विवरण क्वेरी करने की अनुमति देता है।
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
जब आप उपरोक्त कार्यक्रम को संकलित और निष्पादित करते हैं तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Integer 4
Real 4
Complex 4
आप सभी प्रकार के डेटा भी देख सकते हैं -
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
जब आप उपरोक्त कार्यक्रम को संकलित और निष्पादित करते हैं तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Integer 4
Real 4
Complex 4
Character 1
Logical 4