फोरट्रान - संख्याएँ

फोरट्रान में संख्याओं को तीन आंतरिक डेटा प्रकारों द्वारा दर्शाया जाता है -

  • पूर्णांक प्रकार
  • वास्तविक प्रकार
  • जटिल प्रकार

पूर्णांक प्रकार

पूर्णांक प्रकार केवल पूर्णांक मान रख सकते हैं। निम्नलिखित उदाहरण सबसे बड़ा मूल्य निकालता है जो एक सामान्य चार बाइट पूर्णांक में हो सकता है -

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